欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mysql數(shù)據(jù)庫主從同步的實現(xiàn)示例

 更新時間:2025年06月23日 09:43:48   作者:Mr_葉落飄霜  
本文主要介紹了Mysql數(shù)據(jù)庫主從同步的實現(xiàn)示例,包括配置文件設置、賬戶創(chuàng)建、同步命令及錯誤處理,具有一定的參考價值,感興趣的可以了解一下

MySQL數(shù)據(jù)庫的主從復制是一種常見的數(shù)據(jù)備份和高可用性解決方案。通過配置主從復制,可以實現(xiàn)將數(shù)據(jù)從一個MySQL服務器(主服務器)同步到另一個(從服務器)。

前言

mysql數(shù)據(jù)庫的主從同步設置需要修改主庫和從庫的配置文件,并執(zhí)行同步指令,步驟并不復雜。但是在部署過程中還是遇到一些問題,找了很久好像沒人遇到相同的問題,因此將部署流程與遇到的問題分享出來,希望遇到同樣問題時有參考依據(jù)。

1.主庫(主服務器)配置

1.1修改主庫配置文件,啟用二進制日志

數(shù)據(jù)庫配置文件所在目錄:
CentOS7安裝mysql后,配置文件默認路徑為:/etc/my.cnf
Windows安裝mysql后,配置文件默認路徑為:C:\ProgramData\MySQL\MySQL Server 5.7
本次安裝的主服務器CentOS7中,因此需要進入到/ect目錄下,修改my.cnf配置文件:

#進入etc目錄下
cd /etc
#編輯mysql配置文件
vi my.cnf

在配置文件[mysqld]最后一行,添加以下內容:

#mysql主庫配置
server_id = 88               #集群唯一標識,主庫從庫不能重復(值為數(shù)據(jù)庫IP)
log_bin = mysql-bin          #開啟二進制日志
expire_logs_days = 7         #日志有效期(天)

請?zhí)砑訄D片描述

內容說明:#集群唯一標識,主庫從庫不能重復,建議值取數(shù)據(jù)庫IP,避免重復(該項必須配置)
server_id = 88
#開啟mysql二進制日志(該項必須配置)
log_bin = mysql-bin
#設置同步日志有效期(天),到期自動清理,避免磁盤占用空間過大(該項建議配置)
expire_logs_days = 7

1.2重啟數(shù)據(jù)庫服務

Mysql數(shù)據(jù)庫修改my.cnf配置文件后,需要重啟數(shù)據(jù)庫才能使修改的配置文件生效:

systemctl restart mysqld

重啟數(shù)據(jù)庫后,可以查看數(shù)據(jù)庫的運行狀態(tài),確保數(shù)據(jù)庫正常運行(active):

systemctl status mysqld

在這里插入圖片描述

1.3創(chuàng)建遠程連接賬戶

從庫同步主庫的數(shù)據(jù),那么從庫需要先連接到主庫。初始的root賬戶只能在主庫服務器中登錄,在從庫所在服務器中使用該賬戶是無法登錄的,因此需要創(chuàng)建一個遠程連接的賬戶:
登錄數(shù)據(jù)庫:mysql -uroot -p數(shù)據(jù)庫密碼在Windows中直接通過命令行登錄到mysql,需要將mysql添加到環(huán)境變量。本次創(chuàng)建一個遠程連接賬戶’slave’,密碼為’test’(可以根據(jù)自己需要創(chuàng)建不同的賬戶密碼),賦予賬戶只有復制權限:

方法一(分步執(zhí)行):

創(chuàng)建mysql賬戶:

CREATE USER 'slave'@'%' IDENTIFIED BY 'test';

%表示賬戶開通遠程連接,允許所有IP通過該賬戶登錄數(shù)據(jù)庫。

授權該賬戶只有復制的權限:

GRANT REPLICATION SLAVE ON *.* TO 'slave'@'%';

REPLICATION SLAVE 表示僅給該賬戶復制的權限,*.*表示可以該賬戶的權限對所有的數(shù)據(jù)庫和數(shù)據(jù)表都有效,可以復制所有數(shù)據(jù)庫和表,%表示所有IP都可以通過該賬戶連接到數(shù)據(jù)庫。

刷新權限:

flush privileges; 

方法二(合并執(zhí)行):

創(chuàng)建一個賬戶只有復制權限(slave),權限對所有數(shù)據(jù)庫和表生效(*.*),‘slave’賬號,密碼為’test’:

grant replication slave on *.* to 'slave'@'%' identified by 'test';

1.4查看master狀態(tài),記錄二進制文件名(File)和位置(Position):

復制主機的數(shù)據(jù)庫,需要先查詢主機數(shù)據(jù)庫二進制日志的文件名和文件所在位置的,命令如下:

SHOW MASTER STATUS;

在這里插入圖片描述

1.5停止主機數(shù)據(jù)庫的寫操作

注意:從機開始同步之前,主機不能再進行寫操作,如果主機仍在進行寫操作,會導致同步失敗,導致同步無法繼續(xù)執(zhí)行。因此,建議在執(zhí)行同步之前,先把所有連接到mysql數(shù)據(jù)庫的jar、tomcat、中間件、exe程序全部停止,停止程序往主機繼續(xù)寫入數(shù)據(jù),同步時確保數(shù)據(jù)的一致性。

2.從庫(從機)配置

2.1修改從庫配置文件

本次從機安裝在Windows系統(tǒng)中,需要進入mysql的配置文件目錄下,修改配置文件
C:\ProgramData\MySQL\MySQL Server 5.7\my.ini
{如果從機安裝在CentOS7下,則需要修改/etc/my.cnf配置文件,添加以下內容}

在這里插入圖片描述

簡單的配置只需要需改從機的id即可完成。修改server-id,改成與主機不沖突的值(建議取從機的IP,避免沖突)。
進階配置如下圖所示:

在這里插入圖片描述

#mysql從機配置
#從機唯一標識,與主庫不能重復(值取IP地址)
server-id=66
#設置日志保存時長
expire_logs_days=7
#數(shù)據(jù)庫宕機后自動恢復日志,從庫建議開啟,有利于數(shù)據(jù)一致性
relay_log_recovery=1

2.2重啟從機Mysql服務

本次從機安裝在Windows系統(tǒng)中,安裝Mysql后會出現(xiàn)在系統(tǒng)服務中。修改配置文件后,需要重啟系統(tǒng)服務才能適用新的改動:

在這里插入圖片描述

如果從機安裝在CentOS7下,則通過命令重啟Mysql:

systemctl restart mysqld

2.3導入數(shù)據(jù)庫

注意:如果已停止所有程序對數(shù)據(jù)庫的寫入操作,則可以直接將數(shù)據(jù)庫全部同步過來,無需創(chuàng)建導入數(shù)據(jù)庫,此步驟可忽略進入下一步。直接看下一個步驟:2.4開始主從同步。

由于本次同步時,未停止程序對數(shù)據(jù)庫寫入操作,導致在使用中的數(shù)據(jù)庫無法同步到從機中,因此需要手動導入數(shù)據(jù)庫。雖然設置了主從同步,但是如果主庫未停止寫入,從庫并不會將主機在使用中的數(shù)據(jù)庫直接同步復制到從機。因此必須先將主機的數(shù)據(jù)庫導出,再導入到從機的數(shù)據(jù)庫中。從機先創(chuàng)建數(shù)據(jù)庫,新創(chuàng)建的數(shù)據(jù)庫名字、字符集、排序規(guī)則必須和主庫原有的數(shù)據(jù)庫相同。然后再執(zhí)行下一步。

在這里插入圖片描述

數(shù)據(jù)庫創(chuàng)建好后,將主機中導出的數(shù)據(jù)庫導入到從機中:

在這里插入圖片描述

2.4開始主從同步

重啟Mysql后,可以設置從機的數(shù)據(jù)庫同步到主機。設置同步到的主機信息(連接的IP和賬戶),執(zhí)行從機執(zhí)行同步命令。

登錄從機數(shù)據(jù)庫:mysql -uroot -p數(shù)據(jù)庫密碼

登錄成功后,在從機數(shù)據(jù)庫命令行執(zhí)行以下指令,設置主機的連接參數(shù)。使從機可以連接到主機:

change master to master_host='主機IP',master_user='數(shù)據(jù)庫賬戶',master_password='數(shù)據(jù)庫密碼',master_log_file='數(shù)據(jù)庫二進制文件',master_log_pos=文件位置參數(shù);

從機連接到主機后,開始同步,從機復制主機的二進制日志:

start slave;

在這里插入圖片描述

2.5查看從機狀態(tài)

注意:從機開始同步之前,主機不能再進行寫操作,如果主機仍在進行寫操作,會導致同步失敗,Slave_SQL_Running欄顯示為NO,Last_Error會重復出現(xiàn)報錯,導致同步無法繼續(xù)執(zhí)行。

#查看從機狀態(tài)
show slave status;

如果在數(shù)據(jù)庫命令行中執(zhí)行該命令,回顯的信息是沒有分行的,行顯示的數(shù)據(jù)錯亂,可以通過增加“\G”分行展示從機狀態(tài):

#分行查看從機狀態(tài)
show slave status\G;

如果從機的狀態(tài)如下圖所示,則說明同步是成功的:

在這里插入圖片描述

2.6同步報錯解決辦法一

注意:從機開始同步之前,主機不能再進行寫操作。如果主機仍在進行寫操作,會導致同步失敗,Slave_SQL_Running欄顯示為NO,Last_Error會重復出現(xiàn)報錯代碼1032,導致同步無法繼續(xù)執(zhí)行。

在這里插入圖片描述

那么怎么停止主機的寫操作呢?停止主機的寫操作,一定要在主機上停止所有的連接到數(shù)據(jù)庫的程序和中間件,讓程序不再往數(shù)據(jù)庫中寫入數(shù)據(jù)即可。

主機中往數(shù)據(jù)庫寫的操作停止后,從機再重新執(zhí)行同步操作:

start slave;

2.7同步報錯解決辦法二

查閱了許多資料,大佬們的做法是這樣的,從機登錄數(shù)據(jù)庫后執(zhí)行以下命令:

 #sql_slave_skip_counter =1表示跳過1步錯誤,后面的數(shù)字可變,出現(xiàn)多少個報錯則把數(shù)字改成這個數(shù)量可以跳過報錯繼續(xù)同步
stop slave;
set global sql_slave_skip_counter =1;  
start slave;

但是我按照大佬們的操作,還是沒解決問題。如果錯誤比較多,或者中途還是會出現(xiàn)報錯,導致無法完成主從同步,那么建議修改從機的數(shù)據(jù)庫配置文件,跳過所有1032代碼的錯誤:

在這里插入圖片描述

在配置文件中[mysqld]添加以下內容:

#該方法用于跳過所有1032錯誤
slave-skip-errors=1032

如果想跳過其他的錯誤代碼,可以把slave-skip-errors后面的代碼替換為出現(xiàn)的錯誤代碼。更粗暴的是,可以跳過所有的錯誤代碼:

#該方法用于跳過所有錯誤代碼
slave-skip-errors=all

修改配置文件之后,重新啟動mysql數(shù)據(jù)庫。

重啟數(shù)據(jù)庫之后,從機中重新執(zhí)行主從同步命令:

start slave;

3.同步測試

在主機中新建數(shù)據(jù)庫,在數(shù)據(jù)庫中添加數(shù)據(jù)表,查看從庫中是否將主庫修改的內容同步過來:

在這里插入圖片描述

主機新增了“ibms_ksy”數(shù)據(jù)庫,同時導入了數(shù)據(jù)庫報表。我們查看從機是否同步了新增的數(shù)據(jù)庫:

在這里插入圖片描述

可以看到,從機同步了主機新增的數(shù)據(jù)庫,并將主庫中的數(shù)據(jù)表也同步了過來。

到此這篇關于Mysql數(shù)據(jù)庫主從同步的實現(xiàn)示例的文章就介紹到這了,更多相關Mysql 主從同步內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • MySQL數(shù)據(jù)庫的多種連接方式及工具

    MySQL數(shù)據(jù)庫的多種連接方式及工具

    本文詳細的介紹了數(shù)據(jù)庫的連接方式及數(shù)據(jù)庫連接的工具,給初學者分享一些知識,也是學習總結,感興趣的小伙伴可以閱讀一下
    2023-03-03
  • Linux搭建單機MySQL8.0.26版本的操作方法

    Linux搭建單機MySQL8.0.26版本的操作方法

    這篇文章主要介紹了Linux搭建單機MySQL8.0.26版本的操作方法,本文通過圖文并茂的形式給大家講解的非常詳細,感興趣的朋友一起看看吧
    2025-05-05
  • MySQL查詢和篩選存儲的JSON數(shù)據(jù)的操作方法

    MySQL查詢和篩選存儲的JSON數(shù)據(jù)的操作方法

    MySQL是常用的關系型數(shù)據(jù)庫管理系統(tǒng),為了支持非結構化數(shù)據(jù)的存儲和查詢,MySQL引入了對JSON數(shù)據(jù)類型的支持,JSON是一種輕量級的數(shù)據(jù)交換格式,在現(xiàn)代應用程序中得到了廣泛應用,處理和存儲非結構化數(shù)據(jù)變得越來越重要,本文給大家介紹mysql查詢JSON數(shù)據(jù)的相關知識,一起看看吧
    2024-01-01
  • MySQL多表連接的入門實例教程

    MySQL多表連接的入門實例教程

    這篇文章主要給大家介紹了關于MySQL多表連接的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用MySQL具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-12-12
  • mysql最左前綴法則導致索引失效的解決

    mysql最左前綴法則導致索引失效的解決

    最左前綴是在使用innodb存儲引擎索引時,需要遵守的法則,本文主要介紹了mysql最左前綴法則導致索引失效的解決,具有一定的參考價值,感興趣的可以了解一下
    2024-07-07
  • MySQL中列轉行和行轉列總結解決思路

    MySQL中列轉行和行轉列總結解決思路

    最近工作中用到了好幾次列轉行,索性做個小總結,下面這篇文章主要給大家介紹了關于MYSQL如何列轉行的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-01-01
  • mysql存儲過程用法實例分析

    mysql存儲過程用法實例分析

    這篇文章主要介紹了mysql存儲過程用法,結合實例形式簡單分析了mysql存儲過程的概念、功能、定義、執(zhí)行、調用等相關操作技巧,需要的朋友可以參考下
    2018-03-03
  • MySQL會發(fā)生死鎖的幾種情況及處理方法

    MySQL會發(fā)生死鎖的幾種情況及處理方法

    數(shù)據(jù)庫的死鎖是指不同的事務在獲取資源時相互等待,導致無法繼續(xù)執(zhí)行的一種情況,當發(fā)生死鎖時,數(shù)據(jù)庫系統(tǒng)會自動中斷其中一個事務,以解除死鎖,本文給大家介紹了MySQL什么情況下會死鎖,發(fā)生了死鎖怎么處理呢,需要的朋友可以參考下
    2023-09-09
  • mysql 數(shù)據(jù)庫中my.ini的優(yōu)化 2G內存針對站多 抗壓型的設置

    mysql 數(shù)據(jù)庫中my.ini的優(yōu)化 2G內存針對站多 抗壓型的設置

    mysql數(shù)據(jù)庫中my.ini的優(yōu)化,2G內存,針對站多,抗壓型的設置.大家可以借鑒下。
    2009-08-08
  • MySQL出現(xiàn)錯誤代碼:1055的三種解決方案(推薦!)

    MySQL出現(xiàn)錯誤代碼:1055的三種解決方案(推薦!)

    當我們在查詢時使用group by語句,出現(xiàn)錯誤代碼:1055;執(zhí)行發(fā)生錯誤語句,本文給大家介紹了MySQL出現(xiàn)錯誤代碼:1055的三種解決方案,文中有詳細的代碼示例和圖文供大家參考,需要的朋友可以參考下
    2024-05-05

最新評論