91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Django中怎么通過搭建MySQL主從實現讀寫分離

發布時間:2021-08-12 10:49:02 來源:億速云 閱讀:192 作者:Leah 欄目:開發技術

今天就跟大家聊聊有關Django中怎么通過搭建MySQL主從實現讀寫分離,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。


一、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=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    # 主庫,同一局域網內注意要唯一
log-bin=mysql-bin # 開啟二進制日志功能,可以隨便取名字(二進制文件名)

[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      # 從庫設置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 status\G;
# 這兩個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主從實現讀寫分離有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

金湖县| 加查县| 遵化市| 津南区| 确山县| 荣昌县| 中西区| 嘉义县| 当雄县| 日照市| 富裕县| 平安县| 渝中区| 民丰县| 洞口县| 保亭| 连江县| 大姚县| 诸暨市| 靖西县| 北川| 乐平市| 兴安县| 边坝县| 尼勒克县| 土默特右旗| 化隆| 灌云县| 漳平市| 万州区| 民权县| 涟源市| 资阳市| 梅州市| 宝兴县| 永康市| 长海县| 论坛| 鄢陵县| 泰兴市| 和静县|