您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關(guān)Django中怎么通過搭建MySQL主從實(shí)現(xiàn)讀寫分離,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
主從配置原理:
主庫寫日志到 BinLog
從庫開個(gè) IO 線程讀取主庫的 BinLog 日志,并寫入 RelayLog
再開一個(gè) SQL 線程,讀 RelayLog 日志,回放到從庫中
主從配置流程:
master 會(huì)將變動(dòng)記錄到二進(jìn)制日志里面;
master 有一個(gè) I/O 線程將二進(jìn)制日志發(fā)送到 slave;
salve 有一個(gè) I/O 線程把 master 發(fā)送的二進(jìn)制寫入到 relay 日志里面;
slave 有一個(gè) SQL 線程,按照 relay 日志處理 slave 的數(shù)據(jù);
使用 docker 模擬兩臺(tái) MySQL 數(shù)據(jù)庫機(jī)器
1、修改配置文件:
主庫的配置文件
[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 # 主庫,同一局域網(wǎng)內(nèi)注意要唯一 log-bin=mysql-bin # 開啟二進(jìn)制日志功能,可以隨便取名字(二進(jìn)制文件名) [client] default-character-set=utf8 [mysql] default-character-set=utf8
從庫的配置文件
[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 # 從庫設(shè)置server_id,注意要唯一 log-bin=mysql-slave-bin # 開啟二進(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)主庫容器(掛載外部目錄,端口映射成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)從庫容器(掛載外部目錄,端口映射成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、由于主庫和從庫都需要對(duì)日志文件進(jìn)行操作,這就需要另一個(gè)用戶來操作,所以主從都需要?jiǎng)?chuàng)建一個(gè)用戶
# 連接庫 mysql -h 192.168.88.131 -P 33307 -u root -p123456 # 在主庫創(chuàng)建用戶并授權(quán) # 創(chuàng)建test用戶 create user 'test' identified by '123'; # 授權(quán)用戶 grant all privileges on *.* to 'test' ; # 刷新權(quán)限 flush privileges;
3、連接從庫配置
# 連接從庫 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; # 啟用從庫 start slave; # 停止從庫 stop slave; # 查看從庫狀態(tài) show slave status\G; # 這兩個(gè)yes表示匹配成功 -Slave_IO_Running: Yes -Slave_SQL_Running: Yes # 配置詳解 change master to master_host='MySQL主服務(wù)器IP地址', master_user='之前在MySQL主服務(wù)器上面創(chuàng)建的用戶名', 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; 查看
首先主從搭建好了后:
在 setting 中配置
DATABASES = { # 主庫 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'test', 'USER': 'root', 'PASSWORD': '123456', 'HOST': '192.168.88.131', 'PORT': 33307, }, # 從庫 'slave': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'test', 'USER': 'root', 'PASSWORD': '123456', 'HOST': '192.168.88.131', 'PORT': 33306, }, }
在數(shù)據(jù)庫遷移的時(shí)候,可以指定把那個(gè)app的表結(jié)構(gòu)遷移到那個(gè)庫
python manage.py migrate app01 --database=default
手動(dòng)指定
# 去default庫寫——>主庫 content = models.User.objects.using('default').create(name='小楊', age='20') # 去slave庫查——>從庫 content = models.User.objects.using('slave').all().first()
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ì)去從庫讀 return 'slave' else: return 'default' def db_for_write(self, model, **hints): return 'default'
2、在 setting 中注冊(cè)
DATABASE_ROUTERS = ['db_router.Router',] # 以后只要是寫操作就會(huì)用default,只要是讀操作自動(dòng)去slave
看完上述內(nèi)容,你們對(duì)Django中怎么通過搭建MySQL主從實(shí)現(xiàn)讀寫分離有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。