日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長(zhǎng)提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請(qǐng)做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢(xún)客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會(huì)員:747

一、MySQL主從搭建

主從配置原理:

  1. 主庫(kù)寫(xiě)日志到 BinLog
  2. 從庫(kù)開(kāi)個(gè) IO 線程讀取主庫(kù)的 BinLog 日志,并寫(xiě)入 RelayLog
  3. 再開(kāi)一個(gè) SQL 線程,讀 RelayLog 日志,回放到從庫(kù)中

主從配置流程:

  1. master 會(huì)將變動(dòng)記錄到二進(jìn)制日志里面;
  2. master 有一個(gè) I/O 線程將二進(jìn)制日志發(fā)送到 slave;
  3. salve 有一個(gè) I/O 線程把 master 發(fā)送的二進(jìn)制寫(xiě)入到 relay 日志里面;
  4. slave 有一個(gè) SQL 線程,按照 relay 日志處理 slave 的數(shù)據(jù);

操作步驟

使用 Docker 模擬兩臺(tái) MySQL 數(shù)據(jù)庫(kù)機(jī)器

1、修改配置文件:

主庫(kù)的配置文件

[mysqld]
user=mysql
character-set-server=utf8
default_authentication_plugin=mysql_native_password
secure_file_priv=/var/lib/mysql
expire_logs_days=7
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
max_connections=1000

server-id=100  		# 主庫(kù),同一局域網(wǎng)內(nèi)注意要唯一
log-bin=mysql-bin	# 開(kāi)啟二進(jìn)制日志功能,可以隨便取名字(二進(jìn)制文件名)

[client]
default-character-set=utf8
[mysql]
default-character-set=utf8

從庫(kù)的配置文件

[mysqld]
user=mysql
character-set-server=utf8
default_authentication_plugin=mysql_native_password
secure_file_priv=/var/lib/mysql
expire_logs_days=7
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
max_connections=1000

server-id=101 					# 從庫(kù)設(shè)置server_id,注意要唯一
log-bin=mysql-slave-bin			# 開(kāi)啟二進(jìn)制日志功能,定義名字,以備Slave作為其它Slave的Master時(shí)使用
relay_log=edu-mysql-relay-bin	# relay_log配置中繼日志

[client]
default-character-set=utf8
[mysql]
default-character-set=utf8

啟動(dòng)docker

#啟動(dòng)主庫(kù)容器(掛載外部目錄,端口映射成33307,密碼設(shè)置為123456)
docker run  -di -v /home/mysql/data/:/var/lib/mysql -v /home/mysql/conf.d:/etc/mysql/conf.d -v /home/mysql/my.cnf:/etc/mysql/my.cnf -p 33307:3306 --name mysql-master -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7
                    
#啟動(dòng)從庫(kù)容器(掛載外部目錄,端口映射成33306,密碼設(shè)置為123456)
docker run  -di -v /home/mysql2/data/:/var/lib/mysql -v /home/mysql2/conf.d:/etc/mysql/conf.d -v /home/mysql2/my.cnf:/etc/mysql/my.cnf -p 33306:3306 --name mysql-slave -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7

2、由于主庫(kù)和從庫(kù)都需要對(duì)日志文件進(jìn)行操作,這就需要另一個(gè)用戶(hù)來(lái)操作,所以主從都需要?jiǎng)?chuàng)建一個(gè)用戶(hù)

# 連接庫(kù)
mysql -h 192.168.88.131 -P 33307 -u root -p123456

# 在主庫(kù)創(chuàng)建用戶(hù)并授權(quán)
# 創(chuàng)建test用戶(hù)
create user 'test' identified by '123';
# 授權(quán)用戶(hù)
grant all privileges on *.* to 'test' ;
# 刷新權(quán)限
flush privileges;

3、連接從庫(kù)配置

# 連接從庫(kù)
mysql -h 192.168.88.131 -P 33306 -u root -p123456

# 命令如下
change master to master_host='192.168.88.131',master_port=33307,master_user='test',master_password='123',master_log_file='mysql-bin.000003',master_log_pos=0;

# 啟用從庫(kù)
start slave;
# 停止從庫(kù)
stop slave;
# 查看從庫(kù)狀態(tài)
show slave statusG;
# 這兩個(gè)yes表示匹配成功
    -Slave_IO_Running: Yes
    -Slave_SQL_Running: Yes


# 配置詳解
change master to 
master_host='MySQL主服務(wù)器IP地址', 
master_user='之前在MySQL主服務(wù)器上面創(chuàng)建的用戶(hù)名', 
master_password='之前創(chuàng)建的密碼', 
master_log_file='MySQL主服務(wù)器狀態(tài)中的二進(jìn)制文件名', 		# show master status; 查看
master_log_pos='MySQL主服務(wù)器狀態(tài)中的position值';		# show master status; 查看

二、Django實(shí)現(xiàn)讀寫(xiě)分離

首先主從搭建好了后:

在 setting 中配置

DATABASES = {
    # 主庫(kù)
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'test',
        'USER': 'root',
        'PASSWORD': '123456',
        'HOST': '192.168.88.131',
        'PORT': 33307,
    },
    # 從庫(kù)
    'slave': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'test',
        'USER': 'root',
        'PASSWORD': '123456',
        'HOST': '192.168.88.131',
        'PORT': 33306,
    },
}

在數(shù)據(jù)庫(kù)遷移的時(shí)候,可以指定把那個(gè)App的表結(jié)構(gòu)遷移到那個(gè)庫(kù)

Python manage.py migrate app01 --database=default

手動(dòng)指定

# 去default庫(kù)寫(xiě)——>主庫(kù)
content = models.User.objects.using('default').create(name='小楊', age='20')

# 去slave庫(kù)查——>從庫(kù)
content = models.User.objects.using('slave').all().first()

自動(dòng)指定

1、新建一個(gè)py文件

db_router.py

class Router:
    def db_for_read(self, model, **hints):
        return 'slave'

    def db_for_write(self, mode, **hints):
        return 'default'
    
    
# 更細(xì)粒度
class Router1:
    def db_for_read(self, model, **hints):
        if model._meta.model_name == 'user':	# 只有User表才會(huì)去從庫(kù)讀
            return 'slave'
        else:
            return 'default'

    def db_for_write(self, model, **hints):
        return 'default'

2、在 setting 中注冊(cè)

DATABASE_ROUTERS = ['db_router.Router',]
# 以后只要是寫(xiě)操作就會(huì)用default,只要是讀操作自動(dòng)去slave

分享到:
標(biāo)簽:讀寫(xiě) 分離
用戶(hù)無(wú)頭像

網(wǎng)友整理

注冊(cè)時(shí)間:

網(wǎng)站:5 個(gè)   小程序:0 個(gè)  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會(huì)員

趕快注冊(cè)賬號(hào),推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過(guò)答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫(kù),初中,高中,大學(xué)四六

運(yùn)動(dòng)步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動(dòng)步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績(jī)?cè)u(píng)定2018-06-03

通用課目體育訓(xùn)練成績(jī)?cè)u(píng)定