日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Django搭建MySQL主從實現讀寫分離

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

主從配置原理:

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

主從配置流程:

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

使用 docker 模擬兩臺 MySQL 數據庫機器

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 # 主庫,同一局域網內注意要唯一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 # 從庫設置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,密碼設置為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,密碼設置為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、由于主庫和從庫都需要對日志文件進行操作,這就需要另一個用戶來操作,所以主從都需要創建一個用戶

# 連接庫mysql -h 192.168.88.131 -P 33307 -u root -p123456# 在主庫創建用戶并授權# 創建test用戶create user ’test’ identified by ’123’;# 授權用戶grant all privileges on *.* to ’test’ ;# 刷新權限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;# 查看從庫狀態show slave statusG;# 這兩個yes表示匹配成功 -Slave_IO_Running: Yes -Slave_SQL_Running: Yes # 配置詳解change master to master_host=’MySQL主服務器IP地址’, master_user=’之前在MySQL主服務器上面創建的用戶名’, master_password=’之前創建的密碼’, master_log_file=’MySQL主服務器狀態中的二進制文件名’, # show master status; 查看master_log_pos=’MySQL主服務器狀態中的position值’; # show master status; 查看二、Django實現讀寫分離

首先主從搭建好了后:

在 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, },}

在數據庫遷移的時候,可以指定把那個app的表結構遷移到那個庫

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

到此這篇關于Django搭建MySQL主從實現讀寫分離的文章就介紹到這了,更多相關Django MySQL讀寫分離內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: MySQL 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产一区导航| 高清av一区| av日韩中文| 97精品国产福利一区二区三区| 日韩精品导航| 日本午夜精品久久久久| 欧美亚洲人成在线| 国产精品欧美三级在线观看 | 久久这里只有| 国产极品模特精品一二 | 日韩精品一区二区三区中文| 日本在线不卡视频| 国产欧美一区| 国产麻豆一区| 成人精品动漫一区二区三区| 亚洲1234区| 亚洲免费高清| 国产视频亚洲| 91亚洲精品在看在线观看高清| 国产精品欧美三级在线观看| 国产一区丝袜| 伊人精品一区| 日韩精品1区| 99国产精品久久久久久久| 亚洲综合小说| 美女视频网站久久| 成人在线网站| 亚洲丝袜啪啪| 国产精品夜夜夜| 精品亚洲a∨| 欧洲av不卡| 亚洲激情社区| 日本国产欧美| 国际精品欧美精品| 偷拍欧美精品| 日本欧美在线| av日韩中文| 亚洲激情黄色| 国产欧美啪啪| 999国产精品视频| 石原莉奈在线亚洲二区| 欧美在线不卡| 国产麻豆久久| 免费的成人av| 狠狠久久伊人| 欧美综合国产| 久久影院资源站| 91超碰国产精品| 国产欧美在线观看免费| 麻豆国产一区| 亚洲欧美成人综合| 久久精品国产网站| 亚洲一区观看| 大香伊人久久精品一区二区| 国产精品婷婷| 精品国产亚洲日本| 在线一区免费| 久久精品毛片| 六月天综合网| 香蕉视频亚洲一级| 亚洲精品动态| 麻豆网站免费在线观看| 亚洲伊人影院| 91欧美日韩| 亚洲人成亚洲精品| 欧美三级精品| 国产日韩视频| 国产午夜久久| 国产成人精品999在线观看| 久久国产精品久久久久久电车| 久久久国产精品网站| 久久午夜影视| 日韩在线精品| 亚洲精选久久| 免费一二一二在线视频| 国产亚洲久久| 日韩网站在线| 天堂√中文最新版在线| 欧美日韩一视频区二区| 99在线观看免费视频精品观看| 精品三级在线观看视频| 偷拍亚洲精品| 国产亚洲精品v| 日韩国产欧美一区二区| 欧美黄色一区| 亚欧成人精品| aa国产精品| 99成人在线视频| 麻豆精品久久久| 日韩av一区二区在线影视| 免费观看在线色综合| 免费在线小视频| 欧美国产免费| 亚洲精品无播放器在线播放| 国产综合精品一区| 日韩1区在线| 国产三级精品三级在线观看国产| 久久xxxx| 国产女优一区| 免费观看久久av| 午夜精品成人av| 国产精品黑丝在线播放| 国产精品s色| 免费视频一区二区| 香蕉精品视频在线观看| 在线看片国产福利你懂的| 国产精品66| 国产日韩欧美三级| 日韩一区二区三区高清在线观看| 亚洲一区国产| 亚洲国产成人精品女人| 日韩av一级| 欧洲在线一区| 久久蜜桃精品| 日韩精品欧美| 久久久久.com| 三级精品视频| 日韩av免费| 免费亚洲婷婷| 免费看一区二区三区| 国产精品红桃| 久久久久九九精品影院| 久久精品理论片| 美女久久一区| 成人一二三区| 久久久国产精品网站| 国产精品一区亚洲| 奇米777国产一区国产二区| 日韩中文字幕在线一区| 五月激激激综合网色播| 日本欧美一区二区| 久久狠狠久久| 欧美激情aⅴ一区二区三区 | 综合激情视频| 美国欧美日韩国产在线播放| 免费久久精品视频| 日韩国产成人精品| 久久精品 人人爱| 你懂的国产精品永久在线| 久久免费影院| 国产在线观看www| 国产精品99免费看| 99亚洲视频| 日韩和欧美一区二区三区| 欧美日韩xxxx| 久久精品伊人| 97在线精品| 久久久久久久久久久妇女| 欧美日韩国产免费观看视频| 亚洲免费中文| 国产欧美日韩视频在线| 国产一区二区三区探花| 亚洲涩涩在线| 麻豆成人在线| 欧美日韩亚洲一区三区| 精品国产精品久久一区免费式| 黑人精品一区| 欧美特黄一区| 日韩精品成人| 欧美国产小视频| 黄色精品网站| 亚洲精品在线a| 久久一区精品| 国产综合色产| 日韩国产精品久久久久久亚洲| 红杏一区二区三区| 99xxxx成人网| 国产精品探花在线观看| 久久91导航| 日本伊人久久| 美女av在线免费看| 中文字幕亚洲在线观看| 精品一区视频| 亚洲一区中文| 国产精品极品国产中出| 久久中文字幕二区| 亚洲色图网站| 久久精品国产亚洲一区二区三区| 亚洲精品午夜av福利久久蜜桃| 国产亚洲欧美日韩精品一区二区三区 | 国产精品一区二区三区四区在线观看 | 亚洲成人精品| 日日摸夜夜添夜夜添国产精品| 精品资源在线| 亚洲综合欧美| 高清av一区| 亚欧洲精品视频在线观看| 日韩一区亚洲二区| 日韩美女精品| 久久视频一区| 久久国产精品色av免费看| 久久精品亚洲欧美日韩精品中文字幕| 亚洲午夜免费| 日韩av片子| 日韩三级一区| 国产在线欧美| 国产精品一区二区免费福利视频| 不卡在线一区二区| 精品三区视频| 日韩激情网站|