基于idea Maven中的redis配置使用详解

 更新时间:2021年07月21日 14:54:54   作者:wbcra  
这篇文章主要介绍了基于idea Maven中的redis配置使用,包括一些配置文件需要的内容,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下

pom.xml文件需要的内容

<dependency>
      <groupId>redis.clients</groupId>
      <artifactId>jedis</artifactId>
      <version>2.9.0</version>
    </dependency>
 
    <dependency>
      <groupId>org.springframework.data</groupId>
      <artifactId>spring-data-redis</artifactId>
      <version>2.1.0.RELEASE</version>
    </dependency>
 
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.11</version>
      <scope>test</scope>
    </dependency>

Spring配置文件需要的内容

<!-- spring data redis -->
    <bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory">
        <property name="usePool" value="true"></property>
        <property name="hostName" value="${redis.host}" />
        <property name="port" value="${redis.port}" />
        <!--  <property name="password" value=""/> -->
        <property name="timeout" value="${redis.timeout}" />
        <property name="database" value="${redis.default.db}"></property>
        <constructor-arg   ref="jedisPoolConfig" />
    </bean>
    
    <!-- 连接池参数配置 -->
    <bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
        <property name="maxTotal" value="${redis.maxActive}" />
        <property name="maxIdle" value="${redis.maxIdle}" />
        <property name="maxWaitMillis" value="${redis.maxWait}" />
    </bean>
 
    <!-- 配置redis模板,方便存取数据 -->
    <!-- <bean id="redisTemplate" class="org.springframework.data.redis.core.StringRedisTemplate">-->
    <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate">
        <property name="connectionFactory" ref="jedisConnectionFactory" />
    </bean>

在resources中创建application.properties文件

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc\:mysql\://127.0.0.1:3306/mybatis01?useUnicode=true&characterEncoding=UTF-8
jdbc.username=root
jdbc.password=root
 
#定义初始连接数
jdbc.initialSize=0
#定义最大连接数
jdbc.maxActive=20
#定义最大空闲
jdbc.maxIdle=20
#定义最小空闲
jdbc.minIdle=1
#定义最长等待时间
jdbc.maxWait=60000
 
dbcp.initialSize=15
dbcp.maxActive=5000
dbcp.maxIdle=0
dbcp.maxWait=900000
dbcp.defaultAutoCommit=true
dbcp.removeAbandoned=true
dbcp.removeAbandonedTimeout=30
dbcp.whenExhaustedAction=1
dbcp.validationQuery=select 1
dbcp.testOnBorrow=fasle
dbcp.testOnReturn=false
 
 
#redis的服务器地址
redis.host=127.0.0.1
#redis的服务端口
redis.port=6379
#密码
redis.pass=root
#链接数据库
redis.default.db=0
#客户端超时时间单位是毫秒
redis.timeout=100000
#最大连接数
redis.maxActive=300
#最大空闲数
redis.maxIdle=100
#最大建立连接等待时间
redis.maxWait=1000
#指明是否在从池中取出连接前进行检验,如果检验失败,则从池中去除连接并尝试取出另一个
#DBSync.testOnBorrow=true
redis.clientName=requirepass

redis几种类型的测试(String、list、hash、set、sortedset)

package cn.hp;
 
import org.junit.Test;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;
 
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.stream.Stream;
 
public class JedisTest {
    @Test
    public void test1(){
        Jedis jedis = new Jedis("127.0.0.1",6379);
        jedis.select(1);
        jedis.set("username","张三");
        System.out.println(jedis.get("username"));
        jedis.close();
    }
 
    /**
     * 存储以时间为限定的数据
     */
    @Test
    public void test2(){
        Jedis jedis = new Jedis("127.0.0.1",6379);
        jedis.select(1);
        jedis.setex("code",20,"778899");
        System.out.println(jedis.get("code"));
        jedis.close();
    }
 
    /**
     *
     */
    @Test
    public void test3(){
        Jedis jedis = new Jedis("127.0.0.1",6379);
        jedis.lpush("mylist","b","c","d");
        jedis.rpush("mylist","e","f","g");
        List<String> jlist =  jedis.lrange("mylist",0,-1);
        for (String j:jlist){
            System.out.println(j);
        }
        jedis.close();
    }
 
    /**
     * 操作set集合
     */
    @Test
    public void test4(){
        Jedis jedis = new Jedis("127.0.0.1",6379);
        jedis.sadd("myset","zs","ls","ww","zl");
        Set<String> set=jedis.smembers("myset");
        for (String s:set){
            System.out.println(s);
        }
        jedis.close();
    }
 
    /**
     * 操作hash 哈希类型
     */
    @Test
    public void test5(){
        Jedis jedis = new Jedis("127.0.0.1",6379);
        jedis.hset("myhash","userName","zs");
        jedis.hset("myhash","pass","123456");
        Map<String ,String>map = jedis.hgetAll("myhash");
        Set<String> keys = map.keySet();
        for (String k:keys){
            String value = map.get(k);
            System.out.println("k"+k+"value:"+value);
        }
        jedis.close();
    }
 
    /**
     * 排序
     */
    @Test
    public void test6(){
        Jedis jedis = new Jedis("127.0.0.1",6379);
        jedis.zadd("mysort",90,"zs");
        jedis.zadd("mysort",80,"ls");
        jedis.zadd("mysort",70,"ww");
        Set<String> set=jedis.zrange("mysort",0,-1);
        for (String s:set){
            System.out.println(s);
        }
        jedis.close();
    }
 
    /**
     * jedis 连接池使用
     */
    @Test
    public void test7(){
        JedisPoolConfig config=new JedisPoolConfig();//创建一个配置对象
        config.setMaxTotal(50);
        config.setMaxIdle(10);
        JedisPool jedisPool = new JedisPool(config, "127.0.0.1", 6379);//获取连接池
        //从连接池拿到一个jedis连接
        Jedis jedis = jedisPool.getResource();
        jedis.set("aabb","123");
        jedis.close();//归还连接
    }
 
}

到此这篇关于基于idea Maven中的redis配置使用的文章就介绍到这了,更多相关idea redis配置使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java利用MultipartFile实现上传多份文件的代码

    Java利用MultipartFile实现上传多份文件的代码

    这篇文章主要介绍了Java利用MultipartFile实现上传多份文件的代码,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-09-09
  • java实现微信支付(服务端)

    java实现微信支付(服务端)

    这篇文章主要介绍了java实现微信支付,针对服务端进行代码编写,感兴趣的小伙伴们可以参考一下
    2015-12-12
  • 一个依赖搞定 Spring Boot 接口防盗刷的流程分析

    一个依赖搞定 Spring Boot 接口防盗刷的流程分析

    kk-anti-reptile 是适用于基于 spring-boot 开发的分布式系统的反爬虫组件,这篇文章主要介绍了一个依赖搞定 Spring Boot 接口防盗刷,需要的朋友可以参考下
    2022-06-06
  • Java设计模式中的迭代器模式详解

    Java设计模式中的迭代器模式详解

    迭代器模式官方解释就是提供一个对象来顺序访问聚合对象中的一系列数据,而不暴露聚合对象的内部表示。何为聚合对象呢?最典型的就是集合类。大白话也就是,集合中的数据是私有的,集合中不应该提供直接遍历的方法,要定义一个新的对象用于访问这个集合
    2023-02-02
  • jedis的borrow行为方法源码解读

    jedis的borrow行为方法源码解读

    这篇文章主要为大家介绍了jedis的borrow行为方法源码解读,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • Java解除文件占用即Dom4j操作后实现xml关流

    Java解除文件占用即Dom4j操作后实现xml关流

    这篇文章主要介绍了Java解除文件占用即Dom4j操作后实现xml关流,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-04-04
  • java 解决Eclipse挂掉问题的方法

    java 解决Eclipse挂掉问题的方法

    本篇文章是对在java中解决Eclipse挂掉问题的方法进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • java返回前端实体类json数据时忽略某个属性方法

    java返回前端实体类json数据时忽略某个属性方法

    这篇文章主要给大家介绍了关于java返回前端实体类json数据时忽略某个属性的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2023-08-08
  • Java如何做带复选框的菜单实例代码

    Java如何做带复选框的菜单实例代码

    大家好,本篇文章主要讲的是Java如何做带复选框的菜单实例代码,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
    2021-12-12
  • Springcloud seata分布式事务实现代码解析

    Springcloud seata分布式事务实现代码解析

    这篇文章主要介绍了Springcloud seata分布式事务实现代码解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-12-12

最新评论