国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

MySQL主從同步報error 1236

2024-07-24 12:32:10
字體:
來源:轉載
供稿:網友
       【一】前言:作為MySQL的數據庫管理員經常會碰到主從同步的問題,比較常見的有error 1236的報錯。剛好最近又碰到了這個報錯,以下是整理的文檔;
 
       【二】問題說明
1、環境信息
       mysql 版本:5.7.20
       操作系統版本:centeros 6.5
2、報錯信息
點擊(此處)折疊或打開
 
mysql> show slave status/G;
*************************** 1. row ***************************
               Slave_IO_State:
                  Master_Host: 192.168.1.19
                  Master_User: rep
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000123
          Read_Master_Log_Pos: 221693972
               Relay_Log_File: DB-02-relay-bin.000011
                Relay_Log_Pos: 320
        Relay_Master_Log_File: mysql-bin.000123
             Slave_IO_Running: No
            Slave_SQL_Running: Yes
              Replicate_Do_DB: DB02
          Replicate_Ignore_DB:
           Replicate_Do_Table:
       Replicate_Ignore_Table:
      Replicate_Wild_Do_Table:
  Replicate_Wild_Ignore_Table:
                   Last_Errno: 0
                   Last_Error:
                 Skip_Counter: 0
          Exec_Master_Log_Pos: 221693972
              Relay_Log_Space: 535
              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: 1236
                Last_IO_Error: Got fatal error 1236 from master when reading data from binary log: 'log event entry exceeded max_allowed_packet; Increase max_allowed_packet on master; the first event 'mysql-bin.000123' at 221693972, the last event read from '/data/binlog/mysql-bin.000123' at 123, the last byte read from '/data/binlog/mysql-bin.000123' at 221693991.'
               Last_SQL_Errno: 0
               Last_SQL_Error:
  Replicate_Ignore_Server_Ids:
             Master_Server_Id: 11
                  Master_UUID: b688e640-f5d3-11e7-9275-005056a675fe
             Master_Info_File: /data/mysql/master.info
                    SQL_Delay: 0
          SQL_Remaining_Delay: NULL
      Slave_SQL_Running_State: Slave has read all relay log; waiting for more updates
           Master_Retry_Count: 86400
                  Master_Bind:
      Last_IO_Error_Timestamp: 180705 23:22:44
     Last_SQL_Error_Timestamp:
               Master_SSL_Crl:
           Master_SSL_Crlpath:
           Retrieved_Gtid_Set:
            Executed_Gtid_Set: b688e640-f5d3-11e7-9275-005056a666fe:1
                Auto_Position: 0
         Replicate_Rewrite_DB:
                 Channel_Name:
           Master_TLS_Version:
【三】問題原因
Slave_IO_Running: No
 Slave_SQL_Running: Yes
通過以上兩個參數可以知道,當前binlog主庫傳送到從庫的時候就報錯了。已經傳送過來的binlog是可以正常執行的。
 
Last_IO_Error:max_allowed_packet顯示當前參數過小需要進行增加。
max_allowed_packet控制著主從復制過程binglog event傳送的大小,一般以下兩種情況主從就會報錯
1、參數在主備庫的配置大小不一樣,主庫的配置值大于從庫的配置值。 從主庫傳遞到備庫的binlog event大小超過了主庫或者備庫的max_allowed_packet大小。
2、主庫有大量數據寫入時,比如insert into .... select 語句,產生大事務。
當主庫向從庫傳遞一個比從庫的max_allowed_packet 大的packet ,從庫接收該packet失敗,并報 “log event entry exceeded max_allowed_packet“。
 
關于這個參數可以查看mysql的官方文檔:
https://dev.mysql.com/doc/refman/5.7/en/server-system-variables.html#sysvar_max_allowed_packet
Property Value
Command-Line Format --max-allowed-packet=#
System Variable max_allowed_packet
Scope Global, Session
Dynamic Yes
Type integer
Default Value 4194304
Minimum Value 1024
Maximum Value 1073741824該參數可以在session進行修改,最小1k,最大1GB,默認4M
 
【四】解決方法
點擊(此處)折疊或打開
 
參數查看的方法
mysql> show VARIABLES like '%max_allowed_packet%';
+--------------------------+------------+
| Variable_name | Value |
+--------------------------+------------+
| max_allowed_packet | 1073741824 |
| slave_max_allowed_packet | 1073741824 |
+--------------------------+------------+
2 rows in set (0.00 sec)
 
不重啟數據庫的修改方法,但是修改之后要重新登陸mysql
set global max_allowed_packet =512*1024*1024
 
重啟數據庫的修改方法
或者修改my.cnf參數
[server]
slave_max_allowed_packet = 512M
 
修改完之后,重新進行stop slave,再start slave
 
但是這只是其中的一個情況,最近遇到了一個數據庫發現max_allowed_packet參數已經進行了設置,但是無論如何主從也都不會同步。
最后發現由于用戶的誤操作,導致master_log_pos位置錯了,需要重新調整。
change master to master_log_file='mysql-bin.006738', master_log_pos=107;
 
總結:經過一頓折騰總算搞定了,有時候報錯信息很明顯,但是怎么解決都處理不了,這時候管理員的經驗就體現出來了。還有mysql這種開源的產品后續報錯的提示需要更清楚一點,管理起來也會輕松很多。

(編輯:武林網)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 右玉县| 建瓯市| 仙桃市| 哈密市| 萝北县| 山东| 龙海市| 囊谦县| 乌鲁木齐市| 庆安县| 堆龙德庆县| 于田县| 古浪县| 汶上县| 杭锦旗| 黑水县| 什邡市| 芷江| 韶关市| 红安县| 延安市| 抚顺市| 定陶县| 大同县| 应城市| 玉屏| 十堰市| 五寨县| 广丰县| 佛坪县| 乐东| 大庆市| 敦煌市| 安康市| 平湖市| 永济市| 茌平县| 桃园县| 大关县| 赤峰市| 双峰县|