Tomcat + Mysql connection pool issue on Cluster environment

Jamie Sammons, modified 2 Years ago. New Member Post: 1 Join Date: 11/17/21 Recent Posts

Getting below exception when portal is idle for some time. Causing the portal to be unresponsive. Using tomcat database connection pool.

 

com.liferay.portal.kernel.exception.SystemException: com.mysql.cj.jdbc.exceptions.CommunicationsException: The last packet successfully received from the server was 285,122 milliseconds ago.  The last packet sent successfully to the server was 285,126 milliseconds ago. is longer than the server configured value of 'wait_timeout'. You should consider either expiring and/or testing connection validity before use in your application, increasing the server configured values for client timeouts, or using the Connector/J connection property 'autoReconnect=true' to avoid this problem.
        at com.liferay.portal.kernel.internal.service.persistence.TableMapperImpl.getPrimaryKeys(TableMapperImpl.java:444)
        at com.liferay.portal.kernel.internal.service.persistence.TableMapperImpl.getLeftPrimaryKeys(TableMapperImpl.java:282)
        at com.liferay.portal.kernel.internal.service.persistence.change.tracking.CTTableMapper.getLeftPrimaryKeys(CTTableMapper.java:270)
        at com.liferay.portal.kernel.internal.service.persistence.ReverseTableMapper.getRightPrimaryKeys(ReverseTableMapper.java:133)
        at com.liferay.portal.service.persistence.impl.UserPersistenceImpl.getOrganizationPrimaryKeys(UserPersistenceImpl.java:9315)
        at com.liferay.portal.service.impl.OrganizationLocalServiceImpl.getUserOrganizationIds(OrganizationLocalServiceImpl.java:930)
        at sun.reflect.GeneratedMethodAccessor426.invoke(Unknown Source)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:498)
        at com.liferay.portal.spring.aop.AopMethodInvocationImpl.proceed(AopMethodInvocationImpl.java:50)
        at com.liferay.portal.spring.transaction.TransactionInterceptor.invoke(TransactionInterceptor.java:69)
        at com.liferay.portal.spring.aop.AopMethodInvocationImpl.proceed(AopMethodInvocationImpl.java:57)
        at com.liferay.portal.spring.aop.AopInvocationHandler.invoke(AopInvocationHandler.java:49)
        at com.sun.proxy.$Proxy184.getUserOrganizationIds(Unknown Source)
        at com.liferay.portal.kernel.service.OrganizationLocalServiceUtil.getUserOrganizationIds(OrganizationLocalServiceUtil.java:907)
        at com.liferay.portal.model.impl.UserImpl.getOrganizationIds(UserImpl.java:523)
        at com.liferay.portal.model.impl.UserImpl.getOrganizationIds(UserImpl.java:516)
        at com.liferay.portal.util.PortalImpl.getDoAsUserId(PortalImpl.java:7622)
        at com.liferay.portal.util.PortalImpl.getUserId(PortalImpl.java:5717)
        at com.liferay.portal.util.PortalImpl.getUser(PortalImpl.java:5588)
        at com.liferay.portal.kernel.util.PortalUtil.getUser(PortalUtil.java:1741)
        at com.liferay.portal.kernel.service.ServiceContextFactory._getInstance(ServiceContextFactory.java:217)
        at com.liferay.portal.kernel.service.ServiceContextFactory.getInstance(ServiceContextFactory.java:62)
        at com.liferay.portal.servlet.filters.absoluteredirects.AbsoluteRedirectsFilter.doFilterTry(AbsoluteRedirectsFilter.java:88)
        at com.liferay.portal.kernel.servlet.filters.invoker.InvokerFilterChain.processDirectCallFilter(InvokerFilterChain.java:194)
        at com.liferay.portal.kernel.servlet.filters.invoker.InvokerFilterChain.doFilter(InvokerFilterChain.java:99)
        at com.liferay.portal.kernel.servlet.filters.invoker.InvokerFilterChain.processDirectCallFilter(InvokerFilterChain.java:196)
        at com.liferay.portal.kernel.servlet.filters.invoker.InvokerFilterChain.doFilter(InvokerFilterChain.java:99)
        at org.tuckey.web.filters.urlrewrite.RuleChain.handleRewrite(RuleChain.java:176)
        at org.tuckey.web.filters.urlrewrite.RuleChain.doRules(RuleChain.java:145)
        at org.tuckey.web.filters.urlrewrite.UrlRewriter.processRequest(UrlRewriter.java:92)
        at org.tuckey.web.filters.urlrewrite.UrlRewriteFilter.doFilter(UrlRewriteFilter.java:389)
        at com.liferay.portal.servlet.filters.urlrewrite.UrlRewriteFilter.processFilter(UrlRewriteFilter.java:65)
        at com.liferay.portal.kernel.servlet.BaseFilter.doFilter(BaseFilter.java:49)
        at com.liferay.portal.kernel.servlet.filters.invoker.InvokerFilterChain.processDoFilter(InvokerFilterChain.java:215)
        at com.liferay.portal.kernel.servlet.filters.invoker.InvokerFilterChain.doFilter(InvokerFilterChain.java:116)
        at com.liferay.portal.kernel.servlet.filters.invoker.InvokerFilterChain.processDirectCallFilter(InvokerFilterChain.java:175)
        at com.liferay.portal.kernel.servlet.filters.invoker.InvokerFilterChain.doFilter(InvokerFilterChain.java:99)
        at com.liferay.portal.kernel.servlet.filters.invoker.InvokerFilterChain.processDirectCallFilter(InvokerFilterChain.java:175)
        at com.liferay.portal.kernel.servlet.filters.invoker.InvokerFilterChain.doFilter(InvokerFilterChain.java:99)
        at com.liferay.portal.kernel.servlet.filters.invoker.InvokerFilterChain.processDirectCallFilter(InvokerFilterChain.java:196)
        at com.liferay.portal.kernel.servlet.filters.invoker.InvokerFilterChain.doFilter(InvokerFilterChain.java:99)
        at com.liferay.portal.kernel.servlet.filters.invoker.InvokerFilter.doFilter(InvokerFilter.java:104)
        at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)
        at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)
        at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:202)
        at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)
        at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:541)
        at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:139)
        at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)
        at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:74)
        at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)
        at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:373)
        at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:65)
        at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:868)
        at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1589)
        at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
        at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
        at java.lang.Thread.run(Thread.java:748)
 

Thanks in advance