软件编程
位置:首页>> 软件编程>> java编程>> 基于idea Maven中的redis配置使用详解

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

作者:wbcra  发布时间:2023-11-29 11:57:28 

标签:maven,redis,idea

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();//归还连接
   }

}

来源:https://blog.csdn.net/wbcra/article/details/118911783

0
投稿

猜你喜欢

手机版 软件编程 asp之家 www.aspxhome.com