`
sundful
  • 浏览: 1250229 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Slave_SQL_Running: No mysql同步故障解决方法

 
阅读更多
Slave_SQL_Running: No mysql同步故障解决
     今天检查数据库发现一台MySQL Slave未和主机同步,查看Slave状态:
mysql> show slave status\G
Slave_IO_Running: Yes
Slave_SQL_Running: No
Last_Errno: 1062
....
Seconds_Behind_Master:NULL
原因:
1.程序可能在slave上进行了写操作 
2.也可能是slave机器重起后,事务回滚造成的.
解决办法I:
1.首先停掉Slave服务:slave stop
2.到主服务器上查看主机状态:
记录File和Position对应的值。
mysql> show master status;
+------------------+-----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+-----------+--------------+------------------+
| mysql-bin.000020 | 135617781 | | |
+------------------+-----------+--------------+------------------+
1 row in set (0.00 sec)
3.到slave服务器上执行手动同步:
mysql> change master to 
> master_host='master_ip',
> master_user='user', 
> master_password='pwd', 
> master_port=3307, 
> master_log_file='mysql-bin.000020', 
> master_log_pos=135617781;
1 row in set (0.00 sec)
mysql> slave start;
1 row in set (0.00 sec)
再次查看slave状态发现:
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
...
Seconds_Behind_Master: 0
解决办法II:
mysql> slave stop;
mysql> set GLOBAL SQL_SLAVE_SKIP_COUNTER=1;
mysql> slave start;
 
自己的使用体会:方法一是强制性从某一个点开始同步,会有部分没有同步的数据丢失,后续主服务器上删除记录同步也会有一些错误信息,不会影响使用.方法二不一定会有效果.
 
 
=======================================================================================]
1,主从不能同步:
show slave status;报错:Error xxx dosn't exist
且show slave status\G:
Slave_SQL_Running: NO
Seconds_Behind_Master: NULL
解决方法:
stop slave;
set global sql_slave_skip_counter =1 ;
start slave;
之后Slave会和Master去同步 主要看:
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Seconds_Behind_Master是否为0,0就是已经同步了
2,还需要做的一些优化与监视:
show full processlist; //查看mysql当前同步线程号
skip-name-resolve       //跳过dns名称查询,有助于加快连接及同步的速度
max_connections=1000    //增大Mysql的连接数目,(默认100)
max_connect_errors=100 //增大Mysql的错误连接数目,(默认10)
 

查看日志一些命令
1,  show master status\G;
           在这里主要是看log-bin的文件是否相同。
    show slave status\G;
    在这里主要是看:
                   Slave_IO_Running=Yes
                   Slave_SQL_Running=Yes
   如果都是Yes,则说明配置成功.
2,在master上输入show processlist\G;
     mysql> SHOW PROCESSLIST\G
     *************************** 1. row ***************************
       Id: 2
       User: root
       Host: localhost:32931
       db: NULL
       Command: Binlog Dump
       Time: 94
       State: Has sent all binlog to slave; waiting for binlog to
         be updated
       Info: NULL
   如果出现Command: Binlog Dump,则说明配置成功.
 
 
stop slave    #停止同步 
start slave    #开始同步,从日志终止的位置开始更新。 
SET SQL_LOG_BIN=0|1  #主机端运行,需要super权限,用来开停日志,随意开停,会造成主机从机数据不一致,造成错误 
SET GLOBAL SQL_SLAVE_SKIP_COUNTER=n  # 客户端运行,用来跳过几个事件,只有当同步进程出现错误而停止的时候才可以执行。 
RESET MASTER  #主机端运行,清除所有的日志,这条命令就是原来的FLUSH MASTER 
RESET SLAVE   #从机运行,清除日志同步位置标志,并重新生成master.info
虽然重新生成了master.info,但是并不起用,最好,将从机的mysql进程重启一下, 
LOAD TABLE tblname FROM MASTER #从机运行,从主机端重读指定的表的数据,每次只能读取一个,受timeout时间限制,需要调整timeout时间。执行这个命令需要同步账号有 reload和super权限。以及对相应的库有select权限。如果表比较大,要增加net_read_timeout 和 net_write_timeout的值 
LOAD DATA FROM MASTER  #从机执行,从主机端重新读入所有的数据。执行这个命令需要同步账号有reload和super权限。以及对相应的库有select权限。如果表比较大,要增加net_read_timeout 和 net_write_timeout的值 
CHANGE MASTER TO master_def_list  #在线改变一些主机设置,多个用逗号间隔,比如
CHANGE MASTER TO
  MASTER_HOST='master2.mycompany.com',
  MASTER_USER='replication',
  MASTER_PASSWORD='bigs3cret' 
MASTER_POS_WAIT() #从机运行 
SHOW MASTER STATUS #主机运行,看日志导出信息 
SHOW SLAVE HOSTS #主机运行,看连入的从机的情况。 
SHOW SLAVE STATUS (slave) 
SHOW MASTER LOGS (master) 
SHOW BINLOG EVENTS [ IN 'logname' ] [ FROM pos ] [ LIMIT [offset,] rows ] 
PURGE [MASTER] LOGS TO 'logname' ; PURGE [MASTER] LOGS BEFORE 'date'
分享到:
评论

相关推荐

    mysql 主从数据不一致,提示: Slave_SQL_Running: No 的解决方法

    本文实例讲述了mysql 主从数据不一致,提示: Slave_SQL_Running No 的解决方法。分享给大家供大家参考,具体如下: 在slave服务器上通过如下命令 mysql> show slave status\G; 显示如下情况: Slave_IO_Running: ...

    MYSQL同步 Slave_IO_Running: No 或者Slave_SQL_Running: No的解决方法[已测]

    今天在测试mysql是否同步时,检查数据库发现一台MySQL Slave未和主机同步,查看Slave状态: mysql> show slave status\G Slave_IO_Running: Yes Slave_SQL_Running: No Last_Errno: 1062 …. Seconds_Behind_Master:...

    mysql 数据同步 出现Slave_IO_Running:No问题的解决方法小结

    下面写一下,这两个要是有no了,怎么恢复。。 如果是slave_io_running no了,那么就我个人看有三种情况,一个是网络有问题,连接不上,像有一次我用虚拟机搭建replication,使用了nat的网络... 如果是slave_sql_running

    Mysql主从复制Slave_IO_Running: No解决

    mysql> show master status; +------------------+----------+--------------+--------------------------+-------------------+ | File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set | +----...

    MySQL-Master_Slave_repl.txt

     Slave_SQL_Running: Yes It means that it was successful.     Errors in the whole process: Slave_IO_Running: Connecting 1. Mine is the wrong host ip. 2. There are still some firewalls on the ...

    mysql 主从 数据同步

    chown -R mysql:mysql /data/mysql/cacti ``` 2. **设置从服务器的服务器ID**:同样需要设置一个唯一的服务器ID。 ```ini server-id = 2 ``` 3. **配置连接重试时间**:定义从服务器尝试连接主服务器的重试...

    关于MySQL中savepoint语句使用时所出现的错误

    前几天帮同事解决一个案例,在主从... Slave_SQL_Running: No Last_Errno: 1064 Last_Error: Error 'You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for t

    MySQL主从配置完整步骤资料

    `Slave_IO_Running`和`Slave_SQL_Running`均为`Yes`表明复制正在成功运行。如果出现任何错误,可以在此输出中找到错误详情(`Last_Error`等字段)。 ### 总结 本文详细介绍了MySQL主从配置的具体步骤和命令,包括...

    Mysql安装部署手册.doc

    7. 解决同步故障:在Mysql主从复制中,可能会出现同步故障,例如Slave_SQL_Running:No等问题。本手册提供了两种解决办法,以帮助用户解决这些问题。 8. 服务器信息配置:在安装Mysql 8之前,需要配置服务器信息,...

    mariadb数据库同步

    - `Slave_SQL_Running`: Yes - `Last_IO_Errno`: 0 - `Last_IO_Error`: (空) - `Last_SQL_Errno`: 0 - `Last_SQL_Error`: (空) #### 六、解锁数据库 完成同步配置后,需要解除数据库的锁定。 ```sql unlock ...

    常用sql脚本

    - `Slave_SQL_Running`: 表示SQL线程是否正在运行。 - `Seconds_Behind_Master`: 从库落后于主库的时间(秒),用于衡量从库与主库的同步情况。 ### 2. 查询指定日期的数据 #### (a) 访问记录查询 - **SQL脚本**...

    nagios监控mysql主从

    2. 通过`grep`和`awk`筛选出`Slave_IO_Running`和`Slave_SQL_Running`的状态。 3. 判断状态是否都为`Yes`,如果是,则输出`OK - Slave is running`;否则输出`Critical - Slave is error`。 **脚本执行测试:** ``...

    主从单向和双向备份配置

    如果看到 `Slave_IO_Running: Yes` 和 `Slave_SQL_Running: Yes`,则证明配置成功。 双向备份配置 双向备份是指主数据库和从数据库之间的互相备份,实现了数据的双向同步。双向备份的配置是在单向备份的基础上,...

Global site tag (gtag.js) - Google Analytics