生產環境mysql主主同步主鍵衝突處理
原創作品,允許轉載,轉載時請務必以超連結形式標明文章 原始出處 、作者資訊和本宣告。否則將追究法律責任。http://navyaijm.blog.51cto.com/4647068/1241728
主1:192.168.0.223(寫)
主2:192.168.0.230
好吧,先show slave status G看一下同步失敗的具體報錯吧
登入主2庫檢視:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
mysql> show slave status G *************************** 1. row *************************** Slave_IO_State: Master_Host: 192.168.0.223 Master_User: slave Master_Port: 13204 Connect_Retry: 60 Master_Log_File: mysql-bin.000009 Read_Master_Log_Pos: 50419 Relay_Log_File: mysqld-relay-bin.000014 Relay_Log_Pos: 34626 Relay_Master_Log_File: mysql-bin.000009 Slave_IO_Running: No Slave_SQL_Running: No Replicate_Do_DB: Replicate_Ignore_DB: mysql,information_schema,performance_schema, test ,mysql,information_schema,performance_schema, test
Replicate_Do_Table: Replicate_Ignore_Table: Replicate_Wild_Do_Table: Replicate_Wild_Ignore_Table: Last_Errno: 1062 Last_Error: Error `Duplicate entry ` 1329544 ` for key ` PRIMARY `` on query. Default database: `data` . Query: `insert into kn_chongzhi(orderid,aa,buyNum,state, type ,create_time,fac,cc,flag)
values(20130702173025036581,15935779926,1,0, `SJ` ,1372757425, `30.27` , `30` ,100)`
Skip_Counter: 0 Exec_Master_Log_Pos: 34480 Relay_Log_Space: 51171 Until_Condition: None Until_Log_File: Until_Log_Pos: 0 Master_SSL_Allowed: No Master_SSL_CA_File: Master_SSL_CA_Path: Master_SSL_Cert: Master_SSL_Cipher: Master_SSL_Key: Seconds_Behind_Master: NULL Master_SSL_Verify_Server_Cert: No Last_IO_Errno: 0 Last_IO_Error: Last_SQL_Errno: 1062 Last_SQL_Error: Error `Duplicate entry ` 1329544 ` for key ` PRIMARY `` on query. Default database: `data` . Query: `insert into kn_chongzhi(orderid,aa,buyNum,state, type ,create_time,fac,cc,flag)
values(20130702173025036581,15935779926,1,0, `SJ` ,1372757425, `30.27` , `30` ,100)`
Replicate_Ignore_Server_Ids: Master_Server_Id: 2 1 row in set (0.00 sec)
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
mysql> desc kn_chongzhi; +-------------+-----------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-------------+-----------------+------+-----+---------+----------------+ | id | int(10) | NO | PRI | NULL | auto_increment |
| aa | varchar(32) | NO | MUL | NULL | | | bizOfferId | varchar(32) | NO | | NULL | | | number | varchar(20) | NO | MUL | NULL | | | cc | float(10,2) | NO | | NULL | | | fac | float(10,2) | YES | | 0.00 | | | buyNum | int(10) | NO | | NULL | | | state | tinyint(4) | NO | | 0 | | | type | enum( `SJ` , `QB` ) | NO | | SJ | |
| create_time | int(11) | NO | | NULL | | | update_time | int(11) | NO | | NULL | | | flag | int(10) | NO | | 0 | | +-------------+-----------------+------+-----+---------+----------------+ 12 rows in set (0.00 sec)
|
想必大家已經知道問題是這麼產生的了,這裡我再大體的說一下,可能有些人還不明白哈,回頭看前面的架構,引起 這個問題的原因是主1的網路抖動,導致amoeba把寫切到了主2,主1的網路好了,寫又切回了主1,由於主鍵ID是自曾的,所以就出現了這個問題,我舉個例子:
開始是寫主1的,已經寫6條資料(id=1、2、3、4、5、6),突然主1網路抖動,開始在主2寫了三條(id=7、8、9),主1的網路又恢復了,寫又在主1上了(id=7、8、9、10、。。。。),這時,主1要把id=7、8、9、10.。。。。的資料複製給主2,主2 要把id=7、8、9三條資料複製給主1,這不就傻逼了嗎?
處理的過程:
1、在兩個庫上stop slave;
2、在主2上執行select * from kn_chongzhi where id>=1329544G (檢視在主2上寫了幾條資料)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
mysql> select * from kn_chongzhi where id >=1329544G
*************************** 3661. row *************************** id : 1329545
aa: 20130702213504529562 bizOfferId: DK201307021139565210 number: 13991056094 cc: 30.00 fac: 30.22 buyNum: 1 state: 2 type : SJ
create_time: 1372772104 update_time: 1372772474 flag: 100 *************************** 3662. row *************************** id : 1329546
aa: 20130702213506629648 bizOfferId: DK201307021139588209 number: 15511391791 cc: 30.00 fac: 30.17 buyNum: 1 state: 0 type : SJ
create_time: 1372772106 update_time: 0 flag: 100 *************************** 3663. row *************************** id : 1329547
aa: 20130702213516595293 bizOfferId: DK201307021139758209 number: 13615611693 cc: 100.00 fac: 99.85 buyNum: 1 state: 2 type : SJ
create_time: 1372772116 update_time: 1372772315 flag: 101 |
3、在主2上delete from kn_chongzhi where id>=1329544; 並設定自曾ID從1329545開始
1
2
3
4
5
|
mysql> delete from kn_chongzhi where id >=1329544;
Query OK, 0 rows affected (0.00 sec) mysql> alter table kn_chongzhi auto_increment=1329545; Query OK, 0 rows affected (0.15 sec) Records: 0 Duplicates: 0 Warnings: 0 |
4、主2上slave start,show slave status G,發現主2同步主1已經ok了;
5、在主2上show master status G,獲取binlog檔名和Position點,在主1上重新change master
6、把上面三條資料儲存好,發給程式猿手到錄入主1,
PS:當然,如果我按一下設定,肯定不會出現這個問題,如果業務有要求,ID必須連續,那就不能設定這兩個引數了:
1
2
3
4
5
6
|
主1: auto-increment-increment=2 auto-increment-offset=1 主2: auto-increment-increment=2 auto-increment-offset=2 |
相關文章
- 批量插入資料時主鍵衝突的處理
- 生產環境故障處理演練-mysql資料庫主從恢復MySql資料庫
- MySQL 主鍵衝突,無法插入資料MySql
- 生產環境中mysql資料庫由主從關係切換為主主關係MySql資料庫
- mysql主主同步MySql
- mysql 5.7主主同步MySql
- MySQL 5.6主主同步MySql
- mysql忽略主鍵衝突、避免重複插入的幾種方式MySql
- mysql 忽略主鍵衝突、避免重複插入的幾種方式MySql
- Mysql主主同步-配置資料同步MySql
- Windows 環境下,MySQL 的主從複製和主主複製WindowsMySql
- windows環境下,Mysql的主從複製和主主複製WindowsMySql
- 【MySQL】gh-ost改雙主表結構主鍵衝突問題MySql
- MYSQL 主從庫同步 異常處理彙總MySql
- MySQL Xtrabackup真實生產環境搭建主從複製全過程MySql
- 新環境搭建Mysql主從MySql
- UPDATE 時主鍵衝突引發的思考(連結)
- oracle 序列值導致的主鍵衝突問題Oracle
- Hibernate自定義產生主鍵方式
- mysql主從同步MySql主從同步
- 如何基於生產環境mysql 5.6.25主從部署新的mysql從庫操作指南MySql
- MySQL生產庫主從重新同步操作注意事項薦MySql
- MySQL主從不同步問題分析與處理思路MySql
- Linux環境中MySQL主從同步–新增新的從庫LinuxMySql主從同步
- 用 Docker 構建 MySQL 主從環境DockerMySql
- MySQL主從同步配置MySql主從同步
- MySQL主從複製、半同步複製和主主複製MySql
- MySQL主鍵的理解MySql
- 精益生產管理諮詢公司如何處理衝突?
- MySQL主從複製、半同步複製和主主複製概述MySql
- MYSQL資料庫主從同步(一主一從)MySql資料庫主從同步
- sysbench花式採坑之二:自增值導致的主鍵衝突
- MySQL 資料主從同步MySql主從同步
- MySql主從同步介紹MySql主從同步
- Mysql 主從同步實戰MySql主從同步
- mysql主從同步機制MySql主從同步
- mysql master slave 主從同步MySqlAST主從同步
- MySQL的主從複製、半同步複製、主主複製詳解MySql