SceneRestStoreConsumer.java 4.0 KB

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