Urs*_*pke 3 annotations glassfish startup java-ee
我想将Java EE应用程序中长时间运行的进程从同步执行转移到异步执行.该过程应自动启动,然后每小时运行一次.该项目使用Java EE 6在Glassfish 3.1中运行.
经过一番阅读,我相信我可以通过@Singleton和Java在Java EE 6中启动这样的服务@Startup.所以,我创建了一个新类
@Startup
@Singleton
public class MyService {
}
Run Code Online (Sandbox Code Playgroud)
并通过maven运行现有的集成测试.令我惊讶的是,测试失败了,直到最基本的"页面就在那里" - 测试.他们不再找到网页,而是找到错误页面.
试验,我删除@Startup注释,然后再次运行测试.这一次,他们成功了.
手动启动服务器并导航到页面会产生预期结果:页面在那里.更重要的是,在eclipse中,他们通过两个注释成功完成了测试.我能看到的唯一区别是启动服务器的是eclipse,而不是Cargo Maven插件.
这可能会出错?如何@Startup正确使用我需要做什么?
更新:从eclipse切换回IntelliJ IDEA后,我仍然遇到这个问题.但是,我看到了一些例外情况 - 也许你可以用它们做点什么:
[#| 2011-07-25T10:22:51.529 + 0200 |严重| glassfish3.1 | javax.enterprise.system.tools.deployment.org.glassfish.deployment.common | _ThreadID = 65; _ThreadName =线程1; |调用类org.glassfish.ejb.startup.EjbApplication start方法时出现异常
javax.ejb.EJBException异常:javax.ejb.CreateException:初始化在com.sun.ejb.containers.AbstractSingletonContainer.instantiateSingletonInstance失败辛格尔顿MailService的在com.sun.ejb.containers.AbstractSingletonContainer $ SingletonContextFactory.create(AbstractSingletonContainer.java:719) (AbstractSingletonContainer.java:449)在org.glassfish.ejb.startup.SingletonLifeCycleManager.initializeSingleton(SingletonLifeCycleManager.java:216)在org.glassfish.ejb.startup.SingletonLifeCycleManager.initializeSingleton(SingletonLifeCycleManager.java:177)在org.glassfish. ejb.startup.SingletonLifeCycleManager.doStartup(SingletonLifeCycleManager.java:155)在org.glassfish.ejb.startup.EjbApplication.start(EjbApplication.java:177)...
javax.ejb.CreateException:由初始化引起在com.sun.ejb.containers.AbstractSingletonContainer.access $ 100(AbstractSingletonContainer.java失败辛格尔顿MailService的在com.sun.ejb.containers.AbstractSingletonContainer.createSingletonEJB(AbstractSingletonContainer.java:545) :79)at com.sun.ejb.containers.AbstractSingletonContainer $ SingletonContextFactory.create(AbstractSingletonContainer.java:717)... 36更多
在org.jboss.weld.manager.BeanManagerImpl.getBean(BeanManagerImpl.java:1209)在org.jboss.weld在java.util.concurrent.ConcurrentHashMap.get(ConcurrentHashMap.java:768)显示java.lang.NullPointerException:由造成.manager.BeanManagerImpl.getBean(BeanManagerImpl.java:144)在org.glassfish.weld.services.JCDIServiceImpl._createJCDIInjectionContext(JCDIServiceImpl.java:144)
毕竟问题不在于注释,而是错位的beans.xml.META-INF根据需要把它放进去帮助我超越这个.
切换到IntelliJ IDEA有助于解决问题:在其中,日志文件包含非常明显的错误,用于创建bean @Singleton以及a @ApplicationScoped.
另一件事证明非常有用的是在JBoss中尝试完全相同的应用程序.在这里,它有效,所以我有信心我没有误解基本概念.
| 归档时间: |
|
| 查看次数: |
14958 次 |
| 最近记录: |