五月综合激情婷婷六月,日韩欧美国产一区不卡,他扒开我内裤强吻我下面视频 ,无套内射无矿码免费看黄,天天躁,日日躁,狠狠躁

新聞動(dòng)態(tài)

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

發(fā)布日期:2022-02-14 09:07 | 文章來源:站長之家

一、MySQL主從搭建

主從配置原理:

  • 主庫寫日志到 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; 查看

二、Django實(shí)現(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ù)庫遷移的時(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()

自動(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ì)去從庫讀
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

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

海外穩(wěn)定服務(wù)器

版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。

相關(guān)文章

實(shí)時(shí)開通

自選配置、實(shí)時(shí)開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對(duì)1客戶咨詢顧問

在線
客服

在線客服:7*24小時(shí)在線

客服
熱線

400-630-3752
7*24小時(shí)客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部