RedisTemplate操作命令 - 环境

不断记录中...


 

SpringBoot整合redis

 

pom依赖:

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
            <version>2.1.6.RELEASE</version>
        </dependency>

        <dependency>
            <groupId>org.redisson</groupId>
            <artifactId>redisson</artifactId>
            <version>3.11.2</version>
        </dependency>    
View Code
这里用redisson,因为项目中用了redisson做分布式锁。

配置(application-dev.yml):
spring:
  application:
    name: product-web
  redis:
    #数据库索引
    database: 0
    host: 127.0.0.1
    port: 6379
    password: ******
    jedis:
      pool:
        #最大连接数
        max-active: 500
        #最大空闲
        max-idle: 1000
        #最小空闲
        min-idle: 4
        max-wait: 6000ms

 

例 说明:

@Autowired
RedisTemplate redisTemplate;

@Autowired
StringRedisTemplate stringRedisTemplate;
redisTemplate.opsForValue().set(key, value);
redisTemplate.delete(key);

public void set(byte[] key, byte[] value) {
   if (key != null) {
      this.redisTemplate.opsForValue().set(key, value);
   }
}

  

redis文件夹形式:

以:做key的分割线可设置归类(文件夹形式)

@Test
    public void distoryTest(){
        String root = "root";
        String path = "dir";
        String key = "dirTestKey";
        redisTemplate.opsForValue().set(root+":"+path+":"+key, "1");
    }

显示形式:

 

 

RedisClient,引用并封装了上面两个redisTemplate,可以直接执行get、set类似操作

import com.qulv.vdn.common.constant.ConfigConstant;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.*;
import org.springframework.stereotype.Component;

import javax.annotation.Resource;
import java.io.IOException;
import java.util.*;
import java.util.concurrent.TimeUnit;

@SuppressWarnings("ALL")
@Slf4j
@Component("redisClient")
public class RedisClient {
   public static final long DEFAULT_EXPIRE = 86400L;
   public static final long NOT_EXPIRE = -1L;

   @Autowired
   RedisTemplate redisTemplate;

   @Autowired
   StringRedisTemplate stringRedisTemplate;

   @Resource(name = "stringRedisTemplate")
   private ValueOperations<String, String> valueOperations;

   @Resource(name = "stringRedisTemplate")
   private HashOperations<String, String, String> hashOperations;

   public void del(String key) {
      if (this.exists(key)) {
         this.stringRedisTemplate.delete(key);
      }
   }

   public void set(String key, String value, long liveTime) {
      if (!StringUtils.isBlank(key)) {
         this.valueOperations.set(key, value);
         if (liveTime != NOT_EXPIRE) {
            this.stringRedisTemplate.expire(key, liveTime, TimeUnit.SECONDS);
         }
      }
   }

   public void set(String key, String value) {
      this.set(key, value, NOT_EXPIRE);
   }

   public void set(byte[] key, byte[] value) {
      if (key != null) {
         this.redisTemplate.opsForValue().set(key, value);
      }
   }

   public Set<String> scan(String pattern) throws Exception{
      return ConfigConstant.OPEN_REDIS_CLUSTER_NO.equals("false") ? (Set)this.stringRedisTemplate.execute((RedisCallback<Set>) connection -> {
         Cursor<byte[]> cursor = null;
         Set<String> set = new HashSet<>();

         try {
            cursor = connection.scan(ScanOptions.scanOptions().count(2147483647L).match(pattern).build());

            while(cursor.hasNext()) {
               String element = new String((byte[])cursor.next());
               set.add(element);
            }
            Set<String> var16 = set;
            return set;
         } catch (Exception var14) {
            log.error("【[redisClient]使用scan出现异常,异常原因={}】", var14.getMessage());
         } finally {
            if (cursor != null) {
               try {
                  cursor.close();
               } catch (IOException var13) {
                  log.error("【[redisClient]关闭游标异常,异常原因={}】", var13.getMessage());
               }
            }
         }
         return null;
      }) : this.keysCluster(pattern);
   }

   public String get(String key) {
      if (StringUtils.isBlank(key)) {
         return null;
      } else {
         return this.stringRedisTemplate.opsForValue().get(key) == null ? null : this.stringRedisTemplate.opsForValue().get(key).toString();
      }
   }

   public Set<String> keysCluster(String pattern) {
      Set<String> result = new HashSet();
      Set<String> nodesSet = this.getClusterNodes();
      return (Set)(nodesSet == null && nodesSet.size() == 0 ? result : (Set)this.stringRedisTemplate.execute((RedisCallback<Set>)connection -> {
         Iterator iterator = nodesSet.iterator();

         while(iterator.hasNext()) {
            byte[] args1 = pattern.getBytes();
            byte[] args2 = ((String)iterator.next()).getBytes();
            ArrayList object = (ArrayList)connection.execute("keys", new byte[][]{args1, args2});
            Iterator it = object.iterator();

            while(it.hasNext()) {
               String keyName = new String((byte[])it.next());
               result.add(keyName);
            }
         }

         return result;
      }));
   }

   public Set<String> getClusterNodes() {
      return (Set)this.stringRedisTemplate.execute((RedisCallback<Set>)connection -> {
         Set<String> nodes = new HashSet();
         byte[] args1 = "nodes".getBytes();
         byte[] object = (byte[])((byte[])connection.execute("cluster", new byte[][]{args1}));
         if (object == null) {
            return null;
         } else {
            String string = new String(object);
            if (StringUtils.isEmpty(string)) {
               return null;
            } else {
               String[] nodeInfoArray = string.split("\n");

               for(int i = 0; i < nodeInfoArray.length; ++i) {
                  if (nodeInfoArray[i].contains("master")) {
                     String[] nodeInfo = nodeInfoArray[i].split(" ");
                     String nodeName = nodeInfo[0];
                     nodes.add(nodeName);
                  }
               }

               return nodes;
            }
         }
      });
   }

   public void updateCmdStatus(String uin, String userName, String cmdId, String status) {
      if (cmdId != null) {
         this.set(uin + ":cmdId:" + userName + ":" + cmdId, status, DEFAULT_EXPIRE);
      }

   }

   public String getCmdIdStatus(String uin, String userName, String cmdId) {
      return this.get(uin + ":cmdId:" + userName + ":" + cmdId);
   }

   public void expire(String key, long liveTime) {
      stringRedisTemplate.expire(key, liveTime, TimeUnit.SECONDS);
   }

   public Set<String> keys(String pattern) {
      return this.stringRedisTemplate.keys(pattern);
   }

   public boolean exists(String key) {
      return this.stringRedisTemplate.hasKey(key);
   }

   public void lpush(String key, String value) {
      this.stringRedisTemplate.opsForList().leftPush(key, value);
   }

   public void rpush(String key, String value) {
      this.stringRedisTemplate.opsForList().rightPush(key, value);
   }

   public Long llen(String key) {
      return this.stringRedisTemplate.opsForList().size(key);
   }

   public String lindex(String key, Long index) {
      return this.stringRedisTemplate.opsForList().index(key, index) == null ? null : this.stringRedisTemplate.opsForList().index(key, index).toString();
   }

   public String lpop(String key) {
      try {
         return this.stringRedisTemplate.opsForList().leftPop(key).toString();
      } catch (NullPointerException n) {
         //throw new NullPointerException(" opsForList is null ");
         return null;
      }
   }

   public List<String> lrange(String key, long start, long end) {
      return this.stringRedisTemplate.opsForList().range(key, start, end);
   }

   public void hset(String key, String field, String value) {
      this.hset(key, field, value, NOT_EXPIRE);
   }

   public void hset(String key, String field, String value, long liveTime) {
      if (!StringUtils.isBlank(key)) {
         hashOperations.put(key, field, value);
         if (liveTime != NOT_EXPIRE) {
            this.stringRedisTemplate.expire(key, liveTime, TimeUnit.SECONDS);
         }
      }
   }

   public void hsetAll(String key, Map<String, String> m, long liveTime) {
      if (!StringUtils.isBlank(key)) {
         hashOperations.putAll(key, m);
         if (liveTime != NOT_EXPIRE) {
            this.stringRedisTemplate.expire(key, liveTime, TimeUnit.SECONDS);
         }
      }
   }

   public void hsetAll(String key, Map<String, String> m) {
      this.hsetAll(key, m, NOT_EXPIRE);
   }

   public String hget(String key, String field) {
      return this.stringRedisTemplate.opsForHash().get(key, field) == null ? null : this.stringRedisTemplate.opsForHash().get(key, field).toString();
   }

   public void hdel(String key, String field) {
      this.stringRedisTemplate.opsForHash().delete(key, new Object[]{field});
   }

   public Map<String, String> hgetall(String key) {
      return this.hashOperations.entries(key);
   }

   public boolean hasKey(String key, String field) {
      return this.stringRedisTemplate.opsForHash().hasKey(key, field);
   }

   public void hasInc(String key, String hashKey, long delta){
      stringRedisTemplate.opsForHash().increment(key, hashKey, delta);
   }

   public Set zrang(String key, Long start, Long stop) {
      return this.stringRedisTemplate.opsForZSet().range(key, start, stop);
   }

   public Set zrangeByScore(String key, double v1, double l1) {
      return this.stringRedisTemplate.opsForZSet().rangeByScore(key, v1, l1);
   }

   public void zremrangeByScore(String key, double v1, double l1) {
      this.stringRedisTemplate.opsForZSet().removeRangeByScore(key, v1, l1);
   }

   public void zadd(String key, String value, Long score) {
      this.stringRedisTemplate.opsForZSet().add(key, value, (double)score);
   }

   public void zaddlive(String key, String value, Long score, long liveTime) {
      this.stringRedisTemplate.opsForZSet().add(key, value, (double)score);
      this.stringRedisTemplate.expire(key, liveTime, TimeUnit.SECONDS);
   }

   public void zremoveRange(String key, Long start, Long stop) {
      this.stringRedisTemplate.opsForZSet().removeRange(key, start, stop);
   }

   public void saveMessage(String uin, String userName, String msgId, String message) {
      this.hset(uin + ":message:" + userName, msgId, message);
   }

   public Set<String> getRedisMessageRecord(String uin, String wechatUserName, String wechatContactUserName) {
      Set messageSet = null;

      try {
         messageSet = this.stringRedisTemplate.opsForZSet().reverseRange(uin + ":messageRecord:" + wechatUserName + ":" + wechatContactUserName, 0L, 30L);
      } catch (Exception var6) {
         var6.printStackTrace();
      }

      return messageSet;
   }
}
View Code

 

使用示例:

    /**
     * 设置邀请码
     * @param user
     */
    public String setInvitationCode(User user){
        if (user.getUserId() == 1){
            return "";
        } else {
            String code = UUIDUtil.getInvitationCode(user.getUserId()) ;
            Set<String> keys = redisClient.keys("*#"+user.getUserId());
            if (keys.isEmpty()){
                //设置代理人相关信息
                redisClient.set(code + "_vest_in", getAgentVestIn(user), 60 * 24 * 15);
                redisClient.set(code, String.valueOf(user.getUserId()), 60 * 24 * 15);
                user.setInviteCode(code);
            }else {
                code = keys.stream().findFirst().get();
            }
            return code;
        }
    }

 

 

 

 




posted on 2019-12-13 11:10  GhostSugar  阅读(2940)  评论(0编辑  收藏  举报