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

溫馨提示×

溫馨提示×

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

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

MySQL 中怎么創建復制用戶

發布時間:2021-08-04 14:53:43 來源:億速云 閱讀:316 作者:Leah 欄目:數據庫

今天就跟大家聊聊有關MySQL 中怎么創建復制用戶,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

場景 1:僅在主庫創建復制用戶

1.主庫做一個備份并拷貝到從庫

/usr/local/mysql5732/bin/mysqldump --single-transaction --master-data=2 -B zlm -S /tmp/mysql3332.sock -p > zlm.sql  scp zlm.sql root@10.186.60.68:~

2.登陸從庫執行導入

mysql> source zlm.sql

由于沒有使用參數 --set-gtid-purged=off,導出的語句中會帶有 SET @@GLOBAL.GTID_PURGED='xxxx:1-xx' 并執行,導入前需要先在從庫上執行 reset master。

3.主庫創建復制用戶

mysql> create user repl1 identified by 'repl1';

4.從庫配置主從復制并啟動

mysql> change master to master_host='10.186.60.62',master_port=3332,master_user='repl1',master_password='repl1',master_auto_position=1;  mysql> start slave;
MySQL 中怎么創建復制用戶

啟動復制后,報了 Error 1045 的錯誤,此處并不是密碼錯,而是沒有給復制用戶配置 replication slave 權限,在主庫上對 repl1 用戶執行賦權后(grant replication slave on *.* to repl1;),再啟動復制就正常了。

主從復制正常以后,也會在從庫上創建復制用戶 repl1。

MySQL 中怎么創建復制用戶

從庫上并沒有創建過復制用戶 repl1,主從復制就正常搭建好了,為什么呢?因為 change master to 語句中指定的 master_user 是主庫上的復制用戶,從庫通過這個用戶連接到主庫進行同步,當開啟復制線程后,主庫上創建復制用戶的語句會在從庫上進行回放,于是從庫上也會有這個復制用戶了。

結論 1

  • 搭建主從復制時,在從庫創建復制用戶不是必須的,僅在主庫創建即可,復制用戶會同步到從庫。

場景 2:主從庫單獨創建復制用戶(create 語句)

1.主庫做一個備份并拷貝到從庫(gtid_purged=xxxx:1-23)

2.從庫執行導入

3.主庫創建復制用戶并賦權

mysql> create user repl2 identified by 'repl2';  mysql> grant replication slave on *.* to repl2;
MySQL 中怎么創建復制用戶

4.從庫創建復制用戶

MySQL 中怎么創建復制用戶

由于不想在從庫上產生由從庫 uuid 寫入的 binlog 事務,此處設置了 sql_log_bin=0,使事務不被記錄到 binlog 中,原因是在數據庫管理平臺對高可用集群進行管理時,通常是不允許從庫上有主庫不存在的 GTID 事務的。

5.從庫配置主從復制并啟動

mysql> change master to master_host='10.186.60.62',master_port=3332,master_user='repl2',master_password='repl2',master_auto_position=1; mysql> start slave;
MySQL 中怎么創建復制用戶

由于從庫上已經創建了復制用戶,當回放到主庫的這個事務時會報 Error 1396 的錯誤。

可以用 create user 語句創建一個重復用戶來驗證。

MySQL 中怎么創建復制用戶

解析主庫 binlog,啟動復制后執行的第一個事務就是這個 24 的創建用戶語句。

MySQL 中怎么創建復制用戶

結論 2

在從庫導入備份后并分別在主、從庫單獨創建復制用戶后,當從庫執行到創建用戶的事務時會導致復制中斷。

場景 3:主從庫單獨創建復制用戶(grant 語句)

1.主庫做一個備份并拷貝到從庫(gtid_purged=xxxx:1-28)

2.從庫執行導入

3.主庫創建復制用戶

mysql> grant replication slave on *.* repl3 identified by 'repl3';
MySQL 中怎么創建復制用戶

4.從庫創建復制用戶

MySQL 中怎么創建復制用戶

5.從庫配置主從復制并啟動

mysql> change master to master_host='10.186.60.62',master_port=3332,master_user='repl2',master_password='repl2',master_auto_position=1;  mysql> start slave;
MySQL 中怎么創建復制用戶

這次啟動復制后并沒有報錯。為何用 grant 語句創建用戶就可以,用 create 語句就不行呢?

create 與 grant 語句都會產生事務并記錄到 binlog 中,但區別是 grant 語句是一個近似冪等的操作,而 create 語句不是。

解析主庫 binlog,29 和 30 都是重復執行 grant 的事務。

MySQL 中怎么創建復制用戶

觀察 show slave stauts\G,從庫上也把 29,30 這兩個事務都回放掉了,重復執行它們并不影響主從復制。

MySQL 中怎么創建復制用戶

但要注意的是,在 MySQL 8.0 中已經禁止通過 grant 這種語法來創建用戶了。

MySQL 中怎么創建復制用戶

結論 3

  • 從庫導入備份并在主從庫分別使用 grant 語句創建用戶后,在從庫回放時不會導致復制中斷。

總結

1.根據以上驗證結果得知,在搭建主從復制時,采用多種方式創建復制用戶都是可行的,但有些方式存在一些限制,如:在主、從實例上分別創建復制用戶。雖然執行 grant 語句創建用戶不會導致復制中斷,但其并不是標準的 MySQL 創建用戶語法,在 MySQL 8.0 中已被視為語法錯誤,因此不推薦采用這樣的方式來搭建主從。

2.創建復制用戶的方式

Create 語句創建用戶時

1.主庫創建完復制用戶后做備份,再配置主從

2.備份后僅在主庫創建復制用戶,再配置主從(推薦)

3.如果要在主、從庫分別創建復制用戶,應先設置 session 級別的 sql_log_bin=0,再配置主從

Grant 語句創建用戶時(MySQL 5.7 及以下版本)

1.主庫先創建復制用戶后備份,再配置主從

2.僅在主庫創建復制用戶,再配置主從(推薦)

3.主、從庫分別創建復制用戶,再配置主從

看完上述內容,你們對MySQL 中怎么創建復制用戶有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

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

AI

托克逊县| 瓦房店市| 永吉县| 英德市| 龙门县| 怀来县| 永春县| 屏东市| 鄄城县| 沙湾县| 萝北县| 宜昌市| 昂仁县| 台东市| 平乡县| 金湖县| 蓬莱市| 项城市| 罗山县| 博白县| 横峰县| 宁津县| 台州市| 台前县| 镇江市| 公主岭市| 龙泉市| 桂阳县| 蕲春县| 灵台县| 灌南县| 三河市| 当雄县| 河源市| 河间市| 龙胜| 雷山县| 砀山县| 武陟县| 通山县| 康平县|