欧美一区2区三区4区公司二百,国产精品婷婷午夜在线观看,自拍偷拍亚洲精品,国产美女诱惑一区二区

MySQL主主數據同步

環境
操作系統版本:CentOS7 64位
MySQL版本:mysql5.6.33
節點1IP:192.168.1.205 主機名:edu-mysql-01
節點2IP:192.168.1.206 主機名:edu-mysql-02

MySQL 主從復制官方文檔:http://dev.mysql.com/doc/refman/5.6/en/replication.html

注意:
1> 主從服務器操作系統版本和位數要保持一致
2> Master和Slave數據庫的版本要一致
3> Master和Slave數據庫中的數據要一致

配置
配置之前先參考《MySQL5.7安裝與配置(YUM)》安裝好MySQL(注意本文演示的是5.6版本,需要修改文章中的yum源為5.6)

1、安全配置
1> 防火墻
添加mysql通信端口(默認為3306)

shell> vim /etc/sysconfig/iptables
-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT
shell> service ?iptables restart?
shell> vim /etc/sysconfig/iptables
-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT
shell> service ?iptables restart?
或關閉防火墻

shell> service iptables stop
1shell> service iptables stop
2> 關閉selinux

shell> vi /etc/selinux/config
SELINUX=disabled
shell> vi /etc/selinux/config
SELINUX=disabled
將SELINUX的值修改為disabled

2. 節點1配置(192.168.1.205)
2.1 添加數據同步配置
shell> vim /etc/my.cnf
1shell> vim /etc/my.cnf
在[mysqld]中增加以下配置項:

# 服務器的ID,必須唯一,一般設置自己的IP
server_id=205
# 復制過濾:不需要備份的數據庫(MySQL庫一般不同步)
binlog-ignore-db=mysql
# 開啟二進制日志功能,名字可以隨便取,最好有含義(比如項目名)
log-bin=edu-mysql-bin
# 為每個 session 分配的內存,在事務過程中用來存儲二進制日志的緩存
binlog_cache_size=1M
# 主從復制的格式(mixed,statement,row,默認格式是 statement)
binlog_format=mixed
# 二進制日志自動刪除/過期的天數。默認值為 0,表示不自動刪除。
expire_logs_days=7
## 跳過主從復制中遇到的所有錯誤或指定類型的錯誤,避免 slave 端復制中斷。?
## 如:1062 錯誤是指一些主鍵重復,1032 錯誤是因為主從數據庫數據不一致
slave_skip_errors=1062
# 作為從服務器時的中繼日志
relay_log=edu-mysql-relay-bin
# log_slave_updates 表示 slave 將復制事件寫進自己的二進制日志
log_slave_updates=1
# 主鍵自增規則,避免主從同步ID重復的問題
auto_increment_increment=2 ?# 自增因子(每次加2)
auto_increment_offset=1 ? ? # 自增偏移(從1開始),單數

2.2 Master配置
# 先重啟一下服務
shell> service mysqld restart ?
# 登錄到mysql
shell> mysql -uroot -p?
# 創建數據庫同步用戶,并授予相應的權限
mysql> grant replication slave, replication client on *.* to 'repl'@'192.168.1.206' identified by 'root123456';
# 刷新授權表信息
mysql> flush privileges;
# 查看binlog文件的position(偏移)和File(日志文件)的值,從機上需要用到
mysql> show master status;
+----------------------+----------+--------------+------------------+-------------------+
| File ? ? ? ? ? ? ? ? | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+----------------------+----------+--------------+------------------+-------------------+
| edu-mysql-bin.000001 | ? ? ?120 | ? ? ? ? ? ? ?| mysql ? ? ? ? ? ?| ? ? ? ? ? ? ? ? ? |
+----------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

2.3 Slave配置
# master_user和master_password:在206上執行grant replication slave...創建的用戶和密碼
# master_log_file和master_log_pos:在206上運行show master status;命令執行結果對應File和Position字段的值
mysql> change master to master_host='192.168.1.206',master_user='repl', master_password='root123456', master_port=3306, master_log_file='edu-mysql-bin.000001', master_log_pos=439, master_connect_retry=30;
# 查看作為從節點的狀態信息
mysql> show slave status\G;
*************************** 1. row ***************************
? ? ? ? ? ? ? ?Slave_IO_State:
? ? ? ? ? ? ? ? ? Master_Host: 192.168.1.206
? ? ? ? ? ? ? ? ? Master_User: repl
? ? ? ? ? ? ? ? ? Master_Port: 3306
? ? ? ? ? ? ? ? Connect_Retry: 30
? ? ? ? ? ? ? Master_Log_File: edu-mysql-bin.000001
? ? ? ? ? Read_Master_Log_Pos: 439
? ? ? ? ? ? ? ?Relay_Log_File: edu-mysql-relay-bin.000001
? ? ? ? ? ? ? ? Relay_Log_Pos: 4
? ? ? ? Relay_Master_Log_File: edu-mysql-bin.000001
? ? ? ? ? ? ?Slave_IO_Running: No
? ? ? ? ? ? Slave_SQL_Running: No
? ? ? ? ? # 省略其它配置。。。

由于此時從節點還沒有啟動,Slave_IO_State的值為空,Slave_IO_Running和Slave_SQL_Running線程為No表示也沒有運行。

2.4 啟動Slave
注意:要在節點2上創建同步帳戶后再啟動,否則會報連不上master錯誤

# 啟動從節點,開始工作接收主節點發送事件(數據庫數據變更的所有事件)
mysql> start slave;
# 此時再查看slave節點的狀態
mysql> show slave status\G;
*************************** 1. row ***************************
? ? ? ? ? ? ? ?Slave_IO_State: Waiting for master to send event
? ? ? ? ? ? ? ? ? Master_Host: 192.168.1.206
? ? ? ? ? ? ? ? ? Master_User: repl
? ? ? ? ? ? ? ? ? Master_Port: 3306
? ? ? ? ? ? ? ? Connect_Retry: 30
? ? ? ? ? ? ? Master_Log_File: edu-mysql-bin.000001
? ? ? ? ? Read_Master_Log_Pos: 439
? ? ? ? ? ? ? ?Relay_Log_File: edu-mysql-relay-bin.000002
? ? ? ? ? ? ? ? Relay_Log_Pos: 287
? ? ? ? Relay_Master_Log_File: edu-mysql-bin.000001
? ? ? ? ? ? ?Slave_IO_Running: Yes
? ? ? ? ? ? Slave_SQL_Running: Yes
? ? ? ? ? ? ? Replicate_Do_DB:
? ? ? ? ? ? # ...省略其它配置

3. 節點2配置(192.168.1.206)
3.1 添加數據同步配置
shell> vim /etc/my.cnf
1
在[mysqld]中增加以下配置項:

server_id=206
binlog-ignore-db=mysql
log-bin=edu-mysql-bin
binlog_cache_size=1M
binlog_format=mixed
expire_logs_days=7
slave_skip_errors=1062
relay_log=edu-mysql-relay-bin
log_slave_updates=1
#ID自增從2開始,雙數
auto_increment_increment=2
auto_increment_offset=2

3.2 Master配置
# 先重啟一下服務
shell> service mysqld restart ?
# 登錄到mysql
shell> mysql -uroot -p?
# 創建數據庫同步用戶,并授予相應的權限(只允許repl用戶從192.168.1.205上登錄)
mysql> grant replication slave, replication client on *.* to 'repl'@'192.168.1.205' identified by 'root123456';
# 刷新授權表信息
mysql> flush privileges;
# 查看binlog文件的position(偏移)和File(日志文件)的值,從機上需要用到
mysql> show master status;
+----------------------+----------+--------------+------------------+-------------------+
| File ? ? ? ? ? ? ? ? | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+----------------------+----------+--------------+------------------+-------------------+
| edu-mysql-bin.000001 | ? ? ?439 | ? ? ? ? ? ? ?| mysql ? ? ? ? ? ?| ? ? ? ? ? ? ? ? ? |
+----------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

時可以啟動節點1(205)的slave服務

3.3 Slave配置
# master_log_file和master_log_pos:205節點上執行show master status;對應File和position的值
mysql> change master to master_host='192.168.1.205',master_user='repl', master_password='root123456', master_port=3306, master_log_file='edu-mysql-bin.000001', master_log_pos=120, master_connect_retry=30;
Query OK, 0 rows affected, 2 warnings (0.02 sec)
mysql> show slave status\G;
*************************** 1. row ***************************
? ? ? ? ? ? ? ?Slave_IO_State:
? ? ? ? ? ? ? ? ? Master_Host: 192.168.1.205
? ? ? ? ? ? ? ? ? Master_User: repl
? ? ? ? ? ? ? ? ? Master_Port: 3306
? ? ? ? ? ? ? ? Connect_Retry: 30
? ? ? ? ? ? ? Master_Log_File: edu-mysql-bin.000001
? ? ? ? ? Read_Master_Log_Pos: 120
? ? ? ? ? ? ? ?Relay_Log_File: edu-mysql-relay-bin.000001
? ? ? ? ? ? ? ? Relay_Log_Pos: 4
? ? ? ? Relay_Master_Log_File: edu-mysql-bin.000001
? ? ? ? ? ? ?Slave_IO_Running: No
? ? ? ? ? ? Slave_SQL_Running: No
? ? ? ? ? ? ? Replicate_Do_DB:
? ? ? ? ? ? ? #...省略其它配置

3.4、啟動Slave
shell> start slave;
Query OK, 0 rows affected (0.01 sec)
mysql> show slave status\G;
*************************** 1. row ***************************
? ? ? ? ? ? ? ?Slave_IO_State: Waiting for master to send event
? ? ? ? ? ? ? ? ? Master_Host: 192.168.1.205
? ? ? ? ? ? ? ? ? Master_User: repl
? ? ? ? ? ? ? ? ? Master_Port: 3306
? ? ? ? ? ? ? ? Connect_Retry: 30
? ? ? ? ? ? ? Master_Log_File: edu-mysql-bin.000001
? ? ? ? ? Read_Master_Log_Pos: 439
? ? ? ? ? ? ? ?Relay_Log_File: edu-mysql-relay-bin.000002
? ? ? ? ? ? ? ? Relay_Log_Pos: 287
? ? ? ? Relay_Master_Log_File: edu-mysql-bin.000001
? ? ? ? ? ? ?Slave_IO_Running: Yes
? ? ? ? ? ? Slave_SQL_Running: Yes
? ? ? ? ? ? ? Replicate_Do_DB:
? ? ? ? ? ? ? ...省略其它配置

4、驗證
# 登錄205創建一個數據庫
shell> mysql -u root -p
mysql> create database if not exists mydb default character set utf8 collate utf8_general_ci;
mysql> create table user (id int, username varchar(30), password varchar(30));
mysql> insert into user values (1, 'yangxin', '123456');
# 下面是在206節點上的操作
#1、登錄206查詢所有庫,是否包含mydb數據庫
#2、切換到mydb庫,是否包含user表,并有一條數據
#3、在206的mydb.user表插入一條數據,查看205是否同步過去
mysql> insert into user values (2,'yangxin2','123456')

環境
操作系統版本:CentOS7 64位
MySQL版本:mysql5.6.33
節點1IP:192.168.1.205 主機名:edu-mysql-01
節點2IP:192.168.1.206 主機名:edu-mysql-02

MySQL 主從復制官方文檔:http://dev.mysql.com/doc/refman/5.6/en/replication.html

注意:
1> 主從服務器操作系統版本和位數要保持一致
2> Master和Slave數據庫的版本要一致
3> Master和Slave數據庫中的數據要一致

配置
配置之前先參考《MySQL5.7安裝與配置(YUM)》安裝好MySQL(注意本文演示的是5.6版本,需要修改文章中的yum源為5.6)

1、安全配置
1> 防火墻
添加mysql通信端口(默認為3306)

shell> vim /etc/sysconfig/iptables
-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT
shell> service ?iptables restart?

或關閉防火墻

shell> service iptables stop
1
2> 關閉selinux

shell> vi /etc/selinux/config
SELINUX=disabled
1
2
將SELINUX的值修改為disabled

2. 節點1配置(192.168.1.205)
2.1 添加數據同步配置
shell> vim /etc/my.cnf
1
在[mysqld]中增加以下配置項:

# 服務器的ID,必須唯一,一般設置自己的IP
server_id=205
# 復制過濾:不需要備份的數據庫(MySQL庫一般不同步)
binlog-ignore-db=mysql
# 開啟二進制日志功能,名字可以隨便取,最好有含義(比如項目名)
log-bin=edu-mysql-bin
# 為每個 session 分配的內存,在事務過程中用來存儲二進制日志的緩存
binlog_cache_size=1M
# 主從復制的格式(mixed,statement,row,默認格式是 statement)
binlog_format=mixed
# 二進制日志自動刪除/過期的天數。默認值為 0,表示不自動刪除。
expire_logs_days=7
## 跳過主從復制中遇到的所有錯誤或指定類型的錯誤,避免 slave 端復制中斷。?
## 如:1062 錯誤是指一些主鍵重復,1032 錯誤是因為主從數據庫數據不一致
slave_skip_errors=1062
# 作為從服務器時的中繼日志
relay_log=edu-mysql-relay-bin
# log_slave_updates 表示 slave 將復制事件寫進自己的二進制日志
log_slave_updates=1
# 主鍵自增規則,避免主從同步ID重復的問題
auto_increment_increment=2 ?# 自增因子(每次加2)
auto_increment_offset=1 ? ? # 自增偏移(從1開始),單數

2.2 Master配置
# 先重啟一下服務
shell> service mysqld restart ?
# 登錄到mysql
shell> mysql -uroot -p?
# 創建數據庫同步用戶,并授予相應的權限
mysql> grant replication slave, replication client on *.* to 'repl'@'192.168.1.206' identified by 'root123456';
# 刷新授權表信息
mysql> flush privileges;
# 查看binlog文件的position(偏移)和File(日志文件)的值,從機上需要用到
mysql> show master status;
+----------------------+----------+--------------+------------------+-------------------+
| File ? ? ? ? ? ? ? ? | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+----------------------+----------+--------------+------------------+-------------------+
| edu-mysql-bin.000001 | ? ? ?120 | ? ? ? ? ? ? ?| mysql ? ? ? ? ? ?| ? ? ? ? ? ? ? ? ? |
+----------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

2.3 Slave配置
# master_user和master_password:在206上執行grant replication slave...創建的用戶和密碼
# master_log_file和master_log_pos:在206上運行show master status;命令執行結果對應File和Position字段的值
mysql> change master to master_host='192.168.1.206',master_user='repl', master_password='root123456', master_port=3306, master_log_file='edu-mysql-bin.000001', master_log_pos=439, master_connect_retry=30;
# 查看作為從節點的狀態信息
mysql> show slave status\G;
*************************** 1. row ***************************
? ? ? ? ? ? ? ?Slave_IO_State:
? ? ? ? ? ? ? ? ? Master_Host: 192.168.1.206
? ? ? ? ? ? ? ? ? Master_User: repl
? ? ? ? ? ? ? ? ? Master_Port: 3306
? ? ? ? ? ? ? ? Connect_Retry: 30
? ? ? ? ? ? ? Master_Log_File: edu-mysql-bin.000001
? ? ? ? ? Read_Master_Log_Pos: 439
? ? ? ? ? ? ? ?Relay_Log_File: edu-mysql-relay-bin.000001
? ? ? ? ? ? ? ? Relay_Log_Pos: 4
? ? ? ? Relay_Master_Log_File: edu-mysql-bin.000001
? ? ? ? ? ? ?Slave_IO_Running: No
? ? ? ? ? ? Slave_SQL_Running: No
? ? ? ? ? # 省略其它配置。。。

由于此時從節點還沒有啟動,Slave_IO_State的值為空,Slave_IO_Running和Slave_SQL_Running線程為No表示也沒有運行。

2.4 啟動Slave
注意:要在節點2上創建同步帳戶后再啟動,否則會報連不上master錯誤

# 啟動從節點,開始工作接收主節點發送事件(數據庫數據變更的所有事件)
mysql> start slave;
# 此時再查看slave節點的狀態
mysql> show slave status\G;
*************************** 1. row ***************************
? ? ? ? ? ? ? ?Slave_IO_State: Waiting for master to send event
? ? ? ? ? ? ? ? ? Master_Host: 192.168.1.206
? ? ? ? ? ? ? ? ? Master_User: repl
? ? ? ? ? ? ? ? ? Master_Port: 3306
? ? ? ? ? ? ? ? Connect_Retry: 30
? ? ? ? ? ? ? Master_Log_File: edu-mysql-bin.000001
? ? ? ? ? Read_Master_Log_Pos: 439
? ? ? ? ? ? ? ?Relay_Log_File: edu-mysql-relay-bin.000002
? ? ? ? ? ? ? ? Relay_Log_Pos: 287
? ? ? ? Relay_Master_Log_File: edu-mysql-bin.000001
? ? ? ? ? ? ?Slave_IO_Running: Yes
? ? ? ? ? ? Slave_SQL_Running: Yes
? ? ? ? ? ? ? Replicate_Do_DB:
? ? ? ? ? ? # ...省略其它配置

3. 節點2配置(192.168.1.206)
3.1 添加數據同步配置
shell> vim /etc/my.cnf
1
在[mysqld]中增加以下配置項:

server_id=206
binlog-ignore-db=mysql
log-bin=edu-mysql-bin
binlog_cache_size=1M
binlog_format=mixed
expire_logs_days=7
slave_skip_errors=1062
relay_log=edu-mysql-relay-bin
log_slave_updates=1
#ID自增從2開始,雙數
auto_increment_increment=2
auto_increment_offset=2

3.2 Master配置
# 先重啟一下服務
shell> service mysqld restart ?
# 登錄到mysql
shell> mysql -uroot -p?
# 創建數據庫同步用戶,并授予相應的權限(只允許repl用戶從192.168.1.205上登錄)
mysql> grant replication slave, replication client on *.* to 'repl'@'192.168.1.205' identified by 'root123456';
# 刷新授權表信息
mysql> flush privileges;
# 查看binlog文件的position(偏移)和File(日志文件)的值,從機上需要用到
mysql> show master status;
+----------------------+----------+--------------+------------------+-------------------+
| File ? ? ? ? ? ? ? ? | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+----------------------+----------+--------------+------------------+-------------------+
| edu-mysql-bin.000001 | ? ? ?439 | ? ? ? ? ? ? ?| mysql ? ? ? ? ? ?| ? ? ? ? ? ? ? ? ? |
+----------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)

這時可以啟動節點1(205)的slave服務

3.3 Slave配置
# master_log_file和master_log_pos:205節點上執行show master status;對應File和position的值
mysql> change master to master_host='192.168.1.205',master_user='repl', master_password='root123456', master_port=3306, master_log_file='edu-mysql-bin.000001', master_log_pos=120, master_connect_retry=30;
Query OK, 0 rows affected, 2 warnings (0.02 sec)
mysql> show slave status\G;
*************************** 1. row ***************************
? ? ? ? ? ? ? ?Slave_IO_State:
? ? ? ? ? ? ? ? ? Master_Host: 192.168.1.205
? ? ? ? ? ? ? ? ? Master_User: repl
? ? ? ? ? ? ? ? ? Master_Port: 3306
? ? ? ? ? ? ? ? Connect_Retry: 30
? ? ? ? ? ? ? Master_Log_File: edu-mysql-bin.000001
? ? ? ? ? Read_Master_Log_Pos: 120
? ? ? ? ? ? ? ?Relay_Log_File: edu-mysql-relay-bin.000001
? ? ? ? ? ? ? ? Relay_Log_Pos: 4
? ? ? ? Relay_Master_Log_File: edu-mysql-bin.000001
? ? ? ? ? ? ?Slave_IO_Running: No
? ? ? ? ? ? Slave_SQL_Running: No
? ? ? ? ? ? ? Replicate_Do_DB:
? ? ? ? ? ? ? #...省略其它配置

3.4、啟動Slave
shell> start slave;
Query OK, 0 rows affected (0.01 sec)
mysql> show slave status\G;
*************************** 1. row ***************************
? ? ? ? ? ? ? ?Slave_IO_State: Waiting for master to send event
? ? ? ? ? ? ? ? ? Master_Host: 192.168.1.205
? ? ? ? ? ? ? ? ? Master_User: repl
? ? ? ? ? ? ? ? ? Master_Port: 3306
? ? ? ? ? ? ? ? Connect_Retry: 30
? ? ? ? ? ? ? Master_Log_File: edu-mysql-bin.000001
? ? ? ? ? Read_Master_Log_Pos: 439
? ? ? ? ? ? ? ?Relay_Log_File: edu-mysql-relay-bin.000002
? ? ? ? ? ? ? ? Relay_Log_Pos: 287
? ? ? ? Relay_Master_Log_File: edu-mysql-bin.000001
? ? ? ? ? ? ?Slave_IO_Running: Yes
? ? ? ? ? ? Slave_SQL_Running: Yes
? ? ? ? ? ? ? Replicate_Do_DB:
? ? ? ? ? ? ? ...省略其它配置

4、驗證
# 登錄205創建一個數據庫
shell> mysql -u root -p
mysql> create database if not exists mydb default character set utf8 collate utf8_general_ci;
mysql> create table user (id int, username varchar(30), password varchar(30));
mysql> insert into user values (1, 'yangxin', '123456');
# 下面是在206節點上的操作
#1、登錄206查詢所有庫,是否包含mydb數據庫
#2、切換到mydb庫,是否包含user表,并有一條數據
#3、在206的mydb.user表插入一條數據,查看205是否同步過去
mysql> insert into user values (2,'yangxin2','123456')

MySQL主主數據同步

文章鏈接: http://www.qzkangyuan.com/12131.html

文章標題:MySQL主主數據同步

文章版權:夢飛科技所發布的內容,部分為原創文章,轉載請注明來源,網絡轉載文章如有侵權請聯系我們!

聲明:本站所有文章,如無特殊說明或標注,均為本站原創發布。任何個人或組織,在未征得本站同意時,禁止復制、盜用、采集、發布本站內容到任何網站、書籍等各類媒體平臺。如若本站內容侵犯了原著者的合法權益,可聯系我們進行處理。

給TA打賞
共{{data.count}}人
人已打賞
建站教程投稿分享

解除Linux最大進程數和最大文件句柄打開數限制

2022-11-3 14:37:37

建站教程投稿分享

Keepalived安裝與配置

2022-11-3 14:54:01

0 條回復 A文章作者 M管理員
    暫無討論,說說你的看法吧
?
個人中心
購物車
優惠劵
今日簽到
有新私信 私信列表
搜索
主站蜘蛛池模板: 磐石市| 和平县| 双桥区| 维西| 叶城县| 光泽县| 琼中| 象州县| 沙坪坝区| 米林县| 介休市| 台前县| 株洲县| 内江市| 波密县| 古丈县| 宁安市| 乌拉特后旗| 郑州市| 绥宁县| 独山县| 青阳县| 新野县| 贵德县| 金门县| 神木县| 铜陵市| 四川省| 涟水县| 揭西县| 西安市| 格尔木市| 滕州市| 华池县| 婺源县| 左云县| 佛教| 汝州市| 罗山县| 余庆县| 巴楚县|