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/