• springboot-redis-单机版


    1、添加依赖

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

    <dependency>
    <groupId>redis.clients</groupId>
    <artifactId>jedis</artifactId>
    <version>2.9.0</version>
    </dependency>

    2、目录结构

    3、redis.properties

    #Matseru7684ipu5730u5740
    redis.hostName=localhost
    #u7AEFu53E3u53F7
    redis.port=6379
    #u5982u679Cu6709u5BC6u7801
    redis.password=
    #u5BA2u6237u7AEFu8D85u65F6u65F6u95F4u5355u4F4Du662Fu6BEBu79D2 u9ED8u8BA4u662F2000
    redis.timeout=10000

    #u6700u5927u7A7Au95F2u6570
    redis.maxIdle=300
    #u8FDEu63A5u6C60u7684u6700u5927u6570u636Eu5E93u8FDEu63A5u6570u3002u8BBEu4E3A0u8868u793Au65E0u9650u5236,u5982u679Cu662Fjedis 2.4u4EE5u540Eu7528redis.maxTotal
    #redis.maxActive=600
    #u63A7u5236u4E00u4E2Apoolu53EFu5206u914Du591Au5C11u4E2Ajedisu5B9Eu4F8B,u7528u6765u66FFu6362u4E0Au9762u7684redis.maxActive,u5982u679Cu662Fjedis 2.4u4EE5u540Eu7528u8BE5u5C5Eu6027
    redis.maxTotal=1000
    #u6700u5927u5EFAu7ACBu8FDEu63A5u7B49u5F85u65F6u95F4u3002u5982u679Cu8D85u8FC7u6B64u65F6u95F4u5C06u63A5u5230u5F02u5E38u3002u8BBEu4E3A-1u8868u793Au65E0u9650u5236u3002
    redis.maxWaitMillis=1000
    #u8FDEu63A5u7684u6700u5C0Fu7A7Au95F2u65F6u95F4 u9ED8u8BA41800000u6BEBu79D2(30u5206u949F)
    redis.minEvictableIdleTimeMillis=300000
    #u6BCFu6B21u91CAu653Eu8FDEu63A5u7684u6700u5927u6570u76EE,u9ED8u8BA43
    redis.numTestsPerEvictionRun=1024
    #u9010u51FAu626Bu63CFu7684u65F6u95F4u95F4u9694(u6BEBu79D2) u5982u679Cu4E3Au8D1Fu6570,u5219u4E0Du8FD0u884Cu9010u51FAu7EBFu7A0B, u9ED8u8BA4-1
    redis.timeBetweenEvictionRunsMillis=30000
    #u662Fu5426u5728u4ECEu6C60u4E2Du53D6u51FAu8FDEu63A5u524Du8FDBu884Cu68C0u9A8C,u5982u679Cu68C0u9A8Cu5931u8D25,u5219u4ECEu6C60u4E2Du53BBu9664u8FDEu63A5u5E76u5C1Du8BD5u53D6u51FAu53E6u4E00u4E2A
    redis.testOnBorrow=true
    #u5728u7A7Au95F2u65F6u68C0u67E5u6709u6548u6027, u9ED8u8BA4false
    redis.testWhileIdle=true

    #redisu96C6u7FA4u914Du7F6E
    #spring.redis.cluster.nodes=192.168.177.128:7001,192.168.177.128:7002,192.168.177.128:7003,192.168.177.128:7004,192.168.177.128:7005,192.168.177.128:7006
    #spring.redis.cluster.max-redirects=3

    #u54E8u5175u6A21u5F0F
    #redis.sentinel.host1=192.168.177.128
    #redis.sentinel.port1=26379

    #redis.sentinel.host2=172.20.1.231
    #redis.sentinel.port2=26379

    4、RedisConfig

    @Configuration
    @PropertySource("classpath:config/redis.properties")
    public class RedisConfig {

    @Value("${redis.maxIdle}")
    private Integer maxIdle;

    @Value("${redis.maxTotal}")
    private Integer maxTotal;

    @Value("${redis.maxWaitMillis}")
    private Integer maxWaitMillis;

    @Value("${redis.minEvictableIdleTimeMillis}")
    private Integer minEvictableIdleTimeMillis;

    @Value("${redis.numTestsPerEvictionRun}")
    private Integer numTestsPerEvictionRun;

    @Value("${redis.timeBetweenEvictionRunsMillis}")
    private long timeBetweenEvictionRunsMillis;

    @Value("${redis.testOnBorrow}")
    private boolean testOnBorrow;

    @Value("${redis.testWhileIdle}")
    private boolean testWhileIdle;

    // @Value("${spring.redis.cluster.nodes}")
    // private String clusterNodes;

    // @Value("${spring.redis.cluster.max-redirects}")
    // private Integer mmaxRedirectsac;

    /**
    * JedisPoolConfig 连接池
    *
    * @return
    */
    @Bean
    public JedisPoolConfig jedisPoolConfig() {
    JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
    // 最大空闲数
    jedisPoolConfig.setMaxIdle(maxIdle);
    // 连接池的最大数据库连接数
    // jedisPoolConfig.setMaxTotal(maxTotal);
    // 最大建立连接等待时间
    // jedisPoolConfig.setMaxWaitMillis(maxWaitMillis);
    // 逐出连接的最小空闲时间 默认1800000毫秒(30分钟)
    jedisPoolConfig.setMinEvictableIdleTimeMillis(minEvictableIdleTimeMillis);
    // 每次逐出检查时 逐出的最大数目 如果为负数就是 : 1/abs(n), 默认3
    jedisPoolConfig.setNumTestsPerEvictionRun(numTestsPerEvictionRun);
    // 逐出扫描的时间间隔(毫秒) 如果为负数,则不运行逐出线程, 默认-1
    jedisPoolConfig.setTimeBetweenEvictionRunsMillis(timeBetweenEvictionRunsMillis);
    // 是否在从池中取出连接前进行检验,如果检验失败,则从池中去除连接并尝试取出另一个
    jedisPoolConfig.setTestOnBorrow(testOnBorrow);
    // 在空闲时检查有效性, 默认false
    jedisPoolConfig.setTestWhileIdle(testWhileIdle);
    return jedisPoolConfig;
    }

    /**
    * 单机版配置 @Title: JedisConnectionFactory @param @param
    * jedisPoolConfig @param @return @return JedisConnectionFactory @autor
    * lpl @date 2018年2月24日 @throws
    */
    @Bean
    public JedisConnectionFactory JedisConnectionFactory(JedisPoolConfig jedisPoolConfig) {
    JedisConnectionFactory JedisConnectionFactory = new JedisConnectionFactory(jedisPoolConfig);
    // 连接池
    JedisConnectionFactory.setPoolConfig(jedisPoolConfig);
    // IP地址
    JedisConnectionFactory.setHostName("localhost");
    // 端口号
    JedisConnectionFactory.setPort(6379);
    // 如果Redis设置有密码
    // JedisConnectionFactory.setPassword(password);
    // 客户端超时时间单位是毫秒
    JedisConnectionFactory.setTimeout(5000);
    return JedisConnectionFactory;
    }

    /**
    * 实例化 RedisTemplate 对象
    *
    * @return
    */
    @Bean
    public RedisTemplate<String, Object> functionDomainRedisTemplate(RedisConnectionFactory redisConnectionFactory) {
    RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
    initDomainRedisTemplate(redisTemplate, redisConnectionFactory);
    return redisTemplate;
    }

    /**
    * 设置数据存入 redis 的序列化方式,并开启事务
    *
    * @param redisTemplate
    * @param factory
    */
    private void initDomainRedisTemplate(RedisTemplate<String, Object> redisTemplate, RedisConnectionFactory factory) {
    // 如果不配置Serializer,那么存储的时候缺省使用String,如果用User类型存储,那么会提示错误User can't cast to
    // String!
    redisTemplate.setKeySerializer(new StringRedisSerializer());
    redisTemplate.setHashKeySerializer(new StringRedisSerializer());
    redisTemplate.setHashValueSerializer(new GenericJackson2JsonRedisSerializer());
    redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());
    // 开启事务
    redisTemplate.setEnableTransactionSupport(true);
    redisTemplate.setConnectionFactory(factory);
    }

    /**
    * 注入封装RedisTemplate
    * @Title: redisUtil
    * @return RedisUtil
    * @autor lpl
    * @date 2017年12月21日
    * @throws
    */
    @Bean(name = "redisUtil")
    public RedisUtil redisUtil(RedisTemplate<String, Object> redisTemplate) {
    RedisUtil redisUtil = new RedisUtil();
    redisUtil.setRedisTemplate(redisTemplate);
    return redisUtil;
    }
    }

    5、RedisUtil

    public class RedisUtil {

    private RedisTemplate<String, Object> redisTemplate;

    public void setRedisTemplate(RedisTemplate<String, Object> redisTemplate) {
    this.redisTemplate = redisTemplate;
    }

    // =============================common============================
    /**
    * 指定缓存失效时间
    *
    * @param key
    * 键
    * @param time
    * 时间(秒)
    * @return
    */
    public boolean expire(String key, long time) {
    try {
    if (time > 0) {
    redisTemplate.expire(key, time, TimeUnit.SECONDS);
    }
    return true;
    } catch (Exception e) {
    e.printStackTrace();
    return false;
    }
    }

    /**
    * 根据key 获取过期时间
    *
    * @param key
    * 键 不能为null
    * @return 时间(秒) 返回0代表为永久有效
    */
    public long getExpire(String key) {
    return redisTemplate.getExpire(key, TimeUnit.SECONDS);
    }

    /**
    * 判断key是否存在
    *
    * @param key
    * 键
    * @return true 存在 false不存在
    */
    public boolean hasKey(String key) {
    try {
    return redisTemplate.hasKey(key);
    } catch (Exception e) {
    e.printStackTrace();
    return false;
    }
    }

    /**
    * 删除缓存
    *
    * @param key
    * 可以传一个值 或多个
    */
    @SuppressWarnings("unchecked")
    public void del(String... key) {
    if (key != null && key.length > 0) {
    if (key.length == 1) {
    redisTemplate.delete(key[0]);
    } else {
    redisTemplate.delete(CollectionUtils.arrayToList(key));
    }
    }
    }

    // ============================String=============================
    /**
    * 普通缓存获取
    *
    * @param key
    * 键
    * @return 值
    */
    public Object get(String key) {
    return key == null ? null : redisTemplate.opsForValue().get(key);
    }

    /**
    * 普通缓存放入
    *
    * @param key
    * 键
    * @param value
    * 值
    * @return true成功 false失败
    */
    public boolean set(String key, Object value) {
    try {
    redisTemplate.opsForValue().set(key, value);
    return true;
    } catch (Exception e) {
    e.printStackTrace();
    return false;
    }

    }

    /**
    * 普通缓存放入并设置时间
    *
    * @param key
    * 键
    * @param value
    * 值
    * @param time
    * 时间(秒) time要大于0 如果time小于等于0 将设置无限期
    * @return true成功 false 失败
    */
    public boolean set(String key, Object value, long time) {
    try {
    if (time > 0) {
    redisTemplate.opsForValue().set(key, value, time, TimeUnit.SECONDS);
    } else {
    set(key, value);
    }
    return true;
    } catch (Exception e) {
    e.printStackTrace();
    return false;
    }
    }

    /**
    * 递增
    *
    * @param key
    * 键
    * @param by
    * 要增加几(大于0)
    * @return
    */
    public long incr(String key, long delta) {
    if (delta < 0) {
    throw new RuntimeException("递增因子必须大于0");
    }
    return redisTemplate.opsForValue().increment(key, delta);
    }

    /**
    * 递减
    *
    * @param key
    * 键
    * @param by
    * 要减少几(小于0)
    * @return
    */
    public long decr(String key, long delta) {
    if (delta < 0) {
    throw new RuntimeException("递减因子必须大于0");
    }
    return redisTemplate.opsForValue().increment(key, -delta);
    }

    // ================================Map=================================
    /**
    * HashGet
    *
    * @param key
    * 键 不能为null
    * @param item
    * 项 不能为null
    * @return 值
    */
    public Object hget(String key, String item) {
    return redisTemplate.opsForHash().get(key, item);
    }

    /**
    * 获取hashKey对应的所有键值
    *
    * @param key
    * 键
    * @return 对应的多个键值
    */
    public Map<Object, Object> hmget(String key) {
    return redisTemplate.opsForHash().entries(key);
    }

    /**
    * HashSet
    *
    * @param key
    * 键
    * @param map
    * 对应多个键值
    * @return true 成功 false 失败
    */
    public boolean hmset(String key, Map<String, Object> map) {
    try {
    redisTemplate.opsForHash().putAll(key, map);
    return true;
    } catch (Exception e) {
    e.printStackTrace();
    return false;
    }
    }

    /**
    * HashSet 并设置时间
    *
    * @param key
    * 键
    * @param map
    * 对应多个键值
    * @param time
    * 时间(秒)
    * @return true成功 false失败
    */
    public boolean hmset(String key, Map<String, Object> map, long time) {
    try {
    redisTemplate.opsForHash().putAll(key, map);
    if (time > 0) {
    expire(key, time);
    }
    return true;
    } catch (Exception e) {
    e.printStackTrace();
    return false;
    }
    }

    /**
    * 向一张hash表中放入数据,如果不存在将创建
    *
    * @param key
    * 键
    * @param item
    * 项
    * @param value
    * 值
    * @return true 成功 false失败
    */
    public boolean hset(String key, String item, Object value) {
    try {
    redisTemplate.opsForHash().put(key, item, value);
    return true;
    } catch (Exception e) {
    e.printStackTrace();
    return false;
    }
    }

    /**
    * 向一张hash表中放入数据,如果不存在将创建
    *
    * @param key
    * 键
    * @param item
    * 项
    * @param value
    * 值
    * @param time
    * 时间(秒) 注意:如果已存在的hash表有时间,这里将会替换原有的时间
    * @return true 成功 false失败
    */
    public boolean hset(String key, String item, Object value, long time) {
    try {
    redisTemplate.opsForHash().put(key, item, value);
    if (time > 0) {
    expire(key, time);
    }
    return true;
    } catch (Exception e) {
    e.printStackTrace();
    return false;
    }
    }

    /**
    * 删除hash表中的值
    *
    * @param key
    * 键 不能为null
    * @param item
    * 项 可以使多个 不能为null
    */
    public void hdel(String key, Object... item) {
    redisTemplate.opsForHash().delete(key, item);
    }

    /**
    * 判断hash表中是否有该项的值
    *
    * @param key
    * 键 不能为null
    * @param item
    * 项 不能为null
    * @return true 存在 false不存在
    */
    public boolean hHasKey(String key, String item) {
    return redisTemplate.opsForHash().hasKey(key, item);
    }

    /**
    * hash递增 如果不存在,就会创建一个 并把新增后的值返回
    *
    * @param key
    * 键
    * @param item
    * 项
    * @param by
    * 要增加几(大于0)
    * @return
    */
    public double hincr(String key, String item, double by) {
    return redisTemplate.opsForHash().increment(key, item, by);
    }

    /**
    * hash递减
    *
    * @param key
    * 键
    * @param item
    * 项
    * @param by
    * 要减少记(小于0)
    * @return
    */
    public double hdecr(String key, String item, double by) {
    return redisTemplate.opsForHash().increment(key, item, -by);
    }

    // ============================set=============================
    /**
    * 根据key获取Set中的所有值
    *
    * @param key
    * 键
    * @return
    */
    public Set<Object> sGet(String key) {
    try {
    return redisTemplate.opsForSet().members(key);
    } catch (Exception e) {
    e.printStackTrace();
    return null;
    }
    }

    /**
    * 根据value从一个set中查询,是否存在
    *
    * @param key
    * 键
    * @param value
    * 值
    * @return true 存在 false不存在
    */
    public boolean sHasKey(String key, Object value) {
    try {
    return redisTemplate.opsForSet().isMember(key, value);
    } catch (Exception e) {
    e.printStackTrace();
    return false;
    }
    }

    /**
    * 将数据放入set缓存
    *
    * @param key
    * 键
    * @param values
    * 值 可以是多个
    * @return 成功个数
    */
    public long sSet(String key, Object... values) {
    try {
    return redisTemplate.opsForSet().add(key, values);
    } catch (Exception e) {
    e.printStackTrace();
    return 0;
    }
    }

    /**
    * 将set数据放入缓存
    *
    * @param key
    * 键
    * @param time
    * 时间(秒)
    * @param values
    * 值 可以是多个
    * @return 成功个数
    */
    public long sSetAndTime(String key, long time, Object... values) {
    try {
    Long count = redisTemplate.opsForSet().add(key, values);
    if (time > 0)
    expire(key, time);
    return count;
    } catch (Exception e) {
    e.printStackTrace();
    return 0;
    }
    }

    /**
    * 获取set缓存的长度
    *
    * @param key
    * 键
    * @return
    */
    public long sGetSetSize(String key) {
    try {
    return redisTemplate.opsForSet().size(key);
    } catch (Exception e) {
    e.printStackTrace();
    return 0;
    }
    }

    /**
    * 移除值为value的
    *
    * @param key
    * 键
    * @param values
    * 值 可以是多个
    * @return 移除的个数
    */
    public long setRemove(String key, Object... values) {
    try {
    Long count = redisTemplate.opsForSet().remove(key, values);
    return count;
    } catch (Exception e) {
    e.printStackTrace();
    return 0;
    }
    }
    // ===============================list=================================

    /**
    * 获取list缓存的内容
    *
    * @param key
    * 键
    * @param start
    * 开始
    * @param end
    * 结束 0 到 -1代表所有值
    * @return
    */
    public List<Object> lGet(String key, long start, long end) {
    try {
    return redisTemplate.opsForList().range(key, start, end);
    } catch (Exception e) {
    e.printStackTrace();
    return null;
    }
    }

    /**
    * 获取list缓存的长度
    *
    * @param key
    * 键
    * @return
    */
    public long lGetListSize(String key) {
    try {
    return redisTemplate.opsForList().size(key);
    } catch (Exception e) {
    e.printStackTrace();
    return 0;
    }
    }

    /**
    * 通过索引 获取list中的值
    *
    * @param key
    * 键
    * @param index
    * 索引 index>=0时, 0 表头,1 第二个元素,依次类推;index<0时,-1,表尾,-2倒数第二个元素,依次类推
    * @return
    */
    public Object lGetIndex(String key, long index) {
    try {
    return redisTemplate.opsForList().index(key, index);
    } catch (Exception e) {
    e.printStackTrace();
    return null;
    }
    }

    /**
    * 将list放入缓存
    *
    * @param key
    * 键
    * @param value
    * 值
    * @param time
    * 时间(秒)
    * @return
    */
    public boolean lSet(String key, Object value) {
    try {
    redisTemplate.opsForList().rightPush(key, value);
    return true;
    } catch (Exception e) {
    e.printStackTrace();
    return false;
    }
    }

    /**
    * 将list放入缓存
    *
    * @param key
    * 键
    * @param value
    * 值
    * @param time
    * 时间(秒)
    * @return
    */
    public boolean lSet(String key, Object value, long time) {
    try {
    redisTemplate.opsForList().rightPush(key, value);
    if (time > 0)
    expire(key, time);
    return true;
    } catch (Exception e) {
    e.printStackTrace();
    return false;
    }
    }

    /**
    * 将list放入缓存
    *
    * @param key
    * 键
    * @param value
    * 值
    * @param time
    * 时间(秒)
    * @return
    */
    public boolean lSet(String key, List<Object> value) {
    try {
    redisTemplate.opsForList().rightPushAll(key, value);
    return true;
    } catch (Exception e) {
    e.printStackTrace();
    return false;
    }
    }

    /**
    * 将list放入缓存
    *
    * @param key
    * 键
    * @param value
    * 值
    * @param time
    * 时间(秒)
    * @return
    */
    public boolean lSet(String key, List<Object> value, long time) {
    try {
    redisTemplate.opsForList().rightPushAll(key, value);
    if (time > 0)
    expire(key, time);
    return true;
    } catch (Exception e) {
    e.printStackTrace();
    return false;
    }
    }

    /**
    * 根据索引修改list中的某条数据
    *
    * @param key
    * 键
    * @param index
    * 索引
    * @param value
    * 值
    * @return
    */
    public boolean lUpdateIndex(String key, long index, Object value) {
    try {
    redisTemplate.opsForList().set(key, index, value);
    return true;
    } catch (Exception e) {
    e.printStackTrace();
    return false;
    }
    }

    /**
    * 移除N个值为value
    *
    * @param key
    * 键
    * @param count
    * 移除多少个
    * @param value
    * 值
    * @return 移除的个数
    */
    public long lRemove(String key, long count, Object value) {
    try {
    Long remove = redisTemplate.opsForList().remove(key, count, value);
    return remove;
    } catch (Exception e) {
    e.printStackTrace();
    return 0;
    }
    }
    }

    6、controller中使用

    @RestController
    // 表示该controller类下所有的方法都公用的一级上下文根
    @RequestMapping(value = "/springboot")
    public class UserController {

    @Autowired
    TestDomain domain;

    @Autowired
    RedisUtil redisUtil;

    // 这里使用@RequestMapping注解表示该方法对应的二级上下文路径
    @RequestMapping(value = "/getUserByGet", method = RequestMethod.GET)
    String getUserByGet(@RequestParam(value = "userName") String userName) {
    redisUtil.set("zhangxuejiao", "lichangyun");
    System.out.println(redisUtil.get("zhangxuejiao"));
    domain.mysys();



    return "Hello " + userName;
    }
    }

    7、访问http://localhost:8080/springboot/getUserByGet?userName=a

  • 相关阅读:
    An exception was thrown while activating Castle.Proxies.PersonAppServiceProxy. ABP Netcore
    abp 深坑三 Unable to cast object of type 'System.Double' to type 'System.Single'.System.InvalidCastException: Unable to cast object of type 'System.Double' to type 'System.Single'.
    《统计学习方法》笔记--奇异值分解
    《统计学习方法》笔记--聚类方法
    《统计学习方法》笔记--条件随机场
    《统计学习方法》笔记--EM算法
    统计学习方法》笔记--提升方法(二)
    《统计学习方法》笔记--提升方法
    《统计学习方法》笔记--决策树
    《统计学习方法》笔记--逻辑回归
  • 原文地址:https://www.cnblogs.com/lichangyunnianxue/p/9674815.html
Copyright © 2020-2023  润新知