国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

Django搭建MySQL主從實現(xiàn)讀寫分離

瀏覽:50日期:2023-10-18 09:09:55
目錄一、MySQL主從搭建操作步驟二、Django實現(xiàn)讀寫分離自動指定一、MySQL主從搭建

主從配置原理:

主庫寫日志到 BinLog 從庫開個 IO 線程讀取主庫的 BinLog 日志,并寫入 RelayLog 再開一個 SQL 線程,讀 RelayLog 日志,回放到從庫中

主從配置流程:

master 會將變動記錄到二進制日志里面; master 有一個 I/O 線程將二進制日志發(fā)送到 slave; salve 有一個 I/O 線程把 master 發(fā)送的二進制寫入到 relay 日志里面; slave 有一個 SQL 線程,按照 relay 日志處理 slave 的數(shù)據(jù);操作步驟

使用 docker 模擬兩臺 MySQL 數(shù)據(jù)庫機器

1、修改配置文件:

主庫的配置文件

[mysqld]user=mysqlcharacter-set-server=utf8default_authentication_plugin=mysql_native_passwordsecure_file_priv=/var/lib/mysqlexpire_logs_days=7sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTIONmax_connections=1000server-id=100 # 主庫,同一局域網(wǎng)內(nèi)注意要唯一log-bin=mysql-bin # 開啟二進制日志功能,可以隨便取名字(二進制文件名)[client]default-character-set=utf8[mysql]default-character-set=utf8

從庫的配置文件

[mysqld]user=mysqlcharacter-set-server=utf8default_authentication_plugin=mysql_native_passwordsecure_file_priv=/var/lib/mysqlexpire_logs_days=7sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTIONmax_connections=1000server-id=101 # 從庫設(shè)置server_id,注意要唯一log-bin=mysql-slave-bin # 開啟二進制日志功能,定義名字,以備Slave作為其它Slave的Master時使用relay_log=edu-mysql-relay-bin # relay_log配置中繼日志[client]default-character-set=utf8[mysql]default-character-set=utf8

啟動docker

#啟動主庫容器(掛載外部目錄,端口映射成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 #啟動從庫容器(掛載外部目錄,端口映射成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、由于主庫和從庫都需要對日志文件進行操作,這就需要另一個用戶來操作,所以主從都需要創(chuàng)建一個用戶

# 連接庫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 statusG;# 這兩個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)中的二進制文件名’, # show master status; 查看master_log_pos=’MySQL主服務(wù)器狀態(tài)中的position值’; # show master status; 查看二、Django實現(xiàn)讀寫分離

首先主從搭建好了后:

在 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ù)庫遷移的時候,可以指定把那個app的表結(jié)構(gòu)遷移到那個庫

python manage.py migrate app01 --database=default

手動指定

# 去default庫寫——>主庫content = models.User.objects.using(’default’).create(name=’小楊’, age=’20’)# 去slave庫查——>從庫content = models.User.objects.using(’slave’).all().first()自動指定

1、新建一個py文件

db_router.py

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

2、在 setting 中注冊

DATABASE_ROUTERS = [’db_router.Router’,]# 以后只要是寫操作就會用default,只要是讀操作自動去slave

到此這篇關(guān)于Django搭建MySQL主從實現(xiàn)讀寫分離的文章就介紹到這了,更多相關(guān)Django MySQL讀寫分離內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
主站蜘蛛池模板: 最新更新国内自拍视频 | 国产精品黄网站免费观看 | 鲁丝片一区二区三区免费 | 91久久综合九色综合欧美98 | 久久综合久久精品 | 99国产精品免费视频观看 | 欧美三级欧美成人高清www | 99久久国产综合精品1尤物 | 久久久精品2018免费观看 | 日本欧美久久久久免费播放网 | 亚洲国产成人久久综合一区77 | 手机在线观看一级午夜片 | 亚洲成在人线中文字幕 | 俄罗斯aa毛片一级 | 97国产成人精品免费视频 | 亚洲三级毛片 | 亚洲综合p | 欧美性精品 | 男人天堂网址 | 国内视频一区二区 | 日韩高清一级 | 中国黄色一级毛片 | 九九午夜| 在线91精品亚洲网站精品成人 | 黄视频在线免费看 | 国产欧美一区二区精品久久久 | 中文字幕在线一区二区在线 | 久久羞羞 | 欧美一级特黄aaaaaa在线看首页 | 午夜毛片视频高清不卡免费 | 日本高清无吗免费播放 | 久久91精品国产91久久跳舞 | 国产香港特级一级毛片 | 欧美顶级毛片在线播放小说 | 国产日产久久 | 中文字幕在线成人免费看 | 女人张开双腿让男人桶完整 | 精品国产杨幂在线观看福利 | 国产精品夜色视频一级区 | 萌白酱香蕉白丝护士服喷浆 | 久久久久女人精品毛片 |