1.import org.junit.After;
2.import org.junit.Before;
3.import org.junit.Test;
4.import redis.clients.jedis.Jedis;
5.import redis.clients.jedis.JedisPool;
6.import redis.clients.jedis.JedisPoolConfig;
7.
8.import javax.sound.midi.Soundbank;
9.import java.util.*;
10.
11./**
12. * @author: flychao88
13. * Time: 2012.5.7 16:23:15
14. */
15.public class RedisTest {
16. JedisPool pool;
17. Jedis jedis;
18. @Before
19. public void setUp() {
20. pool = new JedisPool(new JedisPoolConfig(), "172.16.100.184");
21.
22. jedis = pool.getResource();
23. jedis.auth("password");
24. }
25.
26. /**
27. * Redis存储初级的字符串
28. * CRUD
29. */
30. @Test
31. public void testBasicString(){
32. //-----添加数据----------
33. jedis.set("name","minxr");//向key-->name中放入了value-->minxr
34. System.out.println(jedis.get("name"));//执行结果:minxr
35.
36. //-----修改数据-----------
37. //1、在原来基础上修改
38. jedis.append("name","jarorwar"); //很直观,类似map 将jarorwar append到已经有的value之后
39. System.out.println(jedis.get("name"));//执行结果:minxrjarorwar
40.
41. //2、直接覆盖原来的数据
42. jedis.set("name","闵晓荣");
43. System.out.println(jedis.get("name"));//执行结果:闵晓荣
44.
45. //删除key对应的记录
46. jedis.del("name");
47. System.out.println(jedis.get("name"));//执行结果:null
48.
49. /**
50. * mset相当于
51. * jedis.set("name","minxr");
52. * jedis.set("jarorwar","闵晓荣");
53. */
54. jedis.mset("name","minxr","jarorwar","闵晓荣");
55. System.out.println(jedis.mget("name","jarorwar"));
56.
57. }
58.
59. /**
60. * jedis操作Map
61. */
62. @Test
63. public void testMap(){
64. Map<String,String> user=new HashMap<String,String>();
65. user.put("name","minxr");
66. user.put("pwd","password");
67. jedis.hmset("user",user);
68. //取出user中的name,执行结果:[minxr]-->注意结果是一个泛型的List
69. //第一个参数是存入redis中map对象的key,后面跟的是放入map中的对象的key,后面的key可以跟多个,是可变参数
70. List<String> rsmap = jedis.hmget("user", "name");
71. System.out.println(rsmap);
72.
73. //删除map中的某个键值
74.// jedis.hdel("user","pwd");
75. System.out.println(jedis.hmget("user", "pwd")); //因为删除了,所以返回的是null
76. System.out.println(jedis.hlen("user")); //返回key为user的键中存放的值的个数1
77. System.out.println(jedis.exists("user"));//是否存在key为user的记录 返回true
78. System.out.println(jedis.hkeys("user"));//返回map对象中的所有key [pwd, name]
79. System.out.println(jedis.hvals("user"));//返回map对象中的所有value [minxr, password]
80.
81. Iterator<String> iter=jedis.hkeys("user").iterator();
82. while (iter.hasNext()){
83. String key = iter.next();
84. System.out.println(key+":"+jedis.hmget("user",key));
85. }
86.
87. }
88.
89. /**
90. * jedis操作List
91. */
92. @Test
93. public void testList(){
94. //开始前,先移除所有的内容
95. jedis.del("java framework");
96. System.out.println(jedis.lrange("java framework",0,-1));
97. //先向key java framework中存放三条数据
98. jedis.lpush("java framework","spring");
99. jedis.lpush("java framework","struts");
100. jedis.lpush("java framework","hibernate");
101. //再取出所有数据jedis.lrange是按范围取出,
102. // 第一个是key,第二个是起始位置,第三个是结束位置,jedis.llen获取长度 -1表示取得所有
103. System.out.println(jedis.lrange("java framework",0,-1));
104. }
105.
106. /**
107. * jedis操作Set
108. */
109. @Test
110. public void testSet(){
111. //添加
112. jedis.sadd("sname","minxr");
113. jedis.sadd("sname","jarorwar");
114. jedis.sadd("sname","闵晓荣");
115. jedis.sadd("sanme","noname");
116. //移除noname
117. jedis.srem("sname","noname");
118. System.out.println(jedis.smembers("sname"));//获取所有加入的value
119. System.out.println(jedis.sismember("sname", "minxr"));//判断 minxr 是否是sname集合的元素
120. System.out.println(jedis.srandmember("sname"));
121. System.out.println(jedis.scard("sname"));//返回集合的元素个数
122. }
123.
124. @Test
125. public void test() throws InterruptedException {
126. //keys中传入的可以用通配符
127. System.out.println(jedis.keys("*")); //返回当前库中所有的key [sose, sanme, name, jarorwar, foo, sname, java framework, user, braand]
128. System.out.println(jedis.keys("*name"));//返回的sname [sname, name]
129. System.out.println(jedis.del("sanmdde"));//删除key为sanmdde的对象 删除成功返回1 删除失败(或者不存在)返回 0
130. System.out.println(jedis.ttl("sname"));//返回给定key的有效时间,如果是-1则表示永远有效
131. jedis.setex("timekey", 10, "min");//通过此方法,可以指定key的存活(有效时间) 时间为秒
132. Thread.sleep(5000);//睡眠5秒后,剩余时间将为<=5
133. System.out.println(jedis.ttl("timekey")); //输出结果为5
134. jedis.setex("timekey", 1, "min"); //设为1后,下面再看剩余时间就是1了
135. System.out.println(jedis.ttl("timekey")); //输出结果为1
136. System.out.println(jedis.exists("key"));//检查key是否存在
137. System.out.println(jedis.rename("timekey","time"));
138. System.out.println(jedis.get("timekey"));//因为移除,返回为null
139. System.out.println(jedis.get("time")); //因为将timekey 重命名为time 所以可以取得值 min
140.
141. //jedis 排序
142. //注意,此处的rpush和lpush是List的操作。是一个双向链表(但从表现来看的)
143. jedis.del("a");//先清除数据,再加入数据进行测试
144. jedis.rpush("a", "1");
145. jedis.lpush("a","6");
146. jedis.lpush("a","3");
147. jedis.lpush("a","9");
148. System.out.println(jedis.lrange("a",0,-1));// [9, 3, 6, 1]
149. System.out.println(jedis.sort("a")); //[1, 3, 6, 9] //输入排序后结果
150. System.out.println(jedis.lrange("a",0,-1));
151.
152. }
分享到:
相关推荐
Windows 上安装 Redis安装Windows 上安装 Redis安装Windows 上安装 Redis安装Windows 上安装 Redis安装Windows 上安装 Redis安装Windows 上安装 Redis安装Windows 上安装 Redis安装Windows 上安装 Redis安装Windows ...
Redis7.0.4.zip,解压缩到D盘根目录后,安装后启动为Windows服务 注意是windows 64位系统才可使用,不支持windows 32位系统使用 已经在Win10,Win11,Windows server 2012系统测试运行可用 使用步骤注意事项: ...
基于前后端分离的应用,无论是否使用Redis,都需要考虑如何进行数据的存储和缓存。下面我将分别介绍基于Redis和无Redis的两种版本的特点。 基于Redis的版本 特点 缓存处理:Redis作为内存数据库可以用来缓存频繁访问...
Redis是一种开源的内存数据结构存储系统,它支持多种数据结构,如字符串、哈希、列表、集合、有序集合等。Redis可以用作数据库、缓存和消息中间件。Redis在性能、可扩展性和灵活性方面表现出色,因此被广泛应用于Web...
redis安装 1: 下载redis-5.0.4.tar.gz 2: 解压源码并进入目录 tar zxvf redis-5.0.4.tar.gz cd redis-5.0.4 3: 不用configure 4: 直接make (如果是32位机器 make 32bit) 查看linux机器是32位还是64位的方法:...
redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-5.0.5.redis-...
注意:由于本人配置redis.conf中的路径使用的是绝对路径,当前redis安装目录的父目录为D:\InstallDir,可以在每个配置文件中修改为自己指定的路径位置 redis638-.conf配置文件内容 #redis服务器端口号 port 6380 #...
在使用redis集群时,发现过期key始终监听不到。网上也没有现成的解决方案。于是想,既然不能监听集群,那我可以建立多个redis连接,分别对每个redis的key过期进行监听。以上做法可能不尽人意,目前也没找到好的解决...
本文档基于以前写的《Redis-3.0.5集群配置》和《Redis-4.0.11集群配置》。 redis-3.0.0开始支持集群,redis-4.0.0开始支持module,redis-5.0.0开始支持类似于kafka那样的消息队列。 本文参考官方文档而成:...
redis-desktop-manager-0.8.3.3850.rar windows平台安装文件 Redis Desktop Manager(redis桌面管理器)是一款非常实用的跨平台Redis桌面管理软件。也被称作Redis可视化工具,是一款开源软件,支持通过SSH Tunnel连接...
1、什么是 Redis? 2、Redis 相比 memcached 有哪些优势? 3、Redis 支持哪几种数据类型? 4、Redis 主要消耗什么物理资源? 5、Redis 的全称是什么? 6、Redis 有哪几种数据淘汰策略? 7、Redis 官方为什么不提供 ...
本地安装redis,通过安装目录下的redis客户端程序可以连接任意Redis服务(只要服务端是启动着的),命令 redis-cli -h ip -p port。如果服务端要求认证资格,可能还要输入用户名密码等参数。 Redis命令十分丰富,...
本资源可结合我的文章《详解CentOS7下编译安装Redis5.x设置开机启动及修改端口(含redis需编译安装包和redis免编译安装包)》配合使用,同时也可单独去使用。包含redis3.0.7免编译版安装包,redis5.0.7离线安装包,...
SpringBoot+VUE+Redis+nginx 网上拍卖平台源码 SpringBoot+VUE+Redis+nginx 网上拍卖平台源码 SpringBoot+VUE+Redis+nginx 网上拍卖平台源码 SpringBoot+VUE+Redis+nginx 网上拍卖平台源码 SpringBoot+...
1、redis_4.0.10-1_arm64.deb 银河麒麟v4+飞腾 安装包 2、自带服务启动 3、目录树 /opt/redis-4.0.10/ ├── bin │ ├── redis-benchmark │ ├── redis-check-aof │ ├── redis-check-rdb │ ├── ...
2016122201_Redis_初探_1.mp4 2016122201_Redis_初探_2.mp4 2016122201_Redis_初探_3.mp4 2016122202_Redis_安装_字符串键_1.mp4 2016122202_Redis_安装_字符串键_2.mp4 2016122202_Redis_安装_字符串键_3.mp4 ...
右键解压Redis压缩包,把所有文件解压到指定的redis文件夹中 1.配置redis.windows.conf文件,除了port配置为对应的端口外,其他根据需要可更改的配置项说明如下: (1)bind 127.0.0.1 (line:79) # 设置为其他机器...
redis桌面链接工具redis-desktop Redis Desktop Manager(简称RDM)是一款跨平台的Redis数据库管理工具,它提供了一个直观且用户友好的图形界面,允许开发者和运维人员轻松地连接到Redis服务器,并对其进行管理和...
1.2.6版StackExchange.Redis。 StackExchange.Redis是.net下的Redis客户端之一,目前是免费的。而用户量比较多的ServiceStack.Redis现在是收费的。把下载的三个文件(StackExchange.Redis.dll、StackExchange.Redis....
Redis是一个key-value存储系统,是当下互联网公司常用的NoSQL数据库之一,是进入互联网行业的Java开发工程师必备技术。 在本课程中,你将了解Redis是什么、能干什么、如何用,了解NoSQL的使用场景和概念,快速掌握...