问题描述:

数据库从库停止同步。

问题分析:

show slave status\G;(也可使用show full processlist)

显示 某个update语句出错,Lock wait timeout exceeded; try restarting transaction;

原因是这条语句提交的时候超时堵塞。原因在于另外的一个操作开启了事务,锁定了相应的数据,导致这条操作相同数据的sql出错。

示例,在sql中

(1)开启事务,锁定数据

终端A:

mysql> begin; (开启事务,开启事务会锁定相关数据)

Query OK, 0 rows affected (0.00 sec)

mysql> update pet set sex="m" where name="Fluffy";(修改)

Query OK, 1 row affected (0.03 sec)

Rows matched: 1  Changed: 1  Warnings: 0

mysql> select * from pet;

+--------+--------+---------+------+------------+------------+

| name   | owner  | species | sex  | birth      | death      |

+--------+--------+---------+------+------------+------------+

| Bowser | Diane  | dog     | m    | 1979-08-31 | 1995-07-29 |

| Buffy  | Harold | dog     | f    | 1989-05-13 | NULL       |

| Claws  | Gwen   | cat     | m    | 1994-03-17 | NULL       |

| Fang   | Benny  | dog     | m    | 2013-02-05 | NULL       |

| Fluffy | Harold | cat     | m    | 2012-09-30 | NULL       |

+--------+--------+---------+------+------------+------------+

5 rows in set (0.00 sec)

终端B:

mysql> select * from pet;

+--------+--------+---------+------+------------+------------+

| name   | owner  | species | sex  | birth      | death      |

+--------+--------+---------+------+------------+------------+

| Bowser | Diane  | dog     | m    | 1979-08-31 | 1995-07-29 |

| Buffy  | Harold | dog     | f    | 1989-05-13 | NULL       |

| Claws  | Gwen   | cat     | m    | 1994-03-17 | NULL       |

| Fang   | Benny  | dog     | m    | 2013-02-05 | NULL       |

| Fluffy | Harold | cat     | NULL | 2012-09-30 | NULL       |

+--------+--------+---------+------+------------+------------+

5 rows in set (0.01 sec)

因为没有提交,所以实际上没有改变。但是会锁定Fluffy这一条数据。导致如下的错误。

终端B:

mysql> update pet set sex="m" where name="Fluffy";



ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction

(2)提交事务,解锁数据

终端A:

mysql> commit;

Query OK, 0 rows affected (0.10 sec)

终端B:

mysql> select * from pet;

+--------+--------+---------+------+------------+------------+

| name   | owner  | species | sex  | birth      | death      |

+--------+--------+---------+------+------------+------------+

| Bowser | Diane  | dog     | m    | 1979-08-31 | 1995-07-29 |

| Buffy  | Harold | dog     | f    | 1989-05-13 | NULL       |

| Claws  | Gwen   | cat     | m    | 1994-03-17 | NULL       |

| Fang   | Benny  | dog     | m    | 2013-02-05 | NULL       |

| Fluffy | Harold | cat     | m    | 2012-09-30 | NULL       |

+--------+--------+---------+------+------------+------------+

5 rows in set (0.00 sec)

mysql> update pet set sex="f" where name="Fluffy";

Query OK, 1 row affected (0.08 sec)

Rows matched: 1  Changed: 1  Warnings: 0

(3)如果where中的条件是索引字段,那么只会锁定索引对应的条目;如果不是索引字段,那么会锁定整张表。

终端A:

mysql> update pet set sex="f" where death="1995-07-29";

Query OK, 1 row affected (0.03 sec)

Rows matched: 1  Changed: 1  Warnings: 0

mysql> select * from pet;

+--------+--------+---------+------+------------+------------+

| name   | owner  | species | sex  | birth      | death      |

+--------+--------+---------+------+------------+------------+

| Bowser | Diane  | dog     | f    | 1979-08-31 | 1995-07-29 |

| Buffy  | Harold | dog     | f    | 1989-05-13 | NULL       |

| Claws  | Gwen   | cat     | m    | 1994-03-17 | NULL       |

| Fang   | Benny  | dog     | m    | 2013-02-05 | NULL       |

| Fluffy | Harold | cat     | f    | 2012-09-30 | NULL       |

+--------+--------+---------+------+------------+------------+

5 rows in set (0.00 sec)

终端B:

mysql> select * from pet;

+--------+--------+---------+------+------------+------------+

| name   | owner  | species | sex  | birth      | death      |

+--------+--------+---------+------+------------+------------+

| Bowser | Diane  | dog     | m    | 1979-08-31 | 1995-07-29 |

| Buffy  | Harold | dog     | f    | 1989-05-13 | NULL       |

| Claws  | Gwen   | cat     | m    | 1994-03-17 | NULL       |

| Fang   | Benny  | dog     | m    | 2013-02-05 | NULL       |

| Fluffy | Harold | cat     | f    | 2012-09-30 | NULL       |

+--------+--------+---------+------+------------+------------+

5 rows in set (0.00 sec)

mysql> update pet set death="2013-07-00" where birth="2013-02-05";

ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction

解决办法

(1) stop slave;      start slave

(2)网上分析说

Mysql 'Lock wait timeout exceeded; try restarting transaction' 解决方案

ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction 

Temporary error: 266: Time-out in NDB, probably caused by deadlock 解决方法:在管理节点的[ndbd default] 

区加:

TransactionDeadLockDetectionTimeOut=10000(设置为10秒)默认是1200(1.2秒)按照顺序重新启动各个节点就不会出现问题了。

不过,本身貌似数据库的TransactionDeadLockDetectionTimeOut已经设置很大,而且即使设置很大,如果那边一直锁表,也是解决不了问题的。

mysql trouble shooting---- 从库停止同步lock_wait_timeout_exceeded_try_restarting_transaction的更多相关文章

  1. 不停止MySQL服务增加从库的两种方式

    不停止MySQL服务增加从库的两种方式 转载自:http://lizhenliang.blog.51cto.com/7876557/1669829 现在生产环境MySQL数据库是一主一从,由于业务量访 ...

  2. 不停止MySQL服务增加从库的两种方式【转载】

    现在生产环境MySQL数据库是一主一从,由于业务量访问不断增大,故再增加一台从库.前提是不能影响线上业务使用,也就是说不能重启MySQL服务,为了避免出现其他情况,选择在网站访问量低峰期时间段操作. ...

  3. MYSQL双主全库同步复制

    环境: A.B两台服务器分别安装mysql-5.7.18服务端,配置成互为主从同步. linux系统版本为CentOS7 A服务器ip:192.168.1.7   主机名:test1 B服务器ip:1 ...

  4. 忽略mysql库的同步

    忽略mysql库的同步,请使用: stop slave sql_thread; change replication filter replicate_ignore_db=(mysql);

  5. mysql主从架构,IO、SQL线程运行为YES,从库没有同步数据

    mysql基于binlog主从复制架构,IO.SQL线程运行为YES,从库没有同步数据 Slave_IO_Running: Yes Slave_SQL_Running: Yes Replicate_D ...

  6. 不停mysql服务添加从库的两种方式

    现在生产环境MySQL数据库是一主一从,由于业务量访问不断增大,故再增加一台从库.前提是不能影响线上业务使用,也就是说不能重启MySQL服务,为了避免出现其他情况,选择在网站访问量低峰期时间段操作. ...

  7. Mysql 实现基于binlog的主从同步

    工作原理 1.主节点必须启用二进制日志,记录任何修改了数据库数据的事件.2.从节点开启一个线程(I/O Thread)把自己扮演成 mysql 的客户端,通过 mysql 协议,请求主节点的二进制日志 ...

  8. MySQL主主互备不同步的解决方法

    MySQL主主互备不同步 首先在服务器上执行show slave satus;可以看到很多同步的参数: Master_Log_File: SLAVE中的I/O线程当前正在读取的主服务器二进制日志文件的 ...

  9. MySQL 5.7 深度解析: 半同步复制技术

    复制架构衍生史 在谈这个特性之前,我们先来看看MySQL的复制架构衍生史. MySQL的复制分为四种: 普通的replication,异步同步. 搭建简单,使用非常广泛,从mysql诞生之初,就产生了 ...

随机推荐

  1. php非阻塞

    PHP非阻塞模式 让PHP不再阻塞当PHP作为后端处理需要完成一些长时间处理,为了快速响应页面请求,不作结果返回判断的情况下,可以有如下措施: 一.若你使用的是FastCGI模式,使用fastcgi_ ...

  2. Object对象

    1.Object类:所有类的根类.是不断抽取而来的,具备所有对象都具有的共性内容.其中的方法,任何对象都可以调用.继承而来的. equals()方法: Object类的equals源码:比较两个对象是 ...

  3. CDockablePane 记忆界面布局的问题

    CWinAppEx类的LoadCustomState()和SaveCustomState()用于向注册表读取和保存应用程序的界面信息,重载该方法可以取消自动记忆界面布局. void CxxxApp:: ...

  4. IE6下整站的bug详解

    <1>文字不居中:加一个行高: <2>png文件作为背景不显示: <!--[if IE 6]> <script src="js/DD_belated ...

  5. HDU - 5234 Happy birthday

    Problem Description Today is Gorwin’s birthday. So her mother want to realize her a wish. Gorwin say ...

  6. nginx slab内存管理

    本来这一篇作为nginx系列的开头是不合适的,不过由于nginx进程框架自己的梳理还没完成,这部分又刚好整理完了,就从这开始吧.这儿谈的是nginx的slab的内存管理方式,这种方式的内存管理在ngi ...

  7. update set from where

    原文链接:http://blog.csdn.net/xcbsdu/article/details/6736503 关于update set from where 下面是这样一个例子: 两个表a.b,想 ...

  8. VIJOS P1647 不差钱 SBT

    [描述] 同学们一起看了小品<不差钱>,LX神突发奇想,想刁难一下十八居士,他让十八居士模拟一下点菜的过程. [输入格式] 输入第一行为一个数price,表示价钱大于price的菜赵本山都 ...

  9. MapReduce常见算法

    1.单词计数 2.数据去重 3.排序 4.Top K(求数据中的最大值) 5.选择 6.投影 7.分组 8.多表连接 9.单表关联

  10. ubuntu下如何安装及使用 pysvn-workbench

    网上对于 pysvn-workbench 的教程几乎没有,没办法,只好去官网自学了,现在能正常上传资料了,写点东西,以免今后忘了 安装方面:在新立得中查找svn-workbench,subversio ...