java直接操作redis

java直接操作redis

1.添加maven依赖

 <!-- https://mvnrepository.com/artifact/redis.clients/jedis -->
<dependency>
    <groupId>redis.clients</groupId>
    <artifactId>jedis</artifactId>
    <version>2.9.0</version>
</dependency>

2.创建连接

Jedis jedis = new Jedis("127.0.0.1",6379);
注,如果redis存在密码,则需要:jedis.auth("redis!@#root");

3.基本操作

1.写入: jedis.set("dd","dd")
2.读取: jedis.get("dd")
3.设置过期时间: jedis.setex("dd",100,"dd1");

4.高级操作

4.1 初始化配置

		JedisPoolConfig config = new JedisPoolConfig();
		//连接耗尽时是否阻塞, false报异常,ture阻塞直到超时, 默认true
		config.setBlockWhenExhausted(true);
		//设置的逐出策略类名, 默认DefaultEvictionPolicy(当连接超过最大空闲时间,或连接数超过最大空闲连接数)
		config.setEvictionPolicyClassName("org.apache.commons.pool2.impl.DefaultEvictionPolicy");
		//是否启用pool的jmx管理功能, 默认true
		config.setJmxEnabled(true);
		//MBean ObjectName = new ObjectName("org.apache.commons.pool2:type=GenericObjectPool,name=" + "pool" + i); 默认为"pool", JMX不熟,具体不知道是干啥的...默认就好.
		config.setJmxNamePrefix("pool");
		//是否启用后进先出, 默认true
		config.setLifo(true);
		//最大空闲连接数, 默认8个
		config.setMaxIdle(10);
		//最大连接数, 默认8个
		config.setMaxTotal(50);
		//获取连接时的最大等待毫秒数(如果设置为阻塞时BlockWhenExhausted),如果超时就抛异常, 小于零:阻塞不确定的时间,  默认-1
		config.setMaxWaitMillis(30000);
		//资源池中资源最小空闲时间(单位为毫秒),达到此值后空闲资源将被移除  默认1800000毫秒(30分钟)
		config.setMinEvictableIdleTimeMillis(60000);
		//最小空闲连接数, 默认0
		config.setMinIdle(0);
		//每次逐出检查时 逐出的最大数目 如果为负数就是 : 1/abs(n), 默认3
		config.setNumTestsPerEvictionRun(3);
		//对象空闲多久后逐出, 当空闲时间>该值 且 空闲连接>最大空闲数 时直接逐出,不再根据MinEvictableIdleTimeMillis判断  (默认逐出策略)
		config.setSoftMinEvictableIdleTimeMillis(1800000);
		//在获取连接的时候检查有效性, 默认false
		config.setTestOnBorrow(false);
		//是否开启空闲资源监测, 默认false
		config.setTestWhileIdle(true);
		//空闲资源的检测周期(单位为毫秒) 如果为负数,则不运行逐出线程, 默认-1
		config.setTimeBetweenEvictionRunsMillis(-1);
		// 创建实例
		JedisPool jedisPool = new JedisPool(config,"127.0.0.1",6379);
		Jedis jedis = jedisPool.getResource();

4.2 复杂类型读写

		1.list:
			1)存储:lpush(key,value1,value2...)、rpush(key,value1,value2...)
			2)获取:lrange(key,start,end),范围获取
			代码:
					jedis.lpush("mylist","a","b","c");//左边存
					jedis.rpush("mylist","a","b","c");//右边存
					//获取
					List<String> mylist = jedis.lrange("mylist", 0, -1);
		2.set:
			1)存储:sadd(key,members)
			2)获取:smembers(key),返回的是Set集合
			代码:
					jedis.sadd("myset","a","b","c");
					//获取
					Set<String> myset = jedis.smembers("myset");
		3.zset:
			1)存储:zadd(key,score,member)
			2)获取:zrange(key,start,end),返回的是Set集合
			代码:
					jedis.zadd("mysortedset",10,"a");
					jedis.zadd("mysortedset",20,"b");
					jedis.zadd("mysortedset",5,"c");
					//获取
					Set<String> mysortedset = jedis.zrange("mysortedset", 0, -1);
		4.hash:
			1)存储:hset(key, field,value)方法;
			2)获取:hget(key,field)方法;
			3)获取所有map数据:hgetAll(key);
			代码:
				jedis.hset("myhash","username","lisi");
				jedis.hset("myhash","age","18");
				String username = jedis.hget("myhash","username");
posted @ 2021-01-23 11:50  无敌哈士奇  阅读(134)  评论(0编辑  收藏  举报