真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

使用Django怎么實現(xiàn)MySQL讀寫分離-創(chuàng)新互聯(lián)

本篇文章為大家展示了使用Django怎么實現(xiàn)MySQL讀寫分離,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

創(chuàng)新互聯(lián)成都企業(yè)網(wǎng)站建設(shè)服務(wù),提供成都做網(wǎng)站、網(wǎng)站設(shè)計、外貿(mào)營銷網(wǎng)站建設(shè)網(wǎng)站開發(fā),網(wǎng)站定制,建網(wǎng)站,網(wǎng)站搭建,網(wǎng)站設(shè)計,成都響應(yīng)式網(wǎng)站建設(shè),網(wǎng)頁設(shè)計師打造企業(yè)風格網(wǎng)站,提供周到的售前咨詢和貼心的售后服務(wù)。歡迎咨詢做網(wǎng)站需要多少錢:18980820575


主從同步介紹和優(yōu)點

在多臺數(shù)據(jù)服務(wù)器中,分為主服務(wù)器和從服務(wù)器。一臺主服務(wù)器對應(yīng)多臺從服務(wù)器。
主服務(wù)器只負責寫入數(shù)據(jù),從服務(wù)器只負責同步主服務(wù)器的數(shù)據(jù),并讓外部程序讀取數(shù)據(jù)。
主服務(wù)器寫入數(shù)據(jù)后,即刻將寫入數(shù)據(jù)的命令發(fā)送給從服務(wù)器,從而使得主從數(shù)據(jù)同步。
應(yīng)用程序可以隨機讀取某一臺從服務(wù)器的數(shù)據(jù),這樣就可以分攤讀取數(shù)據(jù)的壓力。
當從服務(wù)器不能工作時,整個系統(tǒng)將不受影響;當主服務(wù)器不能工作時,可以方便地從從服務(wù)器選舉一臺來當主服務(wù)器
使用主從同步的優(yōu)點:
提高讀寫性能
因為主從同步之后,數(shù)據(jù)寫入和讀取是在不同的服務(wù)器上進行的,而且可以通過增加從服務(wù)器來提高數(shù)據(jù)庫的讀取性能。
提高數(shù)據(jù)安全
因為數(shù)據(jù)已復(fù)制到從服務(wù)器,可以在從服務(wù)器上備份而不破壞主服務(wù)器相應(yīng)數(shù)據(jù)。
主從同步機制
注意:MySQL服務(wù)器之間的主從同步是基于二進制日志機制,主服務(wù)器使用二進制日志來記錄數(shù)據(jù)庫的變動情況,從服務(wù)器通過讀取和執(zhí)行該日志文件來保持和主服務(wù)器的數(shù)據(jù)一致。Docker安裝運行MySQL從機
本項目中我們搭建一主一從的主從同步。主服務(wù)器:ubuntu操作系統(tǒng)中的MySQL。從服務(wù)器:Docker容器中的MySQL獲取MySQL鏡像# 主從同步盡量保證多臺MySQL的版本相同或相近
 sudo docker image pull mysql:5.7.22 # 5.7.22版本 
 sudo docker load -i 文件路徑/mysql_docker_5722.tar

指定MySQL從機配置文件在使用Docker安裝運行MySQL從機之前,需要準備好從機的配置文件。
為了快速準備從機的配置文件,我們直接把主機的配置文件拷貝到從機中。
# 創(chuàng)建MySQL從機配置文件夾
mkdir mysql_slave
# 創(chuàng)建裝數(shù)據(jù)庫數(shù)據(jù)文件夾
mkdir datacp -r /etc/mysql/mysql.conf.d ./

修改MySQL從機配置文件編輯 ~/mysql_slave/mysql.conf.d/mysqld.cnf文件。
由于主從機都在同一個電腦中,所以我們選擇使用不同的端口號區(qū)分主從機,從機端口號是8306。
# 從機端口號
port = 8306
# 關(guān)閉日志
general_log = 0
# 從機唯一編號
server-id = 2

Docker安裝運行MySQL從機創(chuàng)建 root 用戶的密碼為 mysql sudo docker run --name mysql-slave -e MYSQL_ROOT_PASSWORD=mysql -d --network=host -v /home/python/mysql_slave/data:/var/lib/mysql -v /home/python/mysql_slave/mysql.conf.d:/etc/mysql/mysql.conf.d mysql:5.7.22

測試從機是否創(chuàng)建成功mysql -uroot -pmysql -h 127.0.0.1 --port=8306

主從同步實現(xiàn)
配置主機(ubuntu中MySQL)配置文件如有修改,需要重啟主機。sudo service mysql restart
# 開啟日志
general_log_file = /var/log/mysql/mysql.log
general_log = 1
# 主機唯一編號
server-id = 1
# 二進制日志文件
log_bin = /var/log/mysql/mysql-bin.log

從機備份主機原有數(shù)據(jù)# 在做主從同步時,如果從機需要主機上原有數(shù)據(jù),就要先復(fù)制一份到從機
# 1. 收集主機原有數(shù)據(jù)
mysqldump -uroot -pmysql --all-databases --lock-all-tables > ~/master_db.sql# 2. 從機復(fù)制主機原有數(shù)據(jù)
mysql -uroot -pmysql -h227.0.0.1 --port=8306 < ~/master_db.sql

主從同步實現(xiàn)# 登錄到主機
$ mysql –uroot –pmysql
# 創(chuàng)建從機賬號
$ GRANT REPLICATION SLAVE ON *.* TO 'slave'@'%' identified by 'slave';
# 刷新權(quán)限
$ FLUSH PRIVILEGES;
# 展示ubuntu中MySQL主機的二進制日志信息
$ SHOW MASTER STATUS;
# 可以看到master_log_file和master_log_pos=Position

# 登錄到從機
$ mysql -uroot -pmysql -h 127.0.0.1 --port=8306
# 從機連接到主機
$ change master to master_host='127.0.0.1', master_user='slave', master_password='slave',master_log_file=XXX, master_log_pos=XXX;
# 開啟從機服務(wù)
$ start slave;
# 展示從機服務(wù)狀態(tài)
$ show slave status \G

Django實現(xiàn)MySQL讀寫分離
增加slave數(shù)據(jù)庫的配置
DATABASES = {
    'default': { # 寫(主機)
        'ENGINE': 'django.db.backends.mysql', # 數(shù)據(jù)庫引擎
        'HOST': 'XXXX', # 數(shù)據(jù)庫主機
        'PORT': 3306, # 數(shù)據(jù)庫端口
        'USER': 'XX', # 數(shù)據(jù)庫用戶名
        'PASSWORD': 'XXX', # 數(shù)據(jù)庫用戶密碼
        'NAME': 'XXX' # 數(shù)據(jù)庫名字
    },
    'slave': { # 讀(從機)
        'ENGINE': 'django.db.backends.mysql',
        'HOST': 'XXXX',
        'PORT': 8306,
        'USER': 'XXX',
        'PASSWORD': 'XXX',
        'NAME': 'XXX'
    }
}

創(chuàng)建和配置數(shù)據(jù)庫讀寫路由
創(chuàng)建數(shù)據(jù)庫讀寫路由# 在meiduo_mall.utils.db_router.py中實現(xiàn)讀寫路由

class MasterSlaveDBRouter(object):
    """數(shù)據(jù)庫讀寫路由"""    def db_for_read(self, model, **hints):
        """讀"""
        return "slave"    def db_for_write(self, model, **hints):
        """寫"""
        return "default"    def allow_relation(self, obj1, obj2, **hints):
        """是否運行關(guān)聯(lián)操作"""
        return True

配置數(shù)據(jù)庫讀寫路由# 配置數(shù)據(jù)庫讀寫分離路由
DATABASE_ROUTERS = ['meiduo_mall.utils.db_router.MasterSlaveDBRouter']

冷備份
冷備份發(fā)生在數(shù)據(jù)庫已經(jīng)正常關(guān)閉的情況下,當正常關(guān)閉時會提供給我們一個完整的數(shù)據(jù)庫。冷備份是將關(guān)鍵性文件拷貝到另外位置的一種說法。對于備份數(shù)據(jù)庫信息而言,冷備份是最快和最安全的方法。簡單說法就是:離線(沒有新的數(shù)據(jù)來)復(fù)制一份保存,有事就直接用這備份來恢復(fù)。
冷備份的優(yōu)點:
是非??焖俚膫浞莘椒ǎㄖ恍杩截愇募?br/>容易歸檔(簡單拷貝即可)
容易恢復(fù)到某個時間點上(只需將文件再拷貝回去)
能與歸檔方法相結(jié)合,作數(shù)據(jù)庫“最新狀態(tài)”的恢復(fù)。
低度維護,高度安全。
冷備份的缺點:
單獨使用時,只能提供到“某一時間點上”的恢復(fù)。
在實施備份的全過程中,數(shù)據(jù)庫必須要作備份而不能作其它工作。也就是說,在冷備份過程中,數(shù)據(jù)庫必須是關(guān)閉狀態(tài)。
若磁盤空間有限,只能拷貝到磁帶等其它外部存儲設(shè)備上,速度會很慢。
不能按表或按用戶恢復(fù)。
值得注意的是冷備份必須在數(shù)據(jù)庫關(guān)閉的情況下進行,當數(shù)據(jù)庫處于打開狀態(tài)時,執(zhí)行數(shù)據(jù)庫文件系統(tǒng)備份是無效的 。而且在恢復(fù)后一定要把數(shù)據(jù)庫文件的屬組和屬主改為mysql。熱備份
熱備份是在數(shù)據(jù)庫運行的情況下,備份數(shù)據(jù)庫操作的sql語句,當數(shù)據(jù)庫發(fā)生問題時,可以重新執(zhí)行一遍備份的sql語句。簡單說就是:在線的保存對數(shù)據(jù)庫操作的sql語句,有事就再跑一遍這些sql語句。# 在做主從同步時,如果從機需要主機上原有數(shù)據(jù),就要先復(fù)制一份到從機
# 1. 收集主機原有數(shù)據(jù)
mysqldump -uroot -pmysql --all-databases --lock-all-tables > ~/master_db.sql# 2. 從機復(fù)制主機原有數(shù)據(jù)(在配置文件所在目錄下,數(shù)據(jù)會寫入data文件中)
mysql -uroot -pmysql -h227.0.0.1 --port=8306 < ~/master_db.sql
熱備份的優(yōu)點:
可在表空間或數(shù)據(jù)文件級備份,備份時間短。
備份時數(shù)據(jù)庫仍可使用。
可達到秒級恢復(fù)(恢復(fù)到某一時間點上)。
可對幾乎所有數(shù)據(jù)庫實體作恢復(fù)。
恢復(fù)是快速的,在大多數(shù)情況下在數(shù)據(jù)庫仍工作時恢復(fù)。
熱備份的缺點:
不能出錯,否則后果嚴重。
若熱備份不成功,所得結(jié)果不可用于時間點的恢復(fù)。
因難于維護,所以要特別仔細小心,不允許“以失敗而告終”

上述內(nèi)容就是使用Django怎么實現(xiàn)MySQL讀寫分離,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道。


分享名稱:使用Django怎么實現(xiàn)MySQL讀寫分離-創(chuàng)新互聯(lián)
文章分享:http://weahome.cn/article/djoooc.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部