电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:55日期: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 數據庫
相關文章:
主站蜘蛛池模板: 广东燎了网络科技有限公司官网-网站建设-珠海网络推广-高端营销型外贸网站建设-珠海专业h5建站公司「了了网」 | 绿萝净除甲醛|深圳除甲醛公司|测甲醛怎么收费|培训机构|电影院|办公室|车内|室内除甲醛案例|原理|方法|价格立马咨询 | 糖衣机,除尘式糖衣机,全自动糖衣机,泰州市长江制药机械有限公司 体感VRAR全息沉浸式3D投影多媒体展厅展会游戏互动-万展互动 | 哈希余氯测定仪,分光光度计,ph在线监测仪,浊度测定仪,试剂-上海京灿精密机械有限公司 | 科昊仪器超纯水机系统-可成气相液氮罐-美菱超低温冰箱-西安昊兴生物科技有限公司 | 安全阀_弹簧式安全阀_美标安全阀_工业冷冻安全阀厂家-中国·阿司米阀门有限公司 | 拉力机-万能试验机-材料拉伸试验机-电子拉力机-拉力试验机厂家-冲击试验机-苏州皖仪实验仪器有限公司 | 经济师考试_2025中级经济师报名时间_报名入口_考试时间_华课网校经济师培训网站 | 智成电子深圳tdk一级代理-提供TDK电容电感贴片蜂鸣器磁芯lambda电源代理经销,TDK代理商有哪些TDK一级代理商排名查询。-深圳tdk一级代理 | 郑州巴特熔体泵有限公司专业的熔体泵,熔体齿轮泵与换网器生产厂家 | 洛阳永磁工业大吊扇研发生产-工厂通风降温解决方案提供商-中实洛阳环境科技有限公司 | 全自动贴标机-套标机-工业热风机-不干胶贴标机-上海厚冉机械 | 爱德华真空泵油/罗茨泵维修,爱发科-比其尔产品供应东莞/杭州/上海等全国各地 | 液氮罐_液氮容器_自增压液氮罐-北京君方科仪科技发展有限公司 | 植筋胶-粘钢胶-碳纤维布-碳纤维板-环氧砂浆-加固材料生产厂家-上海巧力建筑科技有限公司 | 神超官网_焊接圆锯片_高速钢锯片_硬质合金锯片_浙江神超锯业制造有限公司 | 棉服定制/厂家/公司_棉袄订做/价格/费用-北京圣达信棉服 | 爱佩恒温恒湿测试箱|高低温实验箱|高低温冲击试验箱|冷热冲击试验箱-您身边的模拟环境试验设备技术专家-合作热线:400-6727-800-广东爱佩试验设备有限公司 | 动物麻醉机-数显脑立体定位仪-北京易则佳科技有限公司 | 中央空调温控器_风机盘管温控器_智能_液晶_三速开关面板-中央空调温控器厂家 | 防爆电机生产厂家,YBK3电动机,YBX3系列防爆电机,YBX4节防爆电机--河南省南洋防爆电机有限公司 | 祝融环境-地源热泵多恒系统高新技术企业,舒适生活环境缔造者! | 房间温控器|LonWorks|海思| 在线悬浮物浓度计-多参数水质在线检测仪-上海沃懋仪表科技有限公司 | 瑞典Blueair空气净化器租赁服务中心-专注新装修办公室除醛去异味服务! | 半容积式换热器_北京浮动盘管换热器厂家|北京亿丰上达 | 单级/双级旋片式真空泵厂家,2xz旋片真空泵-浙江台州求精真空泵有限公司 | 上海橡胶接头_弹簧减震器_金属软接头厂家-上海淞江集团 | 电动打包机_气动打包机_钢带捆扎机_废纸打包机_手动捆扎机 | 国际船舶网 - 船厂、船舶、造船、船舶设备、航运及海洋工程等相关行业综合信息平台 | 压缩空气冷冻式干燥机_吸附式干燥机_吸干机_沪盛冷干机 | 今日娱乐圈——影视剧集_八卦娱乐_明星八卦_最新娱乐八卦新闻 | 首页 - 张店继勇软件开发工作室 兰州UPS电源,兰州山特UPS-兰州万胜商贸 | 四川实木门_成都实木门 - 蓬溪聚成门业有限公司 | PSI渗透压仪,TPS酸度计,美国CHAI PCR仪,渗透压仪厂家_价格,微生物快速检测仪-华泰和合(北京)商贸有限公司 | 净化车间_洁净厂房_净化公司_净化厂房_无尘室工程_洁净工程装修|改造|施工-深圳净化公司 | 土壤养分检测仪|土壤水分|土壤紧实度测定仪|土壤墒情监测系统-土壤仪器网 | 仓储货架_南京货架_钢制托盘_仓储笼_隔离网_环球零件盒_诺力液压车_货架-南京一品仓储设备制造公司 | 石磨面粉机|石磨面粉机械|石磨面粉机组|石磨面粉成套设备-河南成立粮油机械有限公司 | 北京亦庄厂房出租_经开区产业园招商信息平台 | 企业管理培训,企业培训公开课,企业内训课程,企业培训师 - 名课堂企业管理培训网 |