
Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
|
28.03.2015, 22:55:09
|
|||
|---|---|---|---|
|
|||
Транзакции в InnoDB - как отследить зависшую? |
|||
|
#18+
Здравствуйте. Запускаю первую транзакцию (1-ая консоль) без коммита: Код: sql 1. 2. Запускаю вторую транзакцию (2-ая консоль): Код: plsql 1. 2. Как и ожидалось, вторая транзакция зависает и через 50 сек выкидывает ошибку: "ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction". После этого, ни одна транзакция не сможет прочитать SELECT id FROM table WHERE id = 100 FOR UPDATE, и никаким запросом не обновить колонки ряда с id 100, пока первая транзакция не будет закоммичена или не разорвать соединение первой консоли с MySQL. Вопрос: как можно отследить проблему, увидеть незавершенные "висящие" транзакции и как их откатить или завершить (перезапуск MySQL, просьба, не предлагать). ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|

start [/forum/topic.php?fid=47&tablet=1&tid=1833370]: |
0ms |
get settings: |
7ms |
get forum list: |
15ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
43ms |
get topic data: |
9ms |
get forum data: |
2ms |
get page messages: |
35ms |
get tp. blocked users: |
1ms |
| others: | 193ms |
| total: | 311ms |

| 0 / 0 |
