菜園子

          BlogJava 首頁 新隨筆 聯系 聚合 管理
            7 Posts :: 1 Stories :: 31 Comments :: 0 Trackbacks

          在我們開發的一個系統中,有定時任務,自然就想到了Quartz,由于框架采用的Spring,Quartz跟Spring的集成也非常簡單,所以就把Quartz配置到框架中,當系統啟動后,定時任務也就自動啟動。在開發的過程中一直沒有發現問題,但是最后上線的時候,采用的是weblogic cluster,啟動了4個節點,發現有的定時任務執行了不止一次,才恍然大悟,4個節點啟動了4個應用,也就啟動了4個定時任務,所以在同一個時間定時任務執行了不止一次。去網上搜索,發現Quartz也支持cluster,但是我覺得就我們的系統而言,沒有必要采用cluster的定時任務,也許是比較懶吧,就想讓定時任務只執行一次。在網上搜到了robbin的一篇文章(http://robbin.iteye.com/blog/40989 ),發現把quartz集中到webapp當中還是有一定的風險,同時同一個時間點執行也不止一次。Robbin的解決辦法就是自己單獨啟動一個Job Server,來quartz跑job,不要部署在web容器中。 

          我也比較同意這個辦法。鑒于時間比較緊,就想有沒有比較方便的方法。其實把原來的webapp當做一個quartz的容器就可以了。可以自己寫一個線程來跑應用,再寫一個command啟動這個線程就可以了。線程類很簡單,如下:

          public class StartServer {

              public static void main(String[] args) throws Exception {

                  ClassPathXmlApplicationContext ctx = new ClassPathXmlApplicationContext(
          new String[] { "/spring/context-annotation.xml","/spring/context-transaction.xml",
          "/spring/context-hibernate.xml",
          "/spring/context-quartz.xml"});

                  System.out.println("start server....");

                  while (true) {

                      try {

                          Thread.sleep(900);

                      } catch (InterruptedException ex) {

                      }

                  }

              };

          }

          去掉了系統的controller配置servlet.xml,運行這個類就可以了。

          在web-inf目錄下寫一個command來啟動這個java類:

          setlocal ENABLEDELAYEDEXPANSION

          if defined CLASSPATH (set CLASSPATH=%CLASSPATH%;.) else (set CLASSPATH=.)

          FOR /R .\lib %%G IN (*.jar) DO set CLASSPATH=!CLASSPATH!;%%G

          Echo The Classpath definition is==== %CLASSPATH%

          set CLASSPATH=./classes;%CLASSPATH%

          java com.company.job.StartServer

          這個command需要把需要的jar(web-inf/lib中)包都放到classpath中。

          每次啟動的時候執行這個command就可以了。跟原來的應用分開了,調試起定時任務也不用影響到原來的應用,還是比較方便的。部署的時候原樣拷貝一份,然后執行這個command就好了,部署起來也比較方便。

           



          QQ:24889356
          posted on 2011-09-13 12:53 GhostZhang 閱讀(2667) 評論(3)  編輯  收藏

          Feedback

          # re: 一次定時任務 2011-09-14 08:55 tb
          恩 不錯   回復  更多評論
            

          # re: 一次定時任務 2011-09-15 18:19 Mister4
          可以根據服務器的iP做個判斷  回復  更多評論
            

          # re: 一次定時任務[未登錄] 2011-09-30 15:57 BucketLi
          這個簡單處理方式有很多. 數據庫搞張任務表,放一條記錄,每個節點先取這條記錄(任務狀態是可執行),然后再通過update將value+1并且更新狀態,帶上先前查詢出來的value作為查詢條件,這樣相當于加了一把樂觀鎖,因為數據庫底層是原子的,所以只有一臺機器會更新成功. 這樣就達到目的了. 還有稍微復雜點的是通過zk來維持一把任務鎖,這樣執行任務的只有一臺機器,掛掉后另外一臺機器搶到鎖開始做事情. 當然還有其他方法  回復  更多評論
            


          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 泽州县| 江安县| 深州市| 利津县| 远安县| 湘阴县| 策勒县| 乐昌市| 万山特区| 绥化市| 天全县| 额尔古纳市| 建德市| 神农架林区| 平泉县| 凤城市| 左权县| 太仆寺旗| 咸宁市| 贵阳市| 商水县| 石城县| 大同市| 察雅县| 雷州市| 淮安市| 西宁市| 广水市| 南宫市| 韶山市| 门头沟区| 湖南省| 吴桥县| 通榆县| 屏南县| 华坪县| 碌曲县| 朝阳区| 枣强县| 桦川县| 古田县|