PantentQueueService.java 37 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851
  1. package cn.cslg.pas.service.upLoadPatent;
  2. import cn.cslg.pas.common.model.vo.ProjectImportPatentVO;
  3. import cn.cslg.pas.common.model.vo.UploadParamsVO;
  4. import cn.cslg.pas.common.utils.DateUtils;
  5. import cn.cslg.pas.common.utils.JsonUtils;
  6. import cn.cslg.pas.common.utils.StringUtils;
  7. import cn.cslg.pas.domain.PQueueData;
  8. import cn.cslg.pas.domain.QuestionRecord;
  9. import cn.cslg.pas.domain.QueueData;
  10. import cn.cslg.pas.domain.Task;
  11. import cn.cslg.pas.domain.asso.TaskCondition;
  12. import cn.cslg.pas.mapper.QuestionRecordMapper;
  13. import cn.cslg.pas.service.OutInterfaceService;
  14. import cn.cslg.pas.service.PatentInstructionService;
  15. import cn.cslg.pas.service.TaskService;
  16. import cn.cslg.pas.service.UploadPatentBatchService;
  17. import cn.cslg.pas.service.asso.TaskConditionService;
  18. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  19. import lombok.RequiredArgsConstructor;
  20. import lombok.extern.slf4j.Slf4j;
  21. import org.springframework.context.annotation.Lazy;
  22. import org.springframework.stereotype.Service;
  23. import java.util.*;
  24. import java.util.concurrent.locks.Condition;
  25. import java.util.concurrent.locks.Lock;
  26. import java.util.concurrent.locks.ReentrantLock;
  27. /**
  28. * 1.生产者线程生产专利(根据任务类型调用对应工厂方法执行获取专利数据)
  29. * 2.装载者线程装载专利(将专利数据装载到专利实体类)
  30. * 3.消费者线程消费专利(将专利入库)
  31. */
  32. @Slf4j
  33. @Service
  34. @RequiredArgsConstructor(onConstructor_ = {@Lazy})
  35. public class PantentQueueService {
  36. private final UploadPatentToDBService uploadPatentToDBService;
  37. private final UploadPatentBatchService uploadPatentBatchService;
  38. private final MessageService messageService;
  39. private final TaskService taskService;
  40. private final TaskConditionService taskConditionService;
  41. private final ExcutePatentDataExcel excutePatentDataExcel;
  42. private final ExcutePatentDataEpo excutePatentDataEpo;
  43. private final ExcutePatentDataStar excutePatentDataStar;
  44. private final PatentInstructionService patentInstructionService;
  45. private final OutInterfaceService outInterfaceService;
  46. private final QuestionRecordService questionRecordService;
  47. private final QuestionRecordMapper questionRecordMapper;
  48. private final List<Integer> taskQueueList = new ArrayList<>();
  49. private final List<PQueueData> setPatentImageQueueList = new ArrayList<>();
  50. private final List<PQueueData> setPatentZhuluQueueList = new ArrayList<>();
  51. private final List<PQueueData> setPatentRightQueueList = new ArrayList<>();
  52. private final List<PQueueData> setPatentInstructionTextQueueList = new ArrayList<>();
  53. private final List<PQueueData> setPatentInstructionPDFQueueList = new ArrayList<>();
  54. private final List<QueueData> patentImageQueueList = new ArrayList<>();
  55. private final List<QueueData> patentZhuluQueueList = new ArrayList<>();
  56. private final List<QueueData> patentRightQueueList = new ArrayList<>();
  57. private final List<QueueData> patentInstructionTextQueueList = new ArrayList<>();
  58. private final List<QueueData> patentInstructionPDFQueueList = new ArrayList<>();
  59. private final Lock taskLock = new ReentrantLock();
  60. private final Lock setPatentImageLock = new ReentrantLock();
  61. private final Lock setPatentZhuluLock = new ReentrantLock();
  62. private final Lock setPatentRightLock = new ReentrantLock();
  63. private final Lock setPatentInstructionTextLock = new ReentrantLock();
  64. private final Lock setPatentInstructionPDFLock = new ReentrantLock();
  65. private final Lock patentImageLock = new ReentrantLock();
  66. private final Lock patentZhuluLock = new ReentrantLock();
  67. private final Lock patentRightLock = new ReentrantLock();
  68. private final Lock patentInstructionTextLock = new ReentrantLock();
  69. private final Lock patentInstructionPDFLock = new ReentrantLock();
  70. private final Condition taskCondition = taskLock.newCondition();
  71. private final Condition setPatentImageCondition = setPatentImageLock.newCondition();
  72. private final Condition setPatentZhuluCondition = setPatentZhuluLock.newCondition();
  73. private final Condition setPatentRightCondition = setPatentRightLock.newCondition();
  74. private final Condition setPatentInstructionTextCondition = setPatentInstructionTextLock.newCondition();
  75. private final Condition setPatentInstructionPDFCondition = setPatentInstructionPDFLock.newCondition();
  76. private final Condition patentImageCondition = patentImageLock.newCondition();
  77. private final Condition patentZhuluCondition = patentZhuluLock.newCondition();
  78. private final Condition patentRightCondition = patentRightLock.newCondition();
  79. private final Condition patentInstructionTextCondition = patentInstructionTextLock.newCondition();
  80. private final Condition patentInstructionPDFCondition = patentInstructionPDFLock.newCondition();
  81. private final HashMap<String, Integer> patentIdMap = new HashMap<>();
  82. /**
  83. * 生产者:从任务队列取出任务,再调用工厂方法根据任务类型返回对应的生产专利方法的对象将专利分配给消费者
  84. */
  85. public void addPatnetToQueue() {
  86. while (true) {
  87. Task task = new Task();
  88. try {
  89. //判断任务队列是否有任务,若没有则线程等待唤醒
  90. if (taskQueueList.size() == 0) {
  91. taskLock.lock();
  92. taskCondition.await();
  93. }
  94. //线程被唤醒后 ↓
  95. if (taskQueueList.size() > 0) {
  96. //从任务队列中取出第一个task任务,同时将其从任务队列中剔除
  97. task = taskService.getById(taskQueueList.remove(0));
  98. //判断任务状态,若不存在或已完成或已暂停或已取消,则跳过继续取下一个任务
  99. if (task == null || task.getStatus().equals(2) || task.getStatus().equals(4) || task.getStatus().equals(5)) {
  100. continue;
  101. }
  102. //若是网站导入任务,则将网站导入相关信息存入task对象中(方便生产与消费时使用)
  103. if (task.getType().equals(3) || task.getType().equals(4)) {
  104. TaskCondition taskCondition = taskConditionService.getById(task.getTaskConditionId());
  105. List<String> configCells = Arrays.asList(taskCondition.getConfigCells().split(","));
  106. task.setConfigCellsNum(configCells.size());
  107. task.setConfigCells(configCells);
  108. task.setOrderBy(taskCondition.getOrderBy());
  109. task.setOrderByType(taskCondition.getOrderByType());
  110. task.setDBType(taskCondition.getDBType());
  111. task.setStartNumber(taskCondition.getStartNumber());
  112. task.setEndNumber(taskCondition.getEndNumber());
  113. if (taskCondition.getIsAddPatentNos() != null && !taskCondition.getIsAddPatentNos().equals("")) {
  114. task.setIsAddPatentNos(Arrays.asList(taskCondition.getIsAddPatentNos().split(",")));
  115. }
  116. if (taskCondition.getIsDeletePatentNos() != null && !taskCondition.getIsDeletePatentNos().equals("")) {
  117. task.setIsDeletePatentNos(Arrays.asList(taskCondition.getIsDeletePatentNos().split(",")));
  118. }
  119. task.setConditions(taskCondition.getConditions());
  120. task.setContinueLastInformation(taskCondition.getContinueLastInformation());
  121. task.setIsAddType(taskCondition.getIsAddType());
  122. }
  123. //TODO 调用工厂方法,工厂方法会根据任务类型创建并返回对应的生产专利方法的对象
  124. IExcutePatentData excutePatentDataObject = createObject(task);
  125. if (excutePatentDataObject != null) {
  126. //执行方法
  127. excutePatentDataObject.startExcute(task);
  128. }
  129. }
  130. } catch (Exception e) {
  131. e.printStackTrace();
  132. //任务表更新状态完成
  133. task.setStatus(2);
  134. task.setEndTime(DateUtils.getDateTime());
  135. taskService.updateById(task);
  136. }
  137. }
  138. }
  139. /**
  140. * 装载线程1:著录项目
  141. */
  142. public void setPatentZhuLu() {
  143. while (true) {
  144. QueueData queueData = new QueueData();
  145. try {
  146. if (setPatentZhuluQueueList.size() > 0) {
  147. PQueueData pQueueData = setPatentZhuluQueueList.remove(0);
  148. Task task = pQueueData.getTask();
  149. queueData
  150. .setTask(task)
  151. .setUploadParamsVO(pQueueData.getUploadParamsVO());
  152. //专利之星
  153. if (task.getType() == 4) {
  154. excutePatentDataStar.setPatentZhuLu(pQueueData.getStarPatent(), pQueueData.getUploadParamsVO());
  155. }
  156. queueData.setUploadParamsVO(pQueueData.getUploadParamsVO());
  157. //装载完成,将其丢入著录消费者队列,并唤醒著录消费者线程
  158. patentZhuluQueueList.add(queueData);
  159. if (patentZhuluLock.tryLock()) {
  160. //patentZhuluLock.lock();
  161. patentZhuluCondition.signalAll();
  162. patentZhuluLock.unlock();
  163. }
  164. } else {
  165. setPatentZhuluLock.lock();
  166. setPatentZhuluCondition.await();
  167. setPatentZhuluLock.unlock();
  168. }
  169. } catch (Exception e) {
  170. e.printStackTrace();
  171. //记录该任务该专利该部分的失败记录
  172. saveQuestionRecord(queueData, 1);
  173. sendMessage(queueData);
  174. }
  175. }
  176. }
  177. /**
  178. * 装载线程2:权要
  179. */
  180. public void setPatentRight() {
  181. while (true) {
  182. QueueData queueData = new QueueData();
  183. try {
  184. if (setPatentRightQueueList.size() > 0) {
  185. PQueueData pQueueData = setPatentRightQueueList.remove(0);
  186. Task task = pQueueData.getTask();
  187. queueData
  188. .setTask(task)
  189. .setUploadParamsVO(pQueueData.getUploadParamsVO());
  190. //专利之星
  191. Boolean canSendMessage = true;
  192. if (task.getType() == 4) {
  193. canSendMessage = excutePatentDataStar.setPatentClaim(pQueueData.getStarPatent(), pQueueData.getUploadParamsVO(), pQueueData);
  194. }
  195. queueData.setUploadParamsVO(pQueueData.getUploadParamsVO());
  196. if (canSendMessage) {
  197. //装载完成,将其丢入权要消费者队列,并唤醒权要消费者线程
  198. patentRightQueueList.add(queueData);
  199. if (patentRightLock.tryLock()) {
  200. //patentRightLock.lock();
  201. patentRightCondition.signalAll();
  202. patentRightLock.unlock();
  203. }
  204. }
  205. } else {
  206. setPatentRightLock.lock();
  207. setPatentRightCondition.await();
  208. setPatentRightLock.unlock();
  209. }
  210. } catch (Exception e) {
  211. e.printStackTrace();
  212. //记录该任务该专利该部分的失败记录
  213. saveQuestionRecord(queueData, 2);
  214. sendMessage(queueData);
  215. }
  216. }
  217. }
  218. /**
  219. * 装载线程3:说明书文本
  220. */
  221. public void setPatentInstructionText() {
  222. while (true) {
  223. QueueData queueData = new QueueData();
  224. try {
  225. if (setPatentInstructionTextQueueList.size() > 0) {
  226. PQueueData pQueueData = setPatentInstructionTextQueueList.remove(0);
  227. Task task = pQueueData.getTask();
  228. queueData
  229. .setTask(task)
  230. .setUploadParamsVO(pQueueData.getUploadParamsVO());
  231. //专利之星
  232. if (task.getType() == 4) {
  233. excutePatentDataStar.setPatentInstructionText(pQueueData.getStarPatent(), pQueueData.getUploadParamsVO(), pQueueData);
  234. }
  235. queueData.setUploadParamsVO(pQueueData.getUploadParamsVO());
  236. //装载完成,将其丢入说明书文本消费者队列,并唤醒说明书文本消费者线程
  237. patentInstructionTextQueueList.add(queueData);
  238. if (patentInstructionTextLock.tryLock()) {
  239. //patentInstructionTextLock.lock();
  240. patentInstructionTextCondition.signalAll();
  241. patentInstructionTextLock.unlock();
  242. }
  243. } else {
  244. setPatentInstructionTextLock.lock();
  245. setPatentInstructionTextCondition.await();
  246. setPatentInstructionTextLock.unlock();
  247. }
  248. } catch (Exception e) {
  249. e.printStackTrace();
  250. //记录该任务该专利该部分的失败记录
  251. saveQuestionRecord(queueData, 3);
  252. sendMessage(queueData);
  253. }
  254. }
  255. }
  256. /**
  257. * 装载线程4:说明书pdf
  258. */
  259. public void setPatentInstructionPDF() {
  260. while (true) {
  261. QueueData queueData = new QueueData();
  262. try {
  263. if (setPatentInstructionPDFQueueList.size() > 0) {
  264. PQueueData pQueueData = setPatentInstructionPDFQueueList.remove(0);
  265. Task task = pQueueData.getTask();
  266. queueData
  267. .setTask(task)
  268. .setUploadParamsVO(pQueueData.getUploadParamsVO());
  269. //专利之星
  270. if (task.getType() == 4) {
  271. excutePatentDataStar.setPatentInstructionPDF(pQueueData.getStarPatent(), pQueueData.getUploadParamsVO(), task);
  272. }
  273. queueData.setUploadParamsVO(pQueueData.getUploadParamsVO());
  274. //装载完成,将其丢入说明书pdf消费者队列,并唤醒说明书pdf消费者线程
  275. patentInstructionPDFQueueList.add(queueData);
  276. if (patentInstructionPDFLock.tryLock()) {
  277. //patentInstructionPDFLock.lock();
  278. patentInstructionPDFCondition.signalAll();
  279. patentInstructionPDFLock.unlock();
  280. }
  281. } else {
  282. setPatentInstructionPDFLock.lock();
  283. setPatentInstructionPDFCondition.await();
  284. setPatentInstructionPDFLock.unlock();
  285. }
  286. } catch (Exception e) {
  287. e.printStackTrace();
  288. //记录该任务该专利该部分的失败记录
  289. saveQuestionRecord(queueData, 4);
  290. sendMessage(queueData);
  291. }
  292. }
  293. }
  294. /**
  295. * 装载线程5:摘要附图
  296. */
  297. public void setPatentImage() {
  298. while (true) {
  299. QueueData queueData = new QueueData();
  300. try {
  301. if (setPatentImageQueueList.size() > 0) {
  302. PQueueData pQueueData = setPatentImageQueueList.remove(0);
  303. Task task = pQueueData.getTask();
  304. queueData
  305. .setTask(task)
  306. .setUploadParamsVO(pQueueData.getUploadParamsVO());
  307. //专利之星
  308. if (task.getType() == 4) {
  309. excutePatentDataStar.setPatentPicture(pQueueData.getStarPatent(), pQueueData.getUploadParamsVO());
  310. }
  311. queueData.setUploadParamsVO(pQueueData.getUploadParamsVO());
  312. //装载完成,将其丢入摘要附图消费者队列,并唤醒摘要附图消费者线程
  313. patentImageQueueList.add(queueData);
  314. if (patentImageLock.tryLock()) {
  315. //patentImageLock.lock();
  316. patentImageCondition.signalAll();
  317. patentImageLock.unlock();
  318. }
  319. } else {
  320. setPatentImageLock.lock();
  321. setPatentImageCondition.await();
  322. setPatentImageLock.unlock();
  323. }
  324. } catch (Exception e) {
  325. e.printStackTrace();
  326. //记录该任务该专利该部分的失败记录
  327. saveQuestionRecord(queueData, 5);
  328. sendMessage(queueData);
  329. }
  330. }
  331. }
  332. /**
  333. * 消费者1:著录项目入库
  334. */
  335. public void pushPatentZhuLuToDB() {
  336. while (true) {
  337. QueueData queueData = new QueueData();
  338. try {
  339. if (patentZhuluQueueList.size() > 0) {
  340. queueData = patentZhuluQueueList.remove(0);
  341. //著录项目入库
  342. uploadPatentToDBService.uploadPatentZhulu(queueData.getUploadParamsVO());
  343. //判断是与专题库关联还是与报告关联
  344. if (queueData.getTask().getProjectId() != null && !queueData.getTask().getProjectId().equals(0)) {
  345. //与专题库关联入库
  346. uploadPatentToDBService.uploadAssoThemaPat(queueData.getUploadParamsVO(), queueData.getTask().getProjectId());
  347. } else if (queueData.getTask().getReportId() != null && !queueData.getTask().getReportId().equals(0)) {
  348. //与报告关联入库(调用报告系统接口)
  349. outInterfaceService.importAssoReportPatentNo(queueData.getTask().getReportId(), queueData.getUploadParamsVO().getPatent().getPatentNo(), queueData.getUploadParamsVO().getPatent().getName());
  350. }
  351. if (queueData.getTask().getPramJson() != null && !queueData.getTask().getPramJson().equals("")) {
  352. ProjectImportPatentVO projectImportPatentVO = JsonUtils.jsonToPojo(queueData.getTask().getPramJson(), ProjectImportPatentVO.class);
  353. //自定义字段标引与专利关联入库
  354. uploadPatentToDBService.uploadAssoFieldPat(queueData.getUploadParamsVO(), projectImportPatentVO);
  355. //文件夹与专利关联入库
  356. uploadPatentToDBService.uploadAssoPorPat(queueData.getUploadParamsVO(), projectImportPatentVO);
  357. }
  358. sendMessage(queueData);
  359. } else {
  360. patentZhuluLock.lock();
  361. patentZhuluCondition.await();
  362. patentZhuluLock.unlock();
  363. }
  364. } catch (Exception e) {
  365. e.printStackTrace();
  366. //记录该任务该专利该部分的失败记录
  367. saveQuestionRecord(queueData, 1);
  368. sendMessage(queueData);
  369. }
  370. }
  371. }
  372. /**
  373. * 消费者2:权利要求入库
  374. */
  375. public void pushPatentRightToDB() {
  376. while (true) {
  377. QueueData queueData = new QueueData();
  378. try {
  379. if (patentRightQueueList.size() > 0) {
  380. queueData = patentRightQueueList.remove(0);
  381. //权要文本入库
  382. uploadPatentToDBService.uploadPatentRight(queueData.getUploadParamsVO());
  383. sendMessage(queueData);
  384. } else {
  385. patentRightLock.lock();
  386. patentRightCondition.await();
  387. patentRightLock.unlock();
  388. }
  389. } catch (Exception e) {
  390. e.printStackTrace();
  391. //记录该任务该专利该部分的失败记录
  392. saveQuestionRecord(queueData, 2);
  393. sendMessage(queueData);
  394. }
  395. }
  396. }
  397. /**
  398. * 消费者3:说明书文本入库
  399. */
  400. public void pushPatentInstructionTextToDB() {
  401. while (true) {
  402. QueueData queueData = new QueueData();
  403. try {
  404. if (patentInstructionTextQueueList.size() > 0) {
  405. queueData = patentInstructionTextQueueList.remove(0);
  406. //说明书文本入库
  407. uploadPatentToDBService.uploadPatentInstructionText(queueData.getUploadParamsVO());
  408. sendMessage(queueData);
  409. } else {
  410. patentInstructionTextLock.lock();
  411. patentInstructionTextCondition.await();
  412. patentInstructionTextLock.unlock();
  413. }
  414. } catch (Exception e) {
  415. e.printStackTrace();
  416. //记录该任务该专利该部分的失败记录
  417. saveQuestionRecord(queueData, 3);
  418. sendMessage(queueData);
  419. }
  420. }
  421. }
  422. /**
  423. * 消费者4:说明书pdf入库
  424. */
  425. public void pushPatentInstructionPDFToDB() {
  426. while (true) {
  427. QueueData queueData = new QueueData();
  428. try {
  429. if (patentInstructionPDFQueueList.size() > 0) {
  430. queueData = patentInstructionPDFQueueList.remove(0);
  431. if (queueData.getUploadParamsVO().getPdf1FileDTO() != null && queueData.getUploadParamsVO().getPdf2FileDTO() == null) { //若只有公开文档pdf
  432. patentInstructionService.edit(queueData.getUploadParamsVO().getPatent().getPatentNo(), queueData.getUploadParamsVO().getPdf1FileDTO());
  433. } else if (queueData.getUploadParamsVO().getPdf1FileDTO() == null && queueData.getUploadParamsVO().getPdf2FileDTO() != null) { //若只有授权文档pdf
  434. patentInstructionService.edit2(queueData.getUploadParamsVO().getPatent().getPatentNo(), queueData.getUploadParamsVO().getPdf2FileDTO());
  435. } else if (queueData.getUploadParamsVO().getPdf1FileDTO() != null && queueData.getUploadParamsVO().getPdf2FileDTO() != null) { //若同时有公开和授权两个文档pdf
  436. patentInstructionService.edit12(queueData.getUploadParamsVO().getPatent().getPatentNo(), queueData.getUploadParamsVO().getPdf1FileDTO(), queueData.getUploadParamsVO().getPdf2FileDTO());
  437. }
  438. sendMessage(queueData);
  439. } else {
  440. patentInstructionPDFLock.lock();
  441. patentInstructionPDFCondition.await();
  442. patentInstructionPDFLock.unlock();
  443. }
  444. } catch (Exception e) {
  445. e.printStackTrace();
  446. //记录该任务该专利该部分的失败记录
  447. saveQuestionRecord(queueData, 4);
  448. sendMessage(queueData);
  449. }
  450. }
  451. }
  452. /**
  453. * 消费者5:摘要附图入库
  454. */
  455. public void pushPatentImageToDB() {
  456. while (true) {
  457. QueueData queueData = new QueueData();
  458. try {
  459. if (patentImageQueueList.size() > 0) {
  460. queueData = patentImageQueueList.remove(0);
  461. UploadParamsVO uploadParamsVO = queueData.getUploadParamsVO();
  462. //摘要附图入库(两种方式:1.Excel摘要附图方式 2.网站导入摘要附图方式)
  463. if (queueData.getTask().getType().equals(1)) {
  464. uploadPatentToDBService.uploadPatentImage(uploadParamsVO);
  465. } else {
  466. uploadPatentToDBService.uploadPatentImage2(uploadParamsVO);
  467. }
  468. sendMessage(queueData);
  469. } else {
  470. patentImageLock.lock();
  471. patentImageCondition.await();
  472. patentImageLock.unlock();
  473. }
  474. } catch (Exception e) {
  475. e.printStackTrace();
  476. //记录该任务该专利该部分的失败记录
  477. saveQuestionRecord(queueData, 5);
  478. sendMessage(queueData);
  479. }
  480. }
  481. }
  482. /**
  483. * 当一个消费者消费完其负责的专利部分,修改成功条数,计算发送进度
  484. *
  485. * @param queueData 任务专利队列对象
  486. */
  487. public void sendMessage(QueueData queueData) {
  488. //每完成一个专利(根据计算该任务该专利的所有消费者都完成时),发送进度
  489. synchronized ("此为同步锁") {
  490. //当前进行的任务
  491. Task task = queueData.getTask();
  492. //当前进行的任务的专利总数量
  493. Integer total = task.getTotal();
  494. //将任务id + "|" + 专利id,拼接成专利的标识(作为当前某一个消费者消费完的这个专利的数量标识)
  495. String currentPatent = task.getId() + "|" + queueData.getUploadParamsVO().getPatent().getId();
  496. Integer num = patentIdMap.get(currentPatent);
  497. int needNum = 3; //临界默认设为4(即Excel导入任务默认使用5个消费者)
  498. if (task.getType().equals(3) || task.getType().equals(4)) { //若是网站导入任务,则临界默认设为下载字段类型数量 - 1
  499. needNum = task.getConfigCellsNum() - 1;
  500. }
  501. if (num == null && needNum > 0) {
  502. patentIdMap.put(currentPatent, 1);
  503. } else if (num != null && num < needNum) {
  504. patentIdMap.put(currentPatent, ++num);
  505. } else { //表示当前这个任务这个专利的消费者全都消费结束
  506. //若任务状态是等待中(即该任务的第一个专利消费完时), 将状态置为进行中
  507. if (task.getStatus() == 0) {
  508. task.setStatus(1);
  509. task.setStartTime(DateUtils.getDateTime());
  510. taskService.updateById(task);
  511. }
  512. patentIdMap.remove(currentPatent);
  513. //任务表更新 完成条数+1
  514. task.setSuccessNum(task.getSuccessNum() + 1);
  515. //根据专利号查询专利是否有导入失败记录
  516. String patentNo = queueData.getUploadParamsVO().getPatent().getPatentNo();
  517. LambdaQueryWrapper<QuestionRecord> wrapper = new LambdaQueryWrapper<>();
  518. wrapper.eq(QuestionRecord::getTaskId, task.getId())
  519. .eq(QuestionRecord::getPatentNo, patentNo);
  520. List<QuestionRecord> questionRecords = questionRecordService.list(wrapper);
  521. if (questionRecords.size() > 0) {
  522. task.setDefaultNum(task.getDefaultNum() + 1);
  523. }
  524. Task updateTask = new Task();
  525. updateTask.setId(task.getId());
  526. updateTask.setSuccessNum(task.getSuccessNum());
  527. updateTask.setDefaultNum(task.getDefaultNum());
  528. updateTask.setTrueSuccessNum(task.getSuccessNum() - updateTask.getDefaultNum());
  529. taskService.updateById(updateTask);
  530. //任务条件表更新isAddPatentNos
  531. if (task.getIsAddPatentNos() != null && task.getIsAddPatentNos().size() > 0) {
  532. ArrayList<String> updateIsAddPatentNos = new ArrayList<>(task.getIsAddPatentNos());
  533. updateIsAddPatentNos.removeIf(item -> item.equals(queueData.getUploadParamsVO().getPatent().getPatentNo()));
  534. updateIsAddPatentNos.removeIf(item -> item.equals(queueData.getUploadParamsVO().getPatent().getApplicationNo()));
  535. TaskCondition taskCondition = new TaskCondition()
  536. .setId(task.getTaskConditionId())
  537. .setIsAddPatentNos(StringUtils.join(updateIsAddPatentNos, ","));
  538. taskConditionService.updateById(taskCondition);
  539. task.setIsAddPatentNos(updateIsAddPatentNos);
  540. }
  541. long percentage = (long) Math.floor((task.getSuccessNum() + 0D) / total * 100D);
  542. //当全部完成时
  543. if (task.getSuccessNum().equals(total)) {
  544. percentage = 100L;
  545. //任务表更新最终数据
  546. if (questionRecords.size() > 0) {
  547. updateTask.setDefaultNum(task.getDefaultNum() + 1);
  548. }
  549. task.setTrueSuccessNum(task.getSuccessNum() - task.getDefaultNum());
  550. task.setStatus(2);
  551. task.setEndTime(DateUtils.getDateTime());
  552. taskService.updateById(task);
  553. }
  554. //websocket发送进度
  555. messageService.sendWebsocketMessage(task, total, task.getSuccessNum(), percentage);
  556. }
  557. }
  558. }
  559. /**
  560. * 数据丢入著录项目生产队列并唤醒装载著录项目线程
  561. *
  562. * @param pQueueData 装载生产队列实体类
  563. */
  564. public void zhuluToPQueue(PQueueData pQueueData) {
  565. setPatentZhuluQueueList.add(pQueueData);
  566. if (setPatentZhuluLock.tryLock()) {
  567. //setPatentZhuluLock.lock();
  568. setPatentZhuluCondition.signalAll();
  569. setPatentZhuluLock.unlock();
  570. }
  571. }
  572. /**
  573. * 数据丢入权要生产队列并唤醒装载权要线程
  574. *
  575. * @param pQueueData 装载生产队列实体类
  576. */
  577. public void rightToPQueue(PQueueData pQueueData) {
  578. setPatentRightQueueList.add(pQueueData);
  579. if (setPatentRightLock.tryLock()) {
  580. //setPatentRightLock.lock();
  581. setPatentRightCondition.signalAll();
  582. setPatentRightLock.unlock();
  583. }
  584. }
  585. /**
  586. * 数据丢入说明书文本生产队列并唤醒装载说明书文本线程
  587. *
  588. * @param pQueueData 装载生产队列实体类
  589. */
  590. public void instructionTextToPQueue(PQueueData pQueueData) {
  591. setPatentInstructionTextQueueList.add(pQueueData);
  592. if (setPatentInstructionTextLock.tryLock()) {
  593. //setPatentInstructionTextLock.lock();
  594. setPatentInstructionTextCondition.signalAll();
  595. setPatentInstructionTextLock.unlock();
  596. }
  597. }
  598. /**
  599. * 数据丢入说明书pdf生产队列并唤醒装载说明书pdf线程
  600. *
  601. * @param pQueueData 装载生产队列实体类
  602. */
  603. public void instructionPDFToPQueue(PQueueData pQueueData) {
  604. setPatentInstructionPDFQueueList.add(pQueueData);
  605. if (setPatentInstructionPDFLock.tryLock()) {
  606. //setPatentInstructionPDFLock.lock();
  607. setPatentInstructionPDFCondition.signalAll();
  608. setPatentInstructionPDFLock.unlock();
  609. }
  610. }
  611. /**
  612. * 数据丢入摘要附图生产队列并唤醒装载摘要附图线程
  613. *
  614. * @param pQueueData 装载生产队列实体类
  615. */
  616. public void imageToPQueue(PQueueData pQueueData) {
  617. setPatentImageQueueList.add(pQueueData);
  618. if (setPatentImageLock.tryLock()) {
  619. //setPatentImageLock.lock();
  620. setPatentImageCondition.signalAll();
  621. setPatentImageLock.unlock();
  622. }
  623. }
  624. /**
  625. * Excel任务专利丢入消费者队列,并唤醒消费者线程
  626. *
  627. * @param task 任务对象
  628. * @param uploadParamsVO 专利实体类对象
  629. */
  630. public void patentToQueue(Task task, UploadParamsVO uploadParamsVO) {
  631. //保存专利基础数据(专利表"os_patent")
  632. uploadPatentBatchService.getOneOrInsertOne(uploadParamsVO);
  633. QueueData queueData = new QueueData()
  634. .setTask(task)
  635. .setUploadParamsVO(uploadParamsVO);
  636. //专利分别加入消费者队列
  637. patentZhuluQueueList.add(queueData);
  638. patentRightQueueList.add(queueData);
  639. patentInstructionTextQueueList.add(queueData);
  640. patentImageQueueList.add(queueData);
  641. //通知消费者线程
  642. //1.著录项目
  643. if (patentZhuluLock.tryLock()) {
  644. //patentZhuluLock.lock();
  645. patentZhuluCondition.signalAll();
  646. patentZhuluLock.unlock();
  647. }
  648. //2.权利要求文本
  649. if (patentRightLock.tryLock()) {
  650. //patentRightLock.lock();
  651. patentRightCondition.signalAll();
  652. patentRightLock.unlock();
  653. }
  654. //3.说明书文本
  655. if (patentInstructionTextLock.tryLock()) {
  656. //patentInstructionTextLock.lock();
  657. patentInstructionTextCondition.signalAll();
  658. patentInstructionTextLock.unlock();
  659. }
  660. //5.摘要附图
  661. if (patentImageLock.tryLock()) {
  662. //patentImageLock.lock();
  663. patentImageCondition.signalAll();
  664. patentImageLock.unlock();
  665. }
  666. }
  667. /**
  668. * 生产者任务队列新增任务ids
  669. *
  670. * @param taskQueueList 生产者任务队列
  671. */
  672. public void taskQueueListAddTask(List<Integer> taskQueueList) {
  673. this.taskQueueList.addAll(taskQueueList);
  674. }
  675. public void taskQueueListRemoveTask(List<Integer> taskQueueList) {
  676. this.taskQueueList.removeAll(taskQueueList);
  677. }
  678. /**
  679. * 生产者生产队列剔除指定任务的所有专利
  680. *
  681. * @param taskId 任务id
  682. */
  683. public void setQueueRemoveTasks(Integer taskId) {
  684. //任务暂停时清除生产者队列中该任务元素
  685. this.setPatentZhuluQueueList.removeIf(pQueueData -> pQueueData.getTask().getId().equals(taskId));
  686. this.setPatentRightQueueList.removeIf(pQueueData -> pQueueData.getTask().getId().equals(taskId));
  687. this.setPatentInstructionTextQueueList.removeIf(pQueueData -> pQueueData.getTask().getId().equals(taskId));
  688. this.setPatentInstructionPDFQueueList.removeIf(pQueueData -> pQueueData.getTask().getId().equals(taskId));
  689. this.setPatentImageQueueList.removeIf(pQueueData -> pQueueData.getTask().getId().equals(taskId));
  690. }
  691. /**
  692. * 消费者专利队列剔除指定任务的所有专利
  693. *
  694. * @param taskId 任务id
  695. */
  696. public void consumerQueueRemoveTasks(Integer taskId) {
  697. //任务暂停时清除消费者队列中已有的该任务的所有专利
  698. this.patentZhuluQueueList.removeIf(queueData -> queueData.getTask().getId().equals(taskId));
  699. this.patentRightQueueList.removeIf(queueData -> queueData.getTask().getId().equals(taskId));
  700. this.patentInstructionTextQueueList.removeIf(queueData -> queueData.getTask().getId().equals(taskId));
  701. this.patentInstructionPDFQueueList.removeIf(queueData -> queueData.getTask().getId().equals(taskId));
  702. this.patentImageQueueList.removeIf(queueData -> queueData.getTask().getId().equals(taskId));
  703. //任务暂停时清除 patentIdMap(任务id + "|" + 专利id,拼接而成的专利的数量标识(作为辨别某一任务的某一专利消费完成的消费者数量))中该任务的专利数量标识
  704. // Iterator<String> iterator = this.patentIdMap.keySet().iterator();
  705. this.patentIdMap.keySet().removeIf(item -> item.contains(taskId + "|"));
  706. // while (iterator.hasNext()) {
  707. // String key = iterator.next();
  708. // if (key.contains(taskId + "|")) {
  709. // iterator.remove();
  710. // this.patentIdMap.remove(key);
  711. // }
  712. // }
  713. }
  714. /**
  715. * 唤醒生产者线程
  716. */
  717. public void awakeTasktch() {
  718. if (taskLock.tryLock()) {
  719. //taskLock.lock();
  720. taskCondition.signalAll();
  721. taskLock.unlock();
  722. }
  723. }
  724. /**
  725. * 工厂方法,根据任务类型返回对应的生产专利数据的对象
  726. *
  727. * @param task 任务
  728. * @return 返回获取专利数据的对象
  729. */
  730. private IExcutePatentData createObject(Task task) {
  731. //根据任务的类型创建并返回对应的解析获取专利数据的对象
  732. switch (task.getType()) {
  733. case 1: //Excel导入专利
  734. return excutePatentDataExcel;
  735. case 3: //欧专局网站导入
  736. return excutePatentDataEpo;
  737. case 4: //专利之星网站导入
  738. return excutePatentDataStar;
  739. default:
  740. return null;
  741. }
  742. }
  743. /**
  744. * 失败记录方法
  745. *
  746. * @param queueData 消费者专利队列
  747. * @param cell 消费者代表的专利字段部分
  748. */
  749. public void saveQuestionRecord(QueueData queueData, Integer cell) {
  750. QuestionRecord questionRecord = new QuestionRecord()
  751. .setPatentNo(queueData.getUploadParamsVO().getPatent().getApplicationNo())
  752. .setTaskId(queueData.getTask().getId())
  753. .setCell(cell);
  754. questionRecordService.save(questionRecord);
  755. }
  756. }