CMoveTask.java 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. package com.zskk.task;
  2. import java.text.SimpleDateFormat;
  3. import java.util.Date;
  4. import java.util.List;
  5. import com.jfinal.plugin.activerecord.Db;
  6. import com.jfinal.plugin.activerecord.Record;
  7. import com.jfinal.plugin.cron4j.ITask;
  8. import com.zskk.service.ServiceFactory;
  9. import com.zskk.service.ThreadPoolService;
  10. import com.zskk.tools.ExecUtil;
  11. public class CMoveTask implements ITask {
  12. @Override
  13. public void run() {
  14. // TODO Auto-generated method stub
  15. List<Record> count = Db.use("local").find("select * from study where status =4");
  16. //同时下载的队列
  17. Integer flag = count.size();
  18. if (flag >= 10) {
  19. return;
  20. }
  21. List<Record> studyidfinds = Db.use("local").find("select * from study where status =1 or status =2 and createAt<? order by createAt asc limit 8",parseStringToDate());
  22. if (studyidfinds == null) {
  23. return;
  24. }
  25. for (Record studyidfind : studyidfinds) {
  26. flag++;
  27. if (flag > 10) {
  28. return;
  29. }
  30. //状态4:下载中
  31. studyidfind.set("status", 4);
  32. Db.use("local").update("study", studyidfind);
  33. ThreadPoolService tService = ServiceFactory.getService(ThreadPoolService.class);
  34. tService.execute(() -> {
  35. String execCmd = ExecUtil.execCmd("/zskk_system/other/cmove.sh " + studyidfind.getStr("studyuid"));
  36. if (execCmd.contains("Connection refused")) {
  37. //状态2:错误
  38. studyidfind.set("status", 2);
  39. Db.use("local").update("study", studyidfind);
  40. }else {
  41. //状态2:完成
  42. studyidfind.set("status", 3);
  43. Db.use("local").update("study", studyidfind);
  44. }
  45. });
  46. }
  47. }
  48. @Override
  49. public void stop() {
  50. // TODO Auto-generated method stub
  51. }
  52. /**
  53. * 日期字符串格式转换
  54. *
  55. * @param dateStr
  56. * @return
  57. */
  58. private String parseStringToDate() {
  59. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  60. Date date = new Date();
  61. long dInteger = date.getTime() - 600000;
  62. String daString = sdf.format(new Date(dInteger));
  63. return daString;
  64. }
  65. }