基于idea Maven中的redis配置使用详解
时间:2023-02-16 09:34:19|栏目:JAVA代码|点击: 次
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();//归还连接 } }
栏 目:JAVA代码
下一篇:关于SSM框架下各层的解释说明(Controller等)
本文标题:基于idea Maven中的redis配置使用详解
本文地址:http://www.codeinn.net/misctech/225880.html