SceneRestStoreConsumer.java 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. package com.fdkankan.manage.mq.consumer;
  2. import com.alibaba.fastjson.JSONObject;
  3. import com.fdkankan.fyun.face.FYunFileServiceInterface;
  4. import com.fdkankan.manage.common.RedisKeyUtil;
  5. import com.fdkankan.manage.common.ResultCode;
  6. import com.fdkankan.manage.exception.BusinessException;
  7. import com.fdkankan.manage.mq.param.SceneRestStoreVo;
  8. import com.fdkankan.manage.service.ISceneColdStorageLogService;
  9. import com.fdkankan.manage.service.ISceneColdStorageService;
  10. import com.fdkankan.manage.service.ISceneProService;
  11. import com.fdkankan.manage.thread.ThreadService;
  12. import com.fdkankan.redis.util.RedisUtil;
  13. import com.rabbitmq.client.Channel;
  14. import lombok.extern.slf4j.Slf4j;
  15. import org.springframework.amqp.core.Message;
  16. import org.springframework.amqp.rabbit.annotation.Queue;
  17. import org.springframework.amqp.rabbit.annotation.RabbitListener;
  18. import org.springframework.beans.factory.annotation.Autowired;
  19. import org.springframework.stereotype.Component;
  20. import java.io.IOException;
  21. import java.nio.charset.StandardCharsets;
  22. import java.util.Arrays;
  23. import java.util.Date;
  24. import java.util.concurrent.ScheduledThreadPoolExecutor;
  25. import java.util.concurrent.TimeUnit;
  26. import java.util.concurrent.atomic.AtomicReference;
  27. /**
  28. * 场景解冻 mq
  29. */
  30. @Slf4j
  31. @Component
  32. public class SceneRestStoreConsumer {
  33. @Autowired
  34. FYunFileServiceInterface fYunFileServiceInterface;
  35. @Autowired
  36. RedisUtil redisUtil;
  37. @Autowired
  38. ISceneColdStorageService sceneColdStorageService;
  39. @Autowired
  40. ISceneColdStorageLogService sceneColdStorageLogService;
  41. @Autowired
  42. ISceneProService sceneProService;
  43. @RabbitListener(
  44. queuesToDeclare = @Queue("${queue.scene.rest-store:scene-rest-store}"),
  45. concurrency = "1"
  46. )
  47. public void consumerQueue(Channel channel, Message message) throws IOException {
  48. try {
  49. String messageId = message.getMessageProperties().getMessageId();
  50. String msg = new String(message.getBody(), StandardCharsets.UTF_8);
  51. log.info("scene-restStore-mq--messageId:{},msg:{}",messageId,msg);
  52. SceneRestStoreVo sceneRestStoreVo = JSONObject.parseObject(msg, SceneRestStoreVo.class);
  53. String num = sceneRestStoreVo.getNum();
  54. String cloudBucket= sceneRestStoreVo.getCloudBucket();
  55. String bucket= sceneRestStoreVo.getBucket();
  56. String folderName= sceneRestStoreVo.getFolderName();
  57. String redisKey = String.format(RedisKeyUtil.restStoreKey, num);
  58. if(redisUtil.hasKey(redisKey)){
  59. return;
  60. }
  61. redisUtil.set(redisKey,folderName);
  62. try {
  63. fYunFileServiceInterface.restoreFolder(cloudBucket,folderName,1);
  64. }catch (Exception e){
  65. log.info("scene-restStore-mq-error:",e);
  66. }
  67. Long startTime = new Date().getTime();
  68. Integer process = fYunFileServiceInterface.getRestoreFolderProcess(cloudBucket, folderName);
  69. log.info("scene-restStore-mq-cloudBucket:{},bucket:{},folderName:{},process:{}",cloudBucket,bucket,folderName,process);
  70. while (process != 100 ){
  71. Long time = new Date().getTime();
  72. if(time - startTime >1000 * 60 * 10){
  73. startTime = time;
  74. process = fYunFileServiceInterface.getRestoreFolderProcess(cloudBucket, folderName);
  75. log.info("scene-restStore-mq-cloudBucket:{},bucket:{},folderName:{},process:{}",cloudBucket,bucket,folderName,process);
  76. }
  77. }
  78. fYunFileServiceInterface.copyFileBetweenBucket(cloudBucket,folderName,bucket,folderName);
  79. log.info("Tscene-restStore-mq-copy-bucket");
  80. sceneColdStorageService.updateStatus(num,2);
  81. sceneColdStorageLogService.saveLog(num,folderName);
  82. sceneProService.restStoreSuccess(num);
  83. redisUtil.del(redisKey);
  84. }catch (Exception e){
  85. log.info("scene-restStore----消费失败",e);
  86. }finally {
  87. channel.basicAck(message.getMessageProperties().getDeliveryTag(), false);
  88. }
  89. }
  90. }