Java EE应用程序中的线程

时间:2009-10-11 08:13:48

标签: java tomcat java-ee multithreading daemon

我有一个Java EE应用程序,它有两个组件:第一个是从Internet上抓取一些信息并将其填入数据库的服务。其次是用户可以浏览该信息的Web界面(部署在tomcat上)。

实施第一个组件的最佳方法是什么?它应该作为后台守护程序/服务或容器中的线程运行吗?

3 个答案:

答案 0 :(得分:8)

我个人将他们分成不同的过程。除了其他任何东西,它意味着你可以重新启动一个而不用担心另一个。这也意味着您可以轻松地将它们部署在不同的计算机上,而无需为实际不需要Web界面的服务安装Tomcat。

答案 1 :(得分:7)

根据应用程序框架的类型,Spring允许您使用Quartzjava.util.concurrent框架。 Spring有一个TaskExecutor抽象(参见Spring documentation),它简化了很多这个,但要检查哪个最适合你的设计。

然后,Spring或Quartz(由Spring管理)控制线程或执行器或作业的创建和启动/停止,以及它们的频率/周期和其他调度参数,并且还管理您可能需要的任何作业池。

我将这些用于我编写的任何Java EE应用程序中的所有后台任务和批处理作业,没有任何问题。由于作业是Spring管理的POJO,因此它们可以访问Spring所需的完整依赖注入框架等,当然,您可以根据需求的变化或扩展,通过对应用程序配置XML文件的简单更改来切换调度程序框架。

答案 2 :(得分:2)

在Web容器中使用后台作业没有任何问题,但您必须让Web容器知道它,以便可以停止并正确启动它。

查看web.xml中的load-on-startup标记。关于http://wiki.metawerx.net/wiki/Web.xml.LoadOnStartup

有一些建议