forum.bitel.ru http://forum.bitel.ru/ |
|
[5.2] http://forum.bitel.ru/viewtopic.php?f=44&t=11311 |
Страница 1 из 1 |
Автор: | [LTC]Dimonyga [ 03 фев 2016, 19:40 ] |
Заголовок сообщения: | [5.2] |
Deadlock появился при обновлении модуля inet с версии 1377 на версию 1381 Посмотрел, ничего критичного, но глаз мазолит =) Цитата: radius 02-03/21:08:26 ERROR [rdsLstnr-p-7-t-10] InetRadiusListenerWorker - com.mysql.jdbc.exceptions.jdbc4.MySQLTransactionRollbackException: Deadlock found when trying to get lock; try restarting transaction ru.bitel.bgbilling.common.BGException: com.mysql.jdbc.exceptions.jdbc4.MySQLTransactionRollbackException: Deadlock found when trying to get lock; try restarting transaction at ru.bitel.bgbilling.modules.inet.api.server.bean.InetAuthErrorDao.addError(InetAuthErrorDao.java:272) at ru.bitel.bgbilling.modules.inet.radius.InetRadiusListenerWorker.writeLog(InetRadiusListenerWorker.java:168) at ru.bitel.bgbilling.modules.inet.radius.InetRadiusListenerWorker.accessRequest(InetRadiusListenerWorker.java:76) at ru.bitel.bgbilling.modules.inet.radius.InetRadiusListenerWorker.accessRequest(InetRadiusListenerWorker.java:1) at ru.bitel.bgbilling.kernel.network.radius.RadiusListenerWorker.processPacket(RadiusListenerWorker.java:216) at ru.bitel.bgbilling.kernel.network.radius.RadiusListenerWorker.runImpl(RadiusListenerWorker.java:135) at ru.bitel.common.worker.WorkerTask.run(WorkerTask.java:86) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1146) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) at java.lang.Thread.run(Thread.java:701) at ru.bitel.common.worker.WorkerThread.run(WorkerThread.java:40) Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLTransactionRollbackException: Deadlock found when trying to get lock; try restarting transaction at sun.reflect.GeneratedConstructorAccessor69.newInstance(Unknown Source) at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) at java.lang.reflect.Constructor.newInstance(Constructor.java:534) at com.mysql.jdbc.Util.handleNewInstance(Util.java:407) at com.mysql.jdbc.Util.getInstance(Util.java:382) at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1064) at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3593) at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3525) at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1986) at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2140) at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2626) at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:2111) at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2407) at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2325) at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2310) at org.apache.commons.dbcp.DelegatingPreparedStatement.executeUpdate(DelegatingPreparedStatement.java:105) at ru.bitel.bgbilling.modules.inet.api.server.bean.InetAuthErrorDao.addError(InetAuthErrorDao.java:218) Цитата: innodb_version 5.5.41-37.0 protocol_version 10 version 5.5.41-37.0-55-log version_comment Percona XtraDB Cluster (GPL), Release rel37.0, Rev... version_compile_machine x86_64 version_compile_os Linux Подключение к mysql реализовано в режиме failover, репликация multimaster, но одно приложение одновременно подключено только к одному серверу, так как для realtime необходимо отключать кэширование, а это приводит к диким дисковым IO. Пробовал выводить ноду из кластера и подключаться только к ней (без репликации, будто сервер совсем один) - ситуация аналогичная. |
Автор: | Amir [ 03 фев 2016, 19:52 ] |
Заголовок сообщения: | Re: [5.2] |
Можно попробовать отключить обновление записей с увеличением счетчика - будет только добавлять. Для этого в корневом устройстве нужно указать authError.update=0 Или можно попробовать установить асинхронную запись в эту таблицу (с 6.0-6.1 это по умолчанию) authError.async=1 #authError.async.maxQueueSize=5000 #authError.async.timeout=50 Можно оба варианта сразу. |
Автор: | [LTC]Dimonyga [ 03 фев 2016, 20:00 ] |
Заголовок сообщения: | Re: [5.2] |
Спасибо, попробую authError.async=1 Как то не очень хочется лишние строки в базе... |
Автор: | [LTC]Dimonyga [ 06 фев 2016, 23:38 ] |
Заголовок сообщения: | Re: [5.2] |
Про добавлении асинхронного обработчика ошибка ушла, Спасибо =) |
Страница 1 из 1 | Часовой пояс: UTC + 5 часов [ Летнее время ] |
Powered by phpBB® Forum Software © phpBB Group http://www.phpbb.com/ |