From f99d8098b0aee17c09be5dfee8b4f72a6f4071b1 Mon Sep 17 00:00:00 2001 From: admin <weikou2014> Date: 星期日, 26 四月 2020 11:57:39 +0800 Subject: [PATCH] 同步老用户等级数据 --- fanli/src/main/java/com/yeshi/fanli/aspect/ActiveUserAspect.java | 30 +++++++++++++++++++++--------- 1 files changed, 21 insertions(+), 9 deletions(-) diff --git a/fanli/src/main/java/com/yeshi/fanli/aspect/ActiveUserAspect.java b/fanli/src/main/java/com/yeshi/fanli/aspect/ActiveUserAspect.java index 1ad960c..d07fed6 100644 --- a/fanli/src/main/java/com/yeshi/fanli/aspect/ActiveUserAspect.java +++ b/fanli/src/main/java/com/yeshi/fanli/aspect/ActiveUserAspect.java @@ -1,6 +1,7 @@ package com.yeshi.fanli.aspect; import java.lang.reflect.Method; +import java.util.Date; import javax.annotation.Resource; @@ -18,16 +19,24 @@ import org.springframework.stereotype.Component; import org.yeshi.utils.NumberUtil; +import com.aliyun.openservices.ons.api.Message; +import com.aliyun.openservices.ons.api.Producer; +import com.yeshi.fanli.dto.mq.user.UserTopicTagEnum; +import com.yeshi.fanli.dto.mq.user.body.UserActiveMQMsg; import com.yeshi.fanli.entity.bus.user.UserInfoExtra; -import com.yeshi.fanli.service.inter.integral.IntegralGetService; import com.yeshi.fanli.service.inter.user.UserInfoExtraService; import com.yeshi.fanli.service.inter.user.UserInfoModifyRecordService; +import com.yeshi.fanli.service.inter.user.integral.IntegralGetService; +import com.yeshi.fanli.util.Constant; import com.yeshi.fanli.util.StringUtil; import com.yeshi.fanli.util.ThreadUtil; import com.yeshi.fanli.util.annotation.UserActive; +import com.yeshi.fanli.util.rocketmq.MQMsgBodyFactory; +import com.yeshi.fanli.util.rocketmq.MQTopicName; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; +import redis.clients.jedis.params.SetParams; /** * 娲昏穬鐢ㄦ埛澶勭悊 @@ -49,6 +58,10 @@ @Resource private IntegralGetService integralGetService; + + @Resource(name = "producer") + private Producer producer; + private ExpressionParser parser = new SpelExpressionParser(); @@ -86,20 +99,19 @@ String key = "useractive-" + uidStr; Jedis jedis = jedisPool.getResource(); try { - if (jedis.setnx(key, "1") > 0) { - jedis.expire(key, 60 * 5);// 5鍒嗛挓鍐呬笉澶勭悊 + if (!StringUtil.isNullOrEmpty(jedis.set(key, "1", new SetParams().nx().ex(300)))) { try { - // TODO 鐢ㄦ埛娲昏穬澶勭悊 Long uid = Long.parseLong(uidStr); - userInfoModifyRecordService.syncBeforeInfo(uid); - UserInfoExtra extra = userInfoExtraService.getUserInfoExtra(uid); - if (extra != null && !StringUtil.isNullOrEmpty(extra.getInviteCode())) - integralGetService.addInviteActivate(uid); + if (!Constant.IS_TEST) { // 娲昏穬閫氱煡 + UserActiveMQMsg msg = new UserActiveMQMsg(uid, new Date()); + Message message = MQMsgBodyFactory.create(MQTopicName.TOPIC_USER, UserTopicTagEnum.userActve, msg); + producer.send(message); + } } catch (Exception e) { } } } finally { - jedisPool.returnResource(jedis); + jedis.close(); } } }); -- Gitblit v1.8.0