CrawlerThread.java 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. package com.yihu.ehr.service.thread;
  2. import com.yihu.ehr.common.config.ThreadConfig;
  3. import com.yihu.ehr.dbhelper.jdbc.DBConfig;
  4. import com.yihu.ehr.dbhelper.jdbc.DBHelper;
  5. import com.yihu.ehr.service.crawler.CrawlerManager;
  6. import com.yihu.ehr.service.standard.StandardManager;
  7. import com.yihu.ehr.util.log.LogUtil;
  8. public class CrawlerThread implements Runnable {
  9. DBHelper db = new DBHelper(Thread.currentThread().getName(), DBConfig.get("defaultUri"));
  10. @Override
  11. public void run() {
  12. while (ThreadManage.crawlerIsRunning) {
  13. try {
  14. LogUtil.info("采集线程开始");
  15. CrawlerManager.getInstance().dataCrawlerFrequency();
  16. LogUtil.info("采集线程结束");
  17. sleep();
  18. } catch (InterruptedException e) {
  19. LogUtil.error("休眠中断!");
  20. LogUtil.error(e);
  21. continue;
  22. } catch (Exception e) {
  23. LogUtil.error("采集线程失败,将重新启动线程!");
  24. LogUtil.error(e);
  25. try {
  26. sleep();
  27. } catch (Exception e1) {
  28. continue;
  29. }
  30. continue;
  31. }
  32. }
  33. }
  34. private void sleep() throws Exception {
  35. if (ThreadConfig.CRAWLER_THREAD_SLEEP_TIME == 0) {
  36. Object obj = db.scalar("select param_value from system_param where param_key='INTERVAL'");
  37. if(obj!=null) {
  38. ThreadConfig.CRAWLER_THREAD_SLEEP_TIME = Integer.parseInt(obj.toString());
  39. }
  40. }
  41. LogUtil.info("开始睡眠,睡眠时间:" + 1000 * ThreadConfig.CRAWLER_THREAD_SLEEP_TIME);
  42. Thread.sleep(1000 * ThreadConfig.CRAWLER_THREAD_SLEEP_TIME);
  43. }
  44. }