2016-11-03 2 views
0

При просмотре некоторых журналов после GlassFish сервер был будучи не отвечает, я наткнулся на эту ошибку:EclipseLink параллелизм исключение

{{[#|2016-06-02T08:37:51.737+0200|WARNING|oracle- 
glassfish3.1.2|org.restlet.Component.ServiceDispatcher|_ThreadID=165;_ThreadName=http-thread-pool-37860(5);|Exception or error caught in status service 
javax.ejb.EJBException 
at com.sun.ejb.containers.BaseContainer.processSystemException(BaseContainer.java:5236) 
at com.sun.ejb.containers.BaseContainer.checkExceptionNoTx(BaseContainer.java:5065) 
at com.sun.ejb.containers.BaseContainer.postInvokeTx(BaseContainer.java:4900) 
at com.sun.ejb.containers.BaseContainer.postInvoke(BaseContainer.java:2046) 
at com.sun.ejb.containers.BaseContainer.postInvoke(BaseContainer.java:1995) 
at com.sun.ejb.containers.EJBLocalObjectInvocationHandler.invoke(EJBLocalObjectInvocationHandler.java:222) 
at com.sun.ejb.containers.EJBLocalObjectInvocationHandlerDelegate.invoke(EJBLocalObjectInvocationHandlerDelegate.java:89) 
at com.sun.proxy.$Proxy228.getKpiValuesFlat(Unknown Source) 
at com.business.renderer.TopSuppliers.getData(TopSuppliers.java:174) 
at com.business.renderer.TopSuppliers.getDataAsJSONTopSuppliers.java:179) 
at com.business.renderer.TopSuppliers.render(TopSuppliers.java:107) 
at com.ui.renderer.engine.AbstractRenderingEngine.render(AbstractRenderingEngine.java:140) 
at com.services.filter.ContainerAdapter.represent(ContainerAdapter.java:311) 
at org.restlet.resource.Resource.getRepresentation(Resource.java:259) 
at org.restlet.resource.Resource.handleGet(Resource.java:425) 
at org.restlet.resource.Finder.handle(Finder.java:470) 
at org.restlet.routing.Filter.doHandle(Filter.java:156) 
at org.restlet.routing.Filter.handle(Filter.java:203) 
at org.restlet.routing.Router.doHandle(Router.java:497) 
at org.restlet.routing.Router.handle(Router.java:737) 
at com.servlets.ServiceDispatcher$1.handle(ServiceDispatcher.java:55) 
at org.restlet.routing.Filter.doHandle(Filter.java:156) 
at org.restlet.routing.Filter.handle(Filter.java:203) 
at org.restlet.routing.Filter.doHandle(Filter.java:156) 
at org.restlet.routing.Filter.handle(Filter.java:203) 
at org.restlet.routing.Filter.doHandle(Filter.java:156) 
at org.restlet.engine.application.StatusFilter.doHandle(StatusFilter.java:151) 
at org.restlet.routing.Filter.handle(Filter.java:203) 
at org.restlet.routing.Filter.doHandle(Filter.java:156) 
at org.restlet.routing.Filter.handle(Filter.java:203) 
at org.restlet.engine.ChainHelper.handle(ChainHelper.java:111) 
at org.restlet.engine.application.ApplicationHelper.handle(ApplicationHelper.java:72) 
at org.restlet.Application.handle(Application.java:388) 
at org.restlet.routing.Filter.doHandle(Filter.java:156) 
at org.restlet.routing.Filter.handle(Filter.java:203) 
at org.restlet.routing.Router.doHandle(Router.java:497) 
at org.restlet.routing.Router.handle(Router.java:737) 
at org.restlet.routing.Filter.doHandle(Filter.java:156) 
at org.restlet.routing.Filter.handle(Filter.java:203) 
at org.restlet.routing.Router.doHandle(Router.java:497) 
at org.restlet.routing.Router.handle(Router.java:737) 
at org.restlet.routing.Filter.doHandle(Filter.java:156) 
at org.restlet.routing.Filter.handle(Filter.java:203) 
at org.restlet.engine.ChainHelper.handle(ChainHelper.java:111) 
at org.restlet.Component.handle(Component.java:387) 
at org.restlet.Server.handle(Server.java:488) 
at org.restlet.engine.ServerHelper.handle(ServerHelper.java:71) 
at org.restlet.engine.http.HttpServerHelper.handle(HttpServerHelper.java:150) 
at org.restlet.ext.servlet.ServerServlet.service(ServerServlet.java:1037) 
at javax.servlet.http.HttpServlet.service(HttpServlet.java:770) 
at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1554) 
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:339) 
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
at com.jamonapi.JAMonFilter.doFilter(JAMonFilter.java:59) 
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:252) 
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210) 
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:278) 
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175) 
at org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:655) 
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:595) 
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:161) 
at org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:655) 
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:595) 
at org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:334) 
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:230) 
at com.sun.enterprise.v3.services.impl.ContainerMapper$AdapterCallable.call(ContainerMapper.java:311) 
at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:189) 
at com.sun.grizzly.http.ProcessorTask.invokeAdapter(ProcessorTask.java:850) 
at com.sun.grizzly.http.ProcessorTask.doProcess(ProcessorTask.java:747) 
at com.sun.grizzly.http.ProcessorTask.process(ProcessorTask.java:1032) 
at com.sun.grizzly.http.DefaultProtocolFilter.execute(DefaultProtocolFilter.java:231) 
at com.sun.grizzly.DefaultProtocolChain.executeProtocolFilter(DefaultProtocolChain.java:137) 
at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:104) 
at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:90) 
at com.sun.grizzly.http.HttpProtocolChain.execute(HttpProtocolChain.java:79) 
at com.sun.grizzly.ProtocolChainContextTask.doCall(ProtocolChainContextTask.java:54) 
at com.sun.grizzly.SelectionKeyContextTask.call(SelectionKeyContextTask.java:59) 
at com.sun.grizzly.ContextTask.run(ContextTask.java:71) 
at com.sun.grizzly.util.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:532) 
at com.sun.grizzly.util.AbstractThreadPool$Worker.run(AbstractThreadPool.java:513) 
at java.lang.Thread.run(Thread.java:745) 
Caused by: Exception [EclipseLink-2004] (Eclipse Persistence Services - 2.3.4.v20151027-346465e): org.eclipse.persistence.exceptions.ConcurrencyException 
Exception Description: A signal was attempted before wait() on ConcurrencyManager. This normally means that an attempt was made to 
commit or rollback a transaction before it was started, or to rollback a transaction twice. 
at org.eclipse.persistence.exceptions.ConcurrencyException.signalAttemptedBeforeWait(ConcurrencyException.java:84) 
at org.eclipse.persistence.internal.helper.ConcurrencyManager.releaseReadLock(ConcurrencyManager.java:489) 
at org.eclipse.persistence.internal.identitymaps.CacheKey.releaseReadLock(CacheKey.java:386) 
at org.eclipse.persistence.internal.sessions.UnitOfWorkImpl.cloneAndRegisterObject(UnitOfWorkImpl.java:1018) 
at org.eclipse.persistence.internal.sessions.UnitOfWorkImpl.cloneAndRegisterObject(UnitOfWorkImpl.java:929) 
at org.eclipse.persistence.internal.sessions.UnitOfWorkIdentityMapAccessor.getAndCloneCacheKeyFromParent(UnitOfWorkIdentityMapAccessor.java:181) 
at org.eclipse.persistence.internal.sessions.UnitOfWorkIdentityMapAccessor.getFromIdentityMap(UnitOfWorkIdentityMapAccessor.java:120) 
at org.eclipse.persistence.internal.sessions.IdentityMapAccessor.getFromIdentityMap(IdentityMapAccessor.java:380) 
at org.eclipse.persistence.internal.sessions.UnitOfWorkImpl.registerExistingObject(UnitOfWorkImpl.java:3899) 
at org.eclipse.persistence.internal.sessions.UnitOfWorkImpl.registerExistingObject(UnitOfWorkImpl.java:3854) 
at org.eclipse.persistence.mappings.CollectionMapping.buildElementUnitOfWorkClone(CollectionMapping.java:267) 
at org.eclipse.persistence.mappings.CollectionMapping.buildElementClone(CollectionMapping.java:279) 
at org.eclipse.persistence.internal.queries.ContainerPolicy.addNextValueFromIteratorInto(ContainerPolicy.java:213) 
at org.eclipse.persistence.mappings.CollectionMapping.buildCloneForPartObject(CollectionMapping.java:205) 
at org.eclipse.persistence.internal.indirection.UnitOfWorkQueryValueHolder.buildCloneFor(UnitOfWorkQueryValueHolder.java:51) 
at org.eclipse.persistence.internal.indirection.UnitOfWorkValueHolder.instantiateImpl(UnitOfWorkValueHolder.java:161) 
at org.eclipse.persistence.internal.indirection.UnitOfWorkValueHolder.instantiate(UnitOfWorkValueHolder.java:222) 
at org.eclipse.persistence.internal.indirection.DatabaseValueHolder.getValue(DatabaseValueHolder.java:88) 
at org.eclipse.persistence.indirection.IndirectList.buildDelegate(IndirectList.java:244) 
at org.eclipse.persistence.indirection.IndirectList.getDelegate(IndirectList.java:414) 
at org.eclipse.persistence.indirection.IndirectList$1.<init>(IndirectList.java:542) 
at org.eclipse.persistence.indirection.IndirectList.listIterator(IndirectList.java:541) 
at org.eclipse.persistence.indirection.IndirectList.iterator(IndirectList.java:505) 
at com.business.frontend.facade.impl.FrontEndBFBean.combineAllContainerKpis(FrontEndBFBean.java:515) 
at com.business.frontend.facade.impl.FrontEndBFBean.getKpiValuesFlat(FrontEndBFBean.java:405) 
at sun.reflect.GeneratedMethodAccessor237.invoke(Unknown Source) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
at java.lang.reflect.Method.invoke(Method.java:606) 
at org.glassfish.ejb.security.application.EJBSecurityManager.runMethod(EJBSecurityManager.java:1052) 
at org.glassfish.ejb.security.application.EJBSecurityManager.invoke(EJBSecurityManager.java:1124) 
at com.sun.ejb.containers.BaseContainer.invokeBeanMethod(BaseContainer.java:5409) 
at com.sun.ejb.EjbInvocation.invokeBeanMethod(EjbInvocation.java:619) 
at com.sun.ejb.containers.interceptors.AroundInvokeChainImpl.invokeNext(InterceptorManager.java:800) 
at com.sun.ejb.EjbInvocation.proceed(EjbInvocation.java:571) 
at com.sun.ejb.containers.interceptors.SystemInterceptorProxy.doAround(SystemInterceptorProxy.java:162) 
at com.sun.ejb.containers.interceptors.SystemInterceptorProxy.aroundInvoke(SystemInterceptorProxy.java:144) 
at sun.reflect.GeneratedMethodAccessor170.invoke(Unknown Source) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
at java.lang.reflect.Method.invoke(Method.java:606) 
at com.sun.ejb.containers.interceptors.AroundInvokeInterceptor.intercept(InterceptorManager.java:861) 
at com.sun.ejb.containers.interceptors.AroundInvokeChainImpl.invokeNext(InterceptorManager.java:800) 
at com.sun.ejb.containers.interceptors.InterceptorManager.intercept(InterceptorManager.java:370) 
at com.sun.ejb.containers.BaseContainer.__intercept(BaseContainer.java:5381) 
at com.sun.ejb.containers.BaseContainer.intercept(BaseContainer.java:5369) 
at com.sun.ejb.containers.EJBLocalObjectInvocationHandler.invoke(EJBLocalObjectInvocationHandler.java:214) 
... 75 more 

О дальнейшем осмотре я notised линии:

_ThreadID=165;_ThreadName=http-thread-pool-37860(5); 

и

Exception [EclipseLink-2004] (Eclipse Persistence Services - 2.3.4.v20151027-346465e) 

Моя первоначальная мысль заключалась в том, что HTTP-поток, ожидающий ожидания вызов БД для завершения, а затем поток HTTP прервал EclipseLink, оставив ConcurrencyManager в неожиданном состоянии (с DeferredLock, фактически не выпущенным после использования). Я сделал небольшое приложение, проверив свою гипотезу, изменив настройки сервера и сделав длинные вызовы в БД и завершая http-вызов до того, как вызов БД был готов, но это, похоже, не воспроизводит проблему. Существует также тот факт, что метод, вызываемый при возникновении исключения, не использует какой-либо JPA (ORM), вызов использует JDBC. Большинство приложений использует EclipseLink и JPA, но не эту часть. Также нередко для приложения используется интенсивное использование базы данных.

Так что я думал, что может быть причиной этой ошибки appart из описательного (This normally means that an attempt was made to commit or rollback a transaction before it was started, or to rollback a transaction twice), я уверен, что код не делает такую ​​вещь.

Так что это должен быть ленивый конфликт загрузки, но я не знаю, какие условия могут вызвать эту проблему.

Я не знаю, где исследовать с этого момента. Любые идеи хорошо приветствуются :)

+0

Ошибка возникает из JPA - вы вызываете ленивые отношения на сущности, читаемой в EntityManager. Это приводит к повторному использованию контекста, с которого была прочитана сущность, для извлечения данных и дает вам это исключение. Проверьте FrontEndBFBean, чтобы узнать, как он читается в данных, которые он использует в методе combAllContainerKpis. Возможно, вы захотите использовать соединение извлечения по этому отношению, чтобы оно было охотно загружено. Вы также можете использовать эти данные в многопоточной среде - EM, а получаемые объекты не являются потокобезопасными. – Chris

+0

@Chris Это кажется рациональной проблемой, потому что там есть ленивая загрузка. Не могли бы вы более подробно рассказать о том, как медленная загрузка запускает сигнал «A» перед попыткой ожидания() на ошибке ConcurrencyManager. Я не могу понять, почему некоторые простые чтения (нет записи) запускают такую ​​ошибку. Кроме того, 'FrontEndBFBean' - это просто вездесущий компонент, поэтому контейнер обрабатывает два вызова методов в компоненте одновременно в отдельных экземплярах. Вы можете разместить его в качестве ответа, чтобы я мог отметить его как правильный. – user3719857

+0

@Chris 'Это приводит к повторному использованию контекста, из которого была прочитана сущность, для извлечения данных и дает вам это исключение.' Не могли бы вы прояснить это? Спасибо :) – user3719857

ответ

1

В этом случае ошибка точной причины исключения параллелизма неизвестна - мы можем видеть только один поток, обращающийся к контексту, путем запуска ленивых отношений в сущности. Как этот объект был прочитан и что произошло в других потоках, которые также могут использовать этот EntityManager, который была прочитана сущностью (прямо или косвенно, путем доступа к объектам, читаемым из нее), требует отслеживания, но обычно ее можно избежать.

Администраторы EntityManagers не предназначены для доступа несколькими потоками и поэтому не обрабатывают одновременный доступ. Объекты, считываемые из EntityManager, имеют много перехватов в контексте, из которого они были прочитаны; эти крючки допускают ленивые отношения, отслеживание изменений и т. д., чтобы они были прозрачными для приложения. Это приводит к тому, что эти объекты тоже не могут быть одновременно доступны - они не должны быть кэшированы или переданы приложением без тщательного рассмотрения. Во многих случаях приложениям может быть лучше отказаться от кэширования дескрипторов JPA и получить доступ к объектам по мере необходимости из контекста.

Смежные вопросы