记得上下班打卡 | git大法好,push需谨慎

Commit 57be5099 authored by 张国柄's avatar 张国柄

~queue.tomdb;

parent cfeea9a2
...@@ -5,9 +5,13 @@ import com.liquidnet.commons.lang.util.CollectionUtil; ...@@ -5,9 +5,13 @@ import com.liquidnet.commons.lang.util.CollectionUtil;
import com.liquidnet.commons.lang.util.JsonUtils; import com.liquidnet.commons.lang.util.JsonUtils;
import com.liquidnet.service.base.constant.MQConst; import com.liquidnet.service.base.constant.MQConst;
import com.liquidnet.service.goblin.dto.GoblinQueueBizMongoDto; import com.liquidnet.service.goblin.dto.GoblinQueueBizMongoDto;
import com.mongodb.BasicDBObject;
import com.mongodb.client.result.UpdateResult;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.mongodb.core.MongoTemplate; import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.data.redis.connection.stream.MapRecord; import org.springframework.data.redis.connection.stream.MapRecord;
import org.springframework.data.redis.connection.stream.StreamRecords; import org.springframework.data.redis.connection.stream.StreamRecords;
import org.springframework.data.redis.core.StringRedisTemplate; import org.springframework.data.redis.core.StringRedisTemplate;
...@@ -30,6 +34,8 @@ public abstract class AbstractMdbRedisReceiver implements StreamListener<String, ...@@ -30,6 +34,8 @@ public abstract class AbstractMdbRedisReceiver implements StreamListener<String,
@Autowired @Autowired
private RedisUtil redisUtil; private RedisUtil redisUtil;
private static final BasicDBObject BASIC_DB_OBJECT = new BasicDBObject();
@Override @Override
public void onMessage(MapRecord<String, String, String> message) { public void onMessage(MapRecord<String, String, String> message) {
String redisStreamKey = this.getRedisStreamKey(); String redisStreamKey = this.getRedisStreamKey();
...@@ -56,17 +62,21 @@ public abstract class AbstractMdbRedisReceiver implements StreamListener<String, ...@@ -56,17 +62,21 @@ public abstract class AbstractMdbRedisReceiver implements StreamListener<String,
if (null == queueBizMongoDto) { if (null == queueBizMongoDto) {
aBoolean = true; aBoolean = true;
} else { } else {
String bizId = queueBizMongoDto.getBizId(); String collectName = queueBizMongoDto.getCollect(), columnName = queueBizMongoDto.getColumn();
int opType = queueBizMongoDto.getOpType(); String prefix = queueBizMongoDto.getBizId(), bizId = queueBizMongoDto.getBizId();
Object o = redisUtil.get(bizId); switch (queueBizMongoDto.getOpType()) {
switch (opType) {
case 1:// insert case 1:// insert
mongoTemplate.insert(""); mongoTemplate.insert(redisUtil.get(prefix.concat(bizId)), collectName);
aBoolean = true;
break; break;
case 2:// update case 2:// update
mongoTemplate.getCollection(""); BasicDBObject basicDBObject = (BasicDBObject) AbstractMdbRedisReceiver.BASIC_DB_OBJECT.clone();
break; UpdateResult updateResult = mongoTemplate.getCollection(collectName).updateOne(
Query.query(Criteria.where(columnName).is(bizId)).getQueryObject(),
basicDBObject.append("$set", mongoTemplate.getConverter().convertToMongoType(redisUtil.get(prefix.concat(bizId))))
);
aBoolean = updateResult.getModifiedCount() > 0;
} }
} }
} catch (Exception e) { } catch (Exception e) {
...@@ -74,7 +84,7 @@ public abstract class AbstractMdbRedisReceiver implements StreamListener<String, ...@@ -74,7 +84,7 @@ public abstract class AbstractMdbRedisReceiver implements StreamListener<String,
} finally { } finally {
if (!aBoolean) { if (!aBoolean) {
HashMap<String, String> map = CollectionUtil.mapStringString(); HashMap<String, String> map = CollectionUtil.mapStringString();
map.put("message", msg); map.put(MQConst.QUEUE_MESSAGE_KEY, msg);
stringRedisTemplate.opsForStream().add(StreamRecords.mapBacked(map).withStreamKey(this.getRedisStreamKey())); stringRedisTemplate.opsForStream().add(StreamRecords.mapBacked(map).withStreamKey(this.getRedisStreamKey()));
} }
} }
......
...@@ -7,6 +7,7 @@ import com.liquidnet.service.base.ResponseDto; ...@@ -7,6 +7,7 @@ import com.liquidnet.service.base.ResponseDto;
import com.liquidnet.service.base.SqlMapping; import com.liquidnet.service.base.SqlMapping;
import com.liquidnet.service.base.UserPathDto; import com.liquidnet.service.base.UserPathDto;
import com.liquidnet.service.base.constant.MQConst; import com.liquidnet.service.base.constant.MQConst;
import com.liquidnet.service.goblin.constant.GoblinRedisConst;
import com.liquidnet.service.goblin.constant.GoblinStatusConst; import com.liquidnet.service.goblin.constant.GoblinStatusConst;
import com.liquidnet.service.goblin.dto.vo.*; import com.liquidnet.service.goblin.dto.vo.*;
import com.liquidnet.service.goblin.entity.GoblinNftOrder; import com.liquidnet.service.goblin.entity.GoblinNftOrder;
...@@ -780,8 +781,8 @@ public class GoblinNftOrderServiceImpl implements IGoblinNftOrderService { ...@@ -780,8 +781,8 @@ public class GoblinNftOrderServiceImpl implements IGoblinNftOrderService {
digitalArtworkVo.setPublisher(goodsInfoVo.getPublisher()); digitalArtworkVo.setPublisher(goodsInfoVo.getPublisher());
// Mongo记录VO // Mongo记录VO
// goblinOrderUtils.setMongoList("GoblinUserDigitalArtworkVo", "artworkId", digitalArtworkVo.getArtworkId(), "goblin:u_d_art:", 1); goblinOrderUtils.setMongoList(GoblinUserDigitalArtworkVo.class.getSimpleName(), "artworkId", digitalArtworkVo.getArtworkId(), GoblinRedisConst.USER_DIGITAL_ARTWORK, 1);
goblinMongoUtils.insertGoblinUserDigitalArtworkVo(digitalArtworkVo); // goblinMongoUtils.insertGoblinUserDigitalArtworkVo(digitalArtworkVo);
// Redis记录VO // Redis记录VO
goblinRedisUtils.setGoblinUserDigitalArtworkVo(digitalArtworkVo); goblinRedisUtils.setGoblinUserDigitalArtworkVo(digitalArtworkVo);
// Redis更新藏品ID列表 // Redis更新藏品ID列表
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment