MySQL主從配置詳解

藏色散人
發布: 2020-03-13 08:51:30
轉載
2679 人瀏覽過

● 本打算買個雲端數據,為我的新專案做點安全保障。阿里雲,騰訊雲轉了一圈,兩個字太貴。不就資料有備份嗎,既然這樣那我不如自己做備份。

● 家裡有2個樹莓派直接把mysql備份到他們上就好了,網路上有教程,這就開整。在segmentfault mysql 這麼一搜好幾篇,按照他們一說的那麼一做,當然是不成功的,要是成功了我就不寫這篇文章了。 ps:他們的教學都是對的。

● 下面就開始設定主從伺服器,跟網路教學一樣,因為我就是看他們的。

1. 主設定(master)

修改mysql設定文件,一般在/etc/mysql/my.conf

server-id=1 //设置mysql的id标识 log-bin=/var/lib/mysql/mysql-bin //log-bin的日志文件,主从备份就是用这个日志记录来实现的 #binlog-do-db=mysql1 #需要备份的数据库名,如果备份多个数据库,重复设置这个选项 即可 #binlog-ignore-db=mysql2 #不需要备份的数据库名,如果备份多个数据库,重复设置这 个选项即可 #log-slave-updates=1 #这个参数当从库又作为其他从库的主库时一定要加上,否则不会给更新的记录写到binglog里二进制文件里 #slave-skip-errors=1 #是跳过错误,继续执行复制操作(可选)
登入後複製

在主mysql增加2個用來同步的帳號

mysql>grant replication slave on *.* to 'sync-1'@'%' identified by '123456'; mysql>grant replication slave on *.* to 'sync-2'@'%' identified by '123456';
登入後複製

重啟msql

mysql>show master status; //可以查看主mysql状态
登入後複製

2. 從設定(slave)

修改mysql設定檔my.conf,兩個從節點設定方式都一樣。

server-id=2 #log-bin=/var/lib/mysql/mysql-bi //从mysql可以不用设置日志文件
登入後複製

在從mysql增加指令參數,master_log_file 和master_log_pos 可以在master mysql中用show master status查詢到

mysql>change master to master_host='192.168.145.222',master_user='sync-1',master_password='123456',master_log_file='mysql-bin.000001',master_log_pos=308; mysql>start slave //启动 mysql>show slave status\G //查询状态,Slave_IO_Running 和Slave_IO_Running都为yes表示成功
登入後複製

3. 設定中的出現的問題

#
Last_Errno: 1146
登入後複製

設定出從的時候,我的主mysql已經有一張表了,當時創建表的binlog二進制日誌就沒有記錄,從mysql無法寫入數據,這時候只有手動導入數據庫文件到從mysql中;原因是網路教學都是全新安裝的主msql和從mysql,不存在已有資料的問題。

Last_Errno: 1062 Error 'Duplicate entry 'xxxxx' for key 'PRIMARY'' on query
登入後複製

主鍵衝突,這個問題比較複雜,應該是有表的設定不對,這個問題後來在Stack Overflow上找到了解決方法

# on slave mysql> stop slave; mysql> flush privileges; # on master rest master mysql> reset master; # on slave; mysql> reset slave; mysql> start slave;
登入後複製

推薦mysql視訊教程,地址://m.sbmmt.com/course/list/51.html

#

以上是MySQL主從配置詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:segmentfault.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!