實現tomcat啟動時自動執行程式碼
方法1:tomcat 自動執行servlet
寫一個servlet,在init()方法中寫好想要執行的程式,程式如下:
eclipse新建一個web\Dynamic Web Project , name = myweb1 , 把tomcat中的 servlet-api.jar複製到lib中,新建一個類MyServlet.Java, 繼承 javax.servlet.HttpServlet,程式碼如下:
- package org.cai;
- import javax.servlet.ServletException;
- import javax.servlet.http.HttpServlet;
- publicclass MyServlet extends HttpServlet {
- @Override
- publicvoid init() throws ServletException {
- // TODO Auto-generated method stub
- super.init();
- System.out.println("自動載入啟動.");
- System.out.println("自動載入啟動.");
- for(int i = 0; i < 10; i++){
- System.out.println(i + "、 自動載入啟動."
- }
- }
- }
同時,在web.xml配置檔案內容如下:
- <?xmlversion="1.0"encoding="UTF-8"?>
- <web-appxmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns="http://java.sun.com/xml/ns/javaee"xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
- <display-name>myweb1</display-name>
- <welcome-file-list>
- <welcome-file>index.jsp</welcome-file>
- </welcome-file-list>
- <servlet>
- <servlet-name>MyServlet</servlet-name>
- <servlet-class>org.cai.MyServlet</servlet-class>
- <strong><load-on-startup>0</load-on-startup></strong>
- </servlet>
- <servlet-mapping>
- <servlet-name>MyServlet</servlet-name>
- <url-pattern>/</url-pattern>
- </servlet-mapping>
- </web-app>
其中<load-on-startup>0</load-on-startup>即可實現tomcat啟動時執行該servlet
load-on-startup的值必須為整數
當load-on-startup值為負整數或者未指定時,容器在該servlet被呼叫時載入
當其值為0和正整數時,容器啟動時載入,值越小,優先順序越高
使用虛擬路徑部署到tomcat中:在 tomcat的 server.xml的 </Host>前加入:
<Context debug="0" docBase="F:/studyworkspace/myweb1/WebRoot" path="myweb1" reloadable="true">
</Context>
docBase為 myweb1的webroot的路徑 ,path為上下文方法2:Servlet偵聽器
要運用Servlet偵聽器需要實現javax.servlet.ServletContextListener介面,同時實現它的contextInitialized(ServletContextEvent event)和contextDestroyed(ServletContextEvent event)兩個介面函式。
listener類如下:
- package org.cai;
- import javax.servlet.ServletContextEvent;
- import javax.servlet.ServletContextListener;
- publicclass MyListener implements ServletContextListener {
- private java.util.Timer timer = null ;
- publicvoid contextDestroyed(ServletContextEvent event) {
- // TODO Auto-generated method stub
- }
- publicvoid contextInitialized(ServletContextEvent event) {
- timer = new java.util.Timer(true) ;
- event.getServletContext().log("定時器已啟動。") ;
- timer.schedule(new MyTask(event.getServletContext()), 0, 5000) ;
- event.getServletContext().log("已經新增任務排程表。" ) ;
- }
- }
contextInitialized函式裡的內容將被自動執行
最後在web.xml裡面新增一個監聽節點就行了
<listener>
<listener-class>org.cai.MyListener</listener-class>
</listener>
完整web.xml如下
- <?xmlversion="1.0"encoding="UTF-8"?>
- <web-appxmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns="http://java.sun.com/xml/ns/javaee"xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"id="WebApp_ID"version="2.5">
- <display-name>myweb2</display-name>
- <welcome-file-list>
- <welcome-file>index.jsp</welcome-file>
- </welcome-file-list>
- <listener>
- <listener-class>org.cai.MyListener</listener-class>
- </listener>
- </web-app>
如果要執行定時任務,就在自動執行的程式碼裡面使用 java.util.Timer以及建立一個繼承java.util.TimerTask的類。示例:
- package org.cai;
- import java.util.TimerTask;
- import javax.servlet.ServletContext;
- public class MyTask extends TimerTask {
- private static boolean isRunning = false;
- private ServletContext context = null;
- public MyTask(ServletContext context){
- this.context = context ;
- }
- @Override
- public void run() {
- if (! isRunning){
- System.out.println("開始執行指定任務.") ;
- //if (C_SCHEDULE_HOUR == c.get(Calendar.HOUR_OF_DAY)) {
- isRunning = true ;
- context.log("開始執行指定任務.") ;
- //TODO 新增自定義的詳細任務,以下只是示例
- int i = 0;
- while (i++ <10) {
- context.log("已完成任務的" + i + "/" + 10);
- //System.out.println("已完成任務的" + i + "/" + 1000) ;
- }
- isRunning = false;
- context.log("指定任務執行結束");
- System.out.println("指定任務執行結束") ;
- //}
- }else{
- context.log("上一次任務執行還未結束");
- }
- }
- }
以上兩種方法部署到tomcat,執行tomcat\bin\startup.bat,即可看到效果,其中方法2中的日誌寫入到tomcat\logs\localhost.xxxx-xx-xx.log檔案中。