JavaWeb 服务启动时,在后台启动加载一个线程
2016-05-25 10:23
891 查看
JavaWeb 服务启动时,在后台启动加载一个线程。
目前,我所掌握的一共有两种方法,第一种是监听(Listener),第二种是配置随项目启动而启动的Servlet。
下面对这两种方法做一简单的介绍,(Mark一下,防止以后急用又忘记了):
监听(Listener)
首先,我们创建一个监听的类,继承ServletContextListener,如下:
[java] view
plain copy
package com.wxp.thread;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
/**
* Listener的方式在后台执行一线程
*
* @author Champion.Wong
*
*/
public class MyListener implements ServletContextListener {
private MyThread myThread;
public void contextDestroyed(ServletContextEvent e) {
if (myThread != null && myThread.isInterrupted()) {
myThread.interrupt();
}
}
public void contextInitialized(ServletContextEvent e) {
String str = null;
if (str == null && myThread == null) {
myThread = new MyThread();
myThread.start(); // servlet 上下文初始化时启动 socket
}
}
}
/**
* 自定义一个 Class 线程类继承自线程类,重写 run() 方法,用于从后台获取并处理数据
*
* @author Champion.Wong
*
*/
class MyThread extends Thread {
public void run() {
while (!this.isInterrupted()) {// 线程未中断执行循环
try {
Thread.sleep(2000); //每隔2000ms执行一次
} catch (InterruptedException e) {
e.printStackTrace();
}
// ------------------ 开始执行 ---------------------------
System.out.println("____FUCK TIME:" + System.currentTimeMillis());
}
}
}
然后,在web.xml中配置如下:
[html] view
plain copy
<listener>
<listener-class>com.wxp.thread.MyListener</listener-class>
</listener>
OK,启动项目,我们可以在控制台看到隔时间段输出的文字内容。
![](http://hi.csdn.net/attachment/201112/31/0_1325309429JEn7.gif)
使用Servlet,在项目启动的时候启动它。
首先,创建一个Servlet,继承HttpServlet
[java] view
plain copy
package com.wxp.thread;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.ite.common.Constants;
public class MyServlet extends HttpServlet{
private static final long serialVersionUID = 1L;
private MyThread1 myThread1;
public MyServlet(){
}
public void init(){
String str = null;
if (str == null && myThread1 == null) {
myThread1 = new MyThread1();
myThread1.start(); // servlet 上下文初始化时启动 socket
}
}
public void doGet(HttpServletRequest httpservletrequest, HttpServletResponse httpservletresponse)
throws ServletException, IOException{
}
public void destory(){
if (myThread1 != null && myThread1.isInterrupted()) {
myThread1.interrupt();
}
}
}
/**
* 自定义一个 Class 线程类继承自线程类,重写 run() 方法,用于从后台获取并处理数据
*
* @author Champion.Wong
*
*/
class MyThread1 extends Thread {
public void run() {
while (!this.isInterrupted()) {// 线程未中断执行循环
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
// ------------------ 开始执行 ---------------------------
System.out.println("____FUCK TIME:" + System.currentTimeMillis());
}
}
}
然后,在web.xml中配置
[html] view
plain copy
<!-- LISTENER FOR THREAD -->
<servlet>
<servlet-name>MyListener</servlet-name>
<servlet-class>com.ite.wxp.MyServlet</servlet-class>
<load-on-startup>9</load-on-startup><!-- 数字越小,启动的优先级越高,必须大于0 -->
</servlet>
<servlet-mapping>
<servlet-name>MyListener</servlet-name>
<url-pattern>/test</url-pattern>
</servlet-mapping>
OK。启动项目,依然可以看到如图所示:
![](http://hi.csdn.net/attachment/201112/31/0_132530966144xs.gif)
其中,Listener的方式,该线程肯定是项目中首先启动的,优先于任何一个Servlet。而Servlet的方式,可以设置与其它Servlet启动的顺序。如果有时候需要首先启动一个Servlet或者它们之间的启动顺序有特殊要求的时候,这个就很有作用了。
目前,我所掌握的一共有两种方法,第一种是监听(Listener),第二种是配置随项目启动而启动的Servlet。
下面对这两种方法做一简单的介绍,(Mark一下,防止以后急用又忘记了):
监听(Listener)
首先,我们创建一个监听的类,继承ServletContextListener,如下:
[java] view
plain copy
package com.wxp.thread;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
/**
* Listener的方式在后台执行一线程
*
* @author Champion.Wong
*
*/
public class MyListener implements ServletContextListener {
private MyThread myThread;
public void contextDestroyed(ServletContextEvent e) {
if (myThread != null && myThread.isInterrupted()) {
myThread.interrupt();
}
}
public void contextInitialized(ServletContextEvent e) {
String str = null;
if (str == null && myThread == null) {
myThread = new MyThread();
myThread.start(); // servlet 上下文初始化时启动 socket
}
}
}
/**
* 自定义一个 Class 线程类继承自线程类,重写 run() 方法,用于从后台获取并处理数据
*
* @author Champion.Wong
*
*/
class MyThread extends Thread {
public void run() {
while (!this.isInterrupted()) {// 线程未中断执行循环
try {
Thread.sleep(2000); //每隔2000ms执行一次
} catch (InterruptedException e) {
e.printStackTrace();
}
// ------------------ 开始执行 ---------------------------
System.out.println("____FUCK TIME:" + System.currentTimeMillis());
}
}
}
然后,在web.xml中配置如下:
[html] view
plain copy
<listener>
<listener-class>com.wxp.thread.MyListener</listener-class>
</listener>
OK,启动项目,我们可以在控制台看到隔时间段输出的文字内容。
![](http://hi.csdn.net/attachment/201112/31/0_1325309429JEn7.gif)
使用Servlet,在项目启动的时候启动它。
首先,创建一个Servlet,继承HttpServlet
[java] view
plain copy
package com.wxp.thread;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.ite.common.Constants;
public class MyServlet extends HttpServlet{
private static final long serialVersionUID = 1L;
private MyThread1 myThread1;
public MyServlet(){
}
public void init(){
String str = null;
if (str == null && myThread1 == null) {
myThread1 = new MyThread1();
myThread1.start(); // servlet 上下文初始化时启动 socket
}
}
public void doGet(HttpServletRequest httpservletrequest, HttpServletResponse httpservletresponse)
throws ServletException, IOException{
}
public void destory(){
if (myThread1 != null && myThread1.isInterrupted()) {
myThread1.interrupt();
}
}
}
/**
* 自定义一个 Class 线程类继承自线程类,重写 run() 方法,用于从后台获取并处理数据
*
* @author Champion.Wong
*
*/
class MyThread1 extends Thread {
public void run() {
while (!this.isInterrupted()) {// 线程未中断执行循环
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
// ------------------ 开始执行 ---------------------------
System.out.println("____FUCK TIME:" + System.currentTimeMillis());
}
}
}
然后,在web.xml中配置
[html] view
plain copy
<!-- LISTENER FOR THREAD -->
<servlet>
<servlet-name>MyListener</servlet-name>
<servlet-class>com.ite.wxp.MyServlet</servlet-class>
<load-on-startup>9</load-on-startup><!-- 数字越小,启动的优先级越高,必须大于0 -->
</servlet>
<servlet-mapping>
<servlet-name>MyListener</servlet-name>
<url-pattern>/test</url-pattern>
</servlet-mapping>
OK。启动项目,依然可以看到如图所示:
![](http://hi.csdn.net/attachment/201112/31/0_132530966144xs.gif)
其中,Listener的方式,该线程肯定是项目中首先启动的,优先于任何一个Servlet。而Servlet的方式,可以设置与其它Servlet启动的顺序。如果有时候需要首先启动一个Servlet或者它们之间的启动顺序有特殊要求的时候,这个就很有作用了。
相关文章推荐
- spring MVC配置详解
- java多线程
- 在JAVA中生成RSA秘钥对实现SSH互信
- 使用Java抽取RTF思想
- JAVA学习之——fail-fast机制
- hash算法 (hashmap 实现原理) Java实现的散列表
- Spring 定时任务之 @Scheduled cron表达式
- java枚举创建,定义注意事项
- JAVA框架
- Java集合框架
- 安卓获取USB存储卡的外挂路径
- java 将 ResultSet 转化为 json格式
- Java字节码操作开源框架
- Spring中的@Transactional深度分析
- java 中webservice的作用完全详解!(转)
- eclipse插件
- JAVA 中常用的几个集合类
- 重新学习JAVA的笔记
- 2016 年排名 Top 100 的 Java 类库
- springMVC学习之接受JSON参数