Проблема обновления базы данных JPA Glassfish - PullRequest
12 голосов
/ 27 августа 2010

У меня установлено приложение на Glassfish v3.0.1, которое считывает события из таблицы в моей базе данных. Когда он будет готов, он помечает их как обработанные. Я получаю странную ошибку, которую не могу объяснить при попытке вызвать метод, который выполняет обновление.

@Override
@TransactionAttribute(TransactionAttributeType.REQUIRES_NEW)
public void markEventAsProcessed(Long eventId) {
    try {
       AtlasEventQueueUpdateAsProcessedQuery setEventAsProcessed = new  AtlasEventQueueUpdateAsProcessedQuery(entityManager, eventId);
       int updateCount = setEventAsProcessed.execute();
       logger.debug("Mark Event [" + eventId + "] processed");
       return updateCount;
    } catch (QueryException ex) {
        logger.error("Event [" + eventId + "has not been marked as processed", ex);
    }
}

Когда это вызывается в моем приложении, я получаю следующее исключение (Полная трассировка внизу поста):

Caused by: javax.ejb.AccessLocalException: Client not authorized for this invocation.

Кто-нибудь знает, что может вызвать эту ошибку, которую я обнаружил в Интернете, но не нашел ничего полезного.

2010-08-27 09:44:37,380 ERROR [Ejb-Timer-Thread-1  :EventProvider       ] Unhandled exception in event processing - javax.ejb.EJBAccessException
javax.ejb.EJBAccessException
        at com.sun.ejb.containers.BaseContainer.mapLocal3xException(BaseContainer.java:2262)
        at com.sun.ejb.containers.BaseContainer.postInvoke(BaseContainer.java:2053)
        at com.sun.ejb.containers.BaseContainer.postInvoke(BaseContainer.java:1955)
        at com.sun.ejb.containers.EJBLocalObjectInvocationHandler.invoke(EJBLocalObjectInvocationHandler.java:198)
        at com.sun.ejb.containers.EJBLocalObjectInvocationHandlerDelegate.invoke(EJBLocalObjectInvocationHandlerDelegate.java:84)
        at $Proxy190.markEventAsProcessed(Unknown Source)
        at com.company.atlas.eventprocessor.provider.EventProvider.processNewEvents(EventProvider.java:170)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
        at java.lang.reflect.Method.invoke(Method.java:597)
        at org.glassfish.ejb.security.application.EJBSecurityManager.runMethod(EJBSecurityManager.java:1056)
        at org.glassfish.ejb.security.application.EJBSecurityManager.invoke(EJBSecurityManager.java:1128)
        at com.sun.ejb.containers.BaseContainer.invokeBeanMethod(BaseContainer.java:5292)
        at com.sun.ejb.EjbInvocation.invokeBeanMethod(EjbInvocation.java:615)
        at com.sun.ejb.containers.interceptors.AroundInvokeChainImpl.invokeNext(InterceptorManager.java:797)
        at com.sun.ejb.EjbInvocation.proceed(EjbInvocation.java:567)
        at com.sun.ejb.containers.interceptors.SystemInterceptorProxy.doAround(SystemInterceptorProxy.java:157)
        at com.sun.ejb.containers.interceptors.SystemInterceptorProxy.aroundTimeout(SystemInterceptorProxy.java:144)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
        at java.lang.reflect.Method.invoke(Method.java:597)
        at com.sun.ejb.containers.interceptors.AroundInvokeInterceptor.intercept(InterceptorManager.java:858)
        at com.sun.ejb.containers.interceptors.AroundInvokeChainImpl.invokeNext(InterceptorManager.java:797)
        at com.sun.ejb.containers.interceptors.InterceptorManager.intercept(InterceptorManager.java:367)
        at com.sun.ejb.containers.BaseContainer.__intercept(BaseContainer.java:5264)
        at com.sun.ejb.containers.BaseContainer.intercept(BaseContainer.java:5252)
        at com.sun.ejb.containers.BaseContainer.callEJBTimeout(BaseContainer.java:3965)
        at com.sun.ejb.containers.EJBTimerService.deliverTimeout(EJBTimerService.java:1667)
        at com.sun.ejb.containers.EJBTimerService.access$100(EJBTimerService.java:98)
        at com.sun.ejb.containers.EJBTimerService$TaskExpiredWork.run(EJBTimerService.java:2485)
        at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:441)
        at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)
        at java.util.concurrent.FutureTask.run(FutureTask.java:138)
        at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
        at java.lang.Thread.run(Thread.java:619)
Caused by: javax.ejb.AccessLocalException: Client not authorized for this invocation.
        at com.sun.ejb.containers.BaseContainer.preInvoke(BaseContainer.java:1850)
        at com.sun.ejb.containers.EJBLocalObjectInvocationHandler.invoke(EJBLocalObjectInvocationHandler.java:188)
        ... 34 more

Ответы [ 6 ]

29 голосов
/ 28 августа 2010

Я удалил каталог domains/domainx/generated/policy/<appname>/ и полностью повторно развернул (а не только перезапустил) приложение .. теперь оно работает как положено.

В документации GlassFish есть запись для этогоошибка:

javax.ejb.AccessLocalException: Ошибка клиента не авторизована

Описание

Информация о сопоставлении ролей доступна в XML для конкретного Sun (дляНапример, sun-ejb-jar.xml), и аутентификация в порядке, но отображается следующее сообщение об ошибке:

[...INFO|sun-appserver-pe8.0|javax.enterprise.system.container.ejb|...|
javax.ejb.AccessLocalException: Client not authorized for this invocation.
at com.sun.ejb.containers.BaseContainer.preInvoke(BaseContainer.java:...
at com.sun.ejb.containers.EJBObjectInvocationHandler.invoke(...)

Решение

Проверьте, является ли модуль EJB (.jar) или веб-модулем (.war) упакован в приложение (.ear) и не имеет информации о сопоставлении ролей на уровне приложения, специфично для Sun, sun-application.xml.Для любого приложения (.ear) информация о сопоставлении ролей безопасности должна быть указана в sun-application.xml.Допустимо иметь как XML уровня модуля, так и XML уровня приложения.

Я не знаю, имеет ли это смысл в вашем контексте.

Если нет,возможно взгляните на следующий поток Постоянная сущность: javax.ejb.AccessLocalException: Клиент не авторизован для этого вызова .Один из авторов предложил установить для уровня ведения журнала SECURITY Logger значение FINE [так, чтобы] подсистема Glassfish Policy записывала подробное сообщение, описывающее характер неудачной проверки разрешений .Это может помочь.И я не могу сказать вам, сталкивались ли вы с той же проблемой, но ОП решил свою проблему, очистив сгенерированные файлы политики:

5 голосов
/ 01 декабря 2011

Это исключение также может возникнуть, если вы попытаетесь скопировать и вставить EJB-сеансные компоненты с помощью новых методов, в качестве файлов исправлений для исправления ошибок или включения новых функций. Перезапуск сервера или отключение и включение корпоративного приложения не поможет, так как компоненты или сущности EJB-сеансов должны быть переупакованы и повторно развернуты, чтобы сервер приложений регистрировал новые методы, проверял и предоставлял / исключал права доступа к новому / измененные методы в сессионных компонентах EJB.

0 голосов
/ 05 мая 2016

У меня была такая же ошибка, но моя была вызвана этим:

<c:set var="speciesList" value="#{timberSaleController.distinctSaleSpecies}"   />

функция:

public List<Species> getDistinctSaleSpecies()
    {
        return ejbFacade.getDistinctSpeciesForAllSales();
    }

когда я изменил установленный тег на этот, он работал:

<c:set var="speciesList" value="#{timberSaleController.getDistinctSaleSpecies()}"   />
0 голосов
/ 21 ноября 2014

По крайней мере на Glassfish 3.1.2, иногда предыдущая итерация бина, который изменился, задушит Glassfish при развертывании.Приложение будет работать до тех пор, пока не получит какой-либо фрагмент кода, который должен быть вызван, но не может быть, потому что ранее развернутый класс все еще там.Я думаю, что Glassfish мог бы отслеживать каждый из них и препятствовать тому, чтобы новый код вызывал старый код, но я не особо волновался об этом, поскольку решение достаточно простое:

Остановите сервер, идив каталог домена и удалите все файлы и подкаталоги в каталоге приложения.Затем сделайте то же самое в сгенерированных каталогах и каталогах osgi-cache.Перезагрузите сервер и перестройте / повторно разверните.

0 голосов
/ 14 мая 2014

У меня была такая же проблема. Я не использую какой-либо контроль доступа в службе, но на одном экземпляре Glassfish все работало нормально, на другом я получил эту ошибку, но только на некоторых методах. Я добавил @PermitAll и снова развернул сервис, и все стало работать.

0 голосов
/ 21 декабря 2012

У меня была такая же проблема, когда я вставлял SessionBean без состояния (TransactionAttribute.REQUIRES_NEW) в другой SessionBean без состояния. Для меня перезапуск сервера решил это для меня ...

Просто хотел, чтобы ты знал; -)

...