hi, im yuki на японском языке.
Я строю веб -систему с вышеуказанной конфигурацией.
Когда SqlTimeout происходит в базе данных, Hikaricp не откатывается, но сменит и терпит атмосферу.@Transactional(rollbackFor = Exception.class)
method{
1.delete table11
2.delete tablel2 -\> this point sqltimeout
}
< /code>
Удаление Table2 вызвало SQLTimeout, и произошло SQLTimeOutException, но удаление Table1 было совершено.
The Log также выводит "org.springframework.transaction.transactionsystemexcept: jdbc houlback не удался.@Around("execution(" + DAO + ")")
@Transactional(rollbackFor = Exception.class)
public Object daoLog(ProceedingJoinPoint joinpoint) throws Throwable {
Signature signature = joinpoint.getSignature();
// Execution class name
String className = "";
// Execution method name
String methodName = "";
// Execution function ID
String functionId = "";
// DB action
String action = "";
// Number of processes
int processCount = 0;
if (signature instanceof MethodSignature) {
// get method name
methodName = signature.getName();
// get class name
className = joinpoint.getTarget().getClass().getSimpleName();
// get DB action
action = getDbAction(methodName);
}
if (CompareUtil.isNotNull(loginInfoDto)) {
if (CompareUtil.isNotEmpty(loginInfoDto.getFunctionId())) {
// get function ID
functionId = loginInfoDto.getFunctionId();
}
}
try {
// execute DAO method
Object result = joinpoint.proceed();
// get the number of processes
processCount = getProcessCount(result);
// output log
log.info(String.format(LOG_FORMAT, functionId, className, methodName, String.format(MESSAGE_FORMAT, processCount, action)));
return result;
} catch (Exception ex) {
TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
log.info(String.format(LOG_FORMAT, functionId, className, methodName, "abnormal end " + ex.getClass().getName()));
throw ex;
}
}
< /code>
phenomenon < /h1>
1.joinpoint.proceed();
SQLTIMEOUT occurs
2.catch (Exception ex) {
At this point, the connection has already been committed and the connection has been destroyed
< /code>
hikari config < /h1>
spring:
datasource:
url : jdbc:oracle:thin:@XXXX/XX
username : XXXX
password : XXXX
driver-class-name : oracle.jdbc.OracleDriver
hikari:
connection-timeout: 15000
maximum-pool-size: 10
leak-detection-threshold: 60000
autoCommit: false
< /code>
журнал вспышки (выдержка) < /h1>
2025/06/11 11:07:08.003 [187] [900000] WARN c.z.h.p.ProxyConnection checkException HikariPool-5 - Connection oracle.jdbc.driver.T4CConnection@71ae8c9f marked as broken because of SQLSTATE(72000), ErrorCode(1013)
java.sql.SQLTimeoutException: ORA-01013:. Cancel of current operation requested by user
Caused by: oracle.jdbc.OracleDatabaseException:. ORA-01013: Cancel of current operation requested by user
at oracle.jdbc.driver.T4CTTIoer11.processError(T4CTTIoer11.java:530) ~[ojdbc10-19.20.0.0.jar:19.20.0.0.0]
... 181 more
2025/06/11 11:07:08.009 [187] [900000] INFO o.s.d.j.UtilLoggingJdbcLogger log [DOMA2222] THROW : CLASS=jp.co.xxxx.db.table.dao.tbikomeisaiexp.xxxxxpDaoImpl, METHOD=deleteTXxxxxxx, EXCEPTION=org.seasar.doma. SqlExecutionException
2025/06/11 11:07:08.010 [187] [900000] INFO j.c.h.c.i.DaoLogInterceptor daoLog SHMT0320 [Target Table]:TbikoMeisaiExpDaoImpl [SQL to execute]:deleteTbikoMeisaiExp Abnormal end org. QueryTimeoutException
2025/06/11 11:07:08.011 [187] [900000] INFO j.c.h.c.i.AppLogInterceptor controllerLog SHMT0320 900000 SHMT0320Controller regist abnormal termination org.springframework.transaction. TransactionSystemException
2025/06/11 11:07:08.012 [187] [900000] ERROR j.c.h.c.h.ControllerExceptionHandler handleException JDBC rollback failed
org.springframework.transaction. JDBC rollback faile
Caused by: java.sql.SQLException: Connection is closed
at com.zaxxer.hikari.pool.ProxyConnection$ClosedConnection.lambda$getClosedConnection$0(ProxyConnection.java:502) ~[HikariCP-5.0.1.jar:?]
at jdk.proxy4.$Proxy117.rollback(Unknown Source) ~[?:?]
at com.zaxxer.hikari.pool.ProxyConnection.rollback(ProxyConnection.java:385) ~[HikariCP-5.0.1.jar:?]
at com.zaxxer.hikari.pool.HikariProxyConnection.rollback(HikariProxyConnection.java) ~[HikariCP-5.0.1.jar:?]
at org.springframework.jdbc.datasource.DataSourceTransactionManager.doRollback(DataSourceTransactionManager.java:352) ~[spring-jdbc-6.0.12.jar:6.0.12]
... 127 more
2025/06/11 11:07:18.383 [187] [] ERROR o.a.c.c.C.[Tomcat].[localhost].[/xxxxx].[dispatcherServlet] log Servlet.service() for servlet [dispatcherServlet] in context with path [/xxxxx] threw exception [Request processing failed: org.springframework.transaction.TransactionSystemException: JDBC rollback failed] with root cause
java.sql.SQLException: Connection is closed
< /code>
Commortical < /h1>
- Time Out (ORA-01013) < /li>
Hikaricp (Spring Standard Connection Pour Уже закрытый < /li>
Распространен в верхние слои в качестве TransactionSystemexception < /li>
Зарегистрировано в журнале ошибок Tomcat < /li>
< /ol>
Запрашивает < /h1>
любое, что происходит, и все еще не обращается. Или кто -нибудь может сказать мне, как сделать Hikaricp, когда он закрывает соединение? Exception.class)
no good < /strong> < /li>
Использовать "TransactionAspectSupport.currentTransactionStatus (). Setrollbackonly ();" В try-catch
не хорошо - Установите AutoCommit: false в настройках Hikaricp
Нет хорошего
Подробнее здесь: https://stackoverflow.com/questions/796 ... ng-back-ja