Redis相关命令及Jedis的demo(转)

时间:2023-03-09 21:59:10
Redis相关命令及Jedis的demo(转)

org.springframework.data.redis.core.RedisTemplate在List操作时的一个注意事项:
BoundListOperations boundListOperations = redisTemplate.boundListOps("key");

org.springframework.data.redis.core.BoundListOperations中
range api使用的是lrange命令,因此要使用lpush存放最新的元素,lpush存放老的数据。
截取API trim使用的ltrim命令,默认从左边截取。

LTRIM key start stop

Available since 1.0.0.

Time complexity: O(N) where N is the number of elements to be removed by the operation.

Trim an existing list so that it will contain only the specified range of elements specified. Both start and stop are zero-based indexes, where 0 is the first element of the list (the head), 1 the next element and so on.

For example: LTRIM foobar 0 2 will modify the list stored at foobar so that only the first three elements of the list will remain.

start and end can also be negative numbers indicating offsets from the end of the list, where -1 is the last element of the list, -2 the penultimate element and so on.

Out of range indexes will not produce an error: if start is larger than the end of the list, or start > end, the result will be an empty list (which causes key to be removed).
If end is larger than the end of the list(will do nothing), Redis will treat it like the last element of the list.

A common use of LTRIM is together with LPUSH / RPUSH. For example:

LPUSH mylist someelement
LTRIM mylist 0 99

This pair of commands will push a new element on the list, while making sure that the list will not grow larger than 100 elements. This is very useful when using Redis to store logs for example. It is important to note that when used in this way LTRIM is an O(1) operation because in the average case just one element is removed from the tail of the list.

连接操作相关的命令

  • quit:关闭连接(connection)
  • auth:简单密码认证

持久化

  • save:将数据同步保存到磁盘
  • bgsave:将数据异步保存到磁盘
  • lastsave:返回上次成功将数据保存到磁盘的Unix时戳
  • shundown:将数据同步保存到磁盘,然后关闭服务

远程服务控制

  • info:提供服务器的信息和统计
  • monitor:实时转储收到的请求
  • slaveof:改变复制策略设置
  • config:在运行时配置Redis服务器

对value操作的命令

  • exists(key):确认一个key是否存在
  • del(key):删除一个key
  • type(key):返回值的类型
  • keys(pattern):返回满足给定pattern的所有key
  • randomkey:随机返回key空间的一个
  • keyrename(oldname, newname):重命名key
  • dbsize:返回当前数据库中key的数目
  • expire:设定一个key的活动时间(s)
  • ttl:获得一个key的活动时间
  • select(index):按索引查询
  • move(key, dbindex):移动当前数据库中的key到dbindex数据库
  • flushdb:删除当前选择数据库中的所有key
  • flushall:删除所有数据库中的所有key

对String操作的命令

  • set(key, value):给数据库中名称为key的string赋予值value
  • get(key):返回数据库中名称为key的string的value
  • getset(key, value):给名称为key的string赋予上一次的value
  • mget(key1, key2,…, key N):返回库中多个string的value
  • setnx(key, value):添加string,名称为key,值为value
  • setex(key, time, value):向库中添加string,设定过期时间time
  • mset(key N, value N):批量设置多个string的值
  • msetnx(key N, value N):如果所有名称为key i的string都不存在
  • incr(key):名称为key的string增1操作
  • incrby(key, integer):名称为key的string增加integer
  • decr(key):名称为key的string减1操作
  • decrby(key, integer):名称为key的string减少integer
  • append(key, value):名称为key的string的值附加value
  • substr(key, start, end):返回名称为key的string的value的子串

对List操作的命令

  • rpush(key, value):在名称为key的list尾添加一个值为value的元素
  • lpush(key, value):在名称为key的list头添加一个值为value的 元素
  • llen(key):返回名称为key的list的长度
  • lrange(key, start, end):返回名称为key的list中start至end之间的元素
  • ltrim(key, start, end):截取名称为key的list
  • lindex(key, index):返回名称为key的list中index位置的元素
  • lset(key, index, value):给名称为key的list中index位置的元素赋值
  • lrem(key, count, value):删除count个key的list中值为value的元素
  • lpop(key):返回并删除名称为key的list中的首元素
  • rpop(key):返回并删除名称为key的list中的尾元素
  • blpop(key1, key2,… key N, timeout):lpop命令的block版本。
  • brpop(key1, key2,… key N, timeout):rpop的block版本。
  • rpoplpush(srckey, dstkey):返回并删除名称为srckey的list的尾元素,并将该元素添加到名称为dstkey的list的头部

对Set操作的命令

  • sadd(key, member):向名称为key的set中添加元素member
  • srem(key, member) :删除名称为key的set中的元素member
  • spop(key) :随机返回并删除名称为key的set中一个元素
  • smove(srckey, dstkey, member) :移到集合元素
  • scard(key) :返回名称为key的set的基数
  • sismember(key, member) :member是否是名称为key的set的元素
  • sinter(key1, key2,…key N) :求交集
  • sinterstore(dstkey, (keys)) :求交集并将交集保存到dstkey的集合
  • sunion(key1, (keys)) :求并集
  • sunionstore(dstkey, (keys)) :求并集并将并集保存到dstkey的集合
  • sdiff(key1, (keys)) :求差集
  • sdiffstore(dstkey, (keys)) :求差集并将差集保存到dstkey的集合
  • smembers(key) :返回名称为key的set的所有元素
  • srandmember(key) :随机返回名称为key的set的一个元素

对Hash操作的命令

  • hset(key, field, value):向名称为key的hash中添加元素field
  • hget(key, field):返回名称为key的hash中field对应的value
  • hmget(key, (fields)):返回名称为key的hash中field i对应的value
  • hmset(key, (fields)):向名称为key的hash中添加元素field
  • hincrby(key, field, integer):将名称为key的hash中field的value增加integer
  • hexists(key, field):名称为key的hash中是否存在键为field的域
  • hdel(key, field):删除名称为key的hash中键为field的域
  • hlen(key):返回名称为key的hash中元素个数
  • hkeys(key):返回名称为key的hash中所有键
  • hvals(key):返回名称为key的hash中所有键对应的value
  • hgetall(key):返回名称为key的hash中所有的键(field)及其对应的value

http://www.cnblogs.com/liuling/p/2014-4-19-03.html

使用Java操作Redis需要jedis-2.1.0.jar,下载地址:http://files.cnblogs.com/liuling/jedis-2.1.0.jar.zip

如果需要使用Redis连接池的话,还需commons-pool-1.5.4.jar,下载地址:http://files.cnblogs.com/liuling/commons-pool-1.5.4.jar.zip

Redis相关命令及Jedis的demo(转)
  1 package com.test;
2
3 import java.util.HashMap;
4 import java.util.Iterator;
5 import java.util.List;
6 import java.util.Map;
7
8 import org.junit.Before;
9 import org.junit.Test;
10
11 import redis.clients.jedis.Jedis;
12
13 public class TestRedis {
14 private Jedis jedis;
15
16 @Before
17 public void setup() {
18 //连接redis服务器,192.168.0.100:6379
19 jedis = new Jedis("192.168.0.100", 6379);
20 //权限认证
21 jedis.auth("admin");
22 }
23
24 /**
25 * redis存储字符串
26 */
27 @Test
28 public void testString() {
29 //-----添加数据----------
30 jedis.set("name","xinxin");//向key-->name中放入了value-->xinxin
31 System.out.println(jedis.get("name"));//执行结果:xinxin
32
33 jedis.append("name", " is my lover"); //拼接
34 System.out.println(jedis.get("name"));
35
36 jedis.del("name"); //删除某个键
37 System.out.println(jedis.get("name"));
38 //设置多个键值对
39 jedis.mset("name","liuling","age","23","qq","476777XXX");
40 jedis.incr("age"); //进行加1操作
41 System.out.println(jedis.get("name") + "-" + jedis.get("age") + "-" + jedis.get("qq"));
42
43 }
44
45 /**
46 * redis操作Map
47 */
48 @Test
49 public void testMap() {
50 //-----添加数据----------
51 Map<String, String> map = new HashMap<String, String>();
52 map.put("name", "xinxin");
53 map.put("age", "22");
54 map.put("qq", "123456");
55 jedis.hmset("user",map);
56 //取出user中的name,执行结果:[minxr]-->注意结果是一个泛型的List
57 //第一个参数是存入redis中map对象的key,后面跟的是放入map中的对象的key,后面的key可以跟多个,是可变参数
58 List<String> rsmap = jedis.hmget("user", "name", "age", "qq");
59 System.out.println(rsmap);
60
61 //删除map中的某个键值
62 jedis.hdel("user","age");
63 System.out.println(jedis.hmget("user", "age")); //因为删除了,所以返回的是null
64 System.out.println(jedis.hlen("user")); //返回key为user的键中存放的值的个数2
65 System.out.println(jedis.exists("user"));//是否存在key为user的记录 返回true
66 System.out.println(jedis.hkeys("user"));//返回map对象中的所有key
67 System.out.println(jedis.hvals("user"));//返回map对象中的所有value
68
69 Iterator<String> iter=jedis.hkeys("user").iterator();
70 while (iter.hasNext()){
71 String key = iter.next();
72 System.out.println(key+":"+jedis.hmget("user",key));
73 }
74 }
75
76 /**
77 * jedis操作List
78 */
79 @Test
80 public void testList(){
81 //开始前,先移除所有的内容
82 jedis.del("java framework");
83 System.out.println(jedis.lrange("java framework",0,-1));
84 //先向key java framework中存放三条数据
85 jedis.lpush("java framework","spring");
86 jedis.lpush("java framework","struts");
87 jedis.lpush("java framework","hibernate");
88 //再取出所有数据jedis.lrange是按范围取出,
89 // 第一个是key,第二个是起始位置,第三个是结束位置,jedis.llen获取长度 -1表示取得所有
90 System.out.println(jedis.lrange("java framework",0,-1));
91
92 jedis.del("java framework");
93 jedis.rpush("java framework","spring");
94 jedis.rpush("java framework","struts");
95 jedis.rpush("java framework","hibernate");
96 System.out.println(jedis.lrange("java framework",0,-1));
97 }
98
99 /**
100 * jedis操作Set
101 */
102 @Test
103 public void testSet(){
104 //添加
105 jedis.sadd("user","liuling");
106 jedis.sadd("user","xinxin");
107 jedis.sadd("user","ling");
108 jedis.sadd("user","zhangxinxin");
109 jedis.sadd("user","who");
110 //移除noname
111 jedis.srem("user","who");
112 System.out.println(jedis.smembers("user"));//获取所有加入的value
113 System.out.println(jedis.sismember("user", "who"));//判断 who 是否是user集合的元素
114 System.out.println(jedis.srandmember("user"));
115 System.out.println(jedis.scard("user"));//返回集合的元素个数
116 }
117
118 @Test
119 public void test() throws InterruptedException {
120 //jedis 排序
121 //注意,此处的rpush和lpush是List的操作。是一个双向链表(但从表现来看的)
122 jedis.del("a");//先清除数据,再加入数据进行测试
123 jedis.rpush("a", "1");
124 jedis.lpush("a","6");
125 jedis.lpush("a","3");
126 jedis.lpush("a","9");
127 System.out.println(jedis.lrange("a",0,-1));// [9, 3, 6, 1]
128 System.out.println(jedis.sort("a")); //[1, 3, 6, 9] //输入排序后结果
129 System.out.println(jedis.lrange("a",0,-1));
130 }
131
132 @Test
133 public void testRedisPool() {
134 RedisUtil.getJedis().set("newname", "中文测试");
135 System.out.println(RedisUtil.getJedis().get("newname"));
136 }
137 }
Redis相关命令及Jedis的demo(转)

Redis连接池:

Redis相关命令及Jedis的demo(转)
 1 package com.test;
2
3 import redis.clients.jedis.Jedis;
4 import redis.clients.jedis.JedisPool;
5 import redis.clients.jedis.JedisPoolConfig;
6
7 public final class RedisUtil {
8
9 //Redis服务器IP
10 private static String ADDR = "192.168.0.100";
11
12 //Redis的端口号
13 private static int PORT = 6379;
14
15 //访问密码
16 private static String AUTH = "admin";
17
18 //可用连接实例的最大数目,默认值为8;
19 //如果赋值为-1,则表示不限制;如果pool已经分配了maxActive个jedis实例,则此时pool的状态为exhausted(耗尽)。
20 private static int MAX_ACTIVE = 1024;
21
22 //控制一个pool最多有多少个状态为idle(空闲的)的jedis实例,默认值也是8。
23 private static int MAX_IDLE = 200;
24
25 //等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。如果超过等待时间,则直接抛出JedisConnectionException;
26 private static int MAX_WAIT = 10000;
27
28 private static int TIMEOUT = 10000;
29
30 //在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的;
31 private static boolean TEST_ON_BORROW = true;
32
33 private static JedisPool jedisPool = null;
34
35 /**
36 * 初始化Redis连接池
37 */
38 static {
39 try {
40 JedisPoolConfig config = new JedisPoolConfig();
41 config.setMaxActive(MAX_ACTIVE);
42 config.setMaxIdle(MAX_IDLE);
43 config.setMaxWait(MAX_WAIT);
44 config.setTestOnBorrow(TEST_ON_BORROW);
45 jedisPool = new JedisPool(config, ADDR, PORT, TIMEOUT, AUTH);
46 } catch (Exception e) {
47 e.printStackTrace();
48 }
49 }
50
51 /**
52 * 获取Jedis实例
53 * @return
54 */
55 public synchronized static Jedis getJedis() {
56 try {
57 if (jedisPool != null) {
58 Jedis resource = jedisPool.getResource();
59 return resource;
60 } else {
61 return null;
62 }
63 } catch (Exception e) {
64 e.printStackTrace();
65 return null;
66 }
67 }
68
69 /**
70 * 释放jedis资源
71 * @param jedis
72 */
73 public static void returnResource(final Jedis jedis) {
74 if (jedis != null) {
75 jedisPool.returnResource(jedis);
76 }
77 }
78 }

http://www.cnblogs.com/liuling/p/2014-4-19-04.html