redis在java客户端的操作
redis高性能,速度快,效率高的特点,用来做缓存服务器是很不错的选择。(和memcache相似)
redis在客户端的操作步骤:
1.redis单机版操作
1.1通过Jedis对象操作
(1)将安装redis服务的服务器的ip地址和redis的端口号作为构造参数传递给Jedis,用来创建一个Jedis对象
Jedis jedis = new Jedis(ip,port);
(2)通过第一步创建的jedis对象,操作redis的5大数据类型(hash类型,string类型,list类型,set类型,zset类型,有序)
jedis.set(string key,string value);
jedis.get(string key);
(3)操作完成后关闭jedis连接
jedis.close();
这种方法需要每次创建连接,关闭连接,比较浪费资源。因此使用下面的jedisPool连接池操作单机版redis
直接上代码:
// 创建jedis对象
Jedis jedis = new Jedis("ip", 6379);
// 操作string数据类型
jedis.set("username", "helloworld");
// 根据key取出对应的value值
String value = jedis.get("username");
// 值输出
System.out.println(value);
// 关闭连接
jedis.close();
1.2通过jedisPool操作jedis
(1)创建JedisPool连接池
JedisPool pool = new JedisPool(ip,port);
(2)通过连接池获得jedis对象
Jedis jedis = pool.getResource();
(3)获得jedis对象后,可以直接对redis数据类型进行操作
(4)操作完成后将jedis对象归还连接池,资源回收
(5)连接池不用的时候关闭
// 创建连接池
JedisPool pool = new JedisPool("ip地址", 6379);
// 获得连接对象
Jedis jedis = pool.getResource();
// 操作hash类型
Map<String, String> hash = new HashMap<>();
hash.put("name", "tom");
hash.put("age", "23");
hash.put("address", "长江路");
jedis.hmset("student", hash);
Map<String, String> all = jedis.hgetAll("student");
Set<Entry<String, String>> entrySet = all.entrySet();
for (Entry<String, String> entry : entrySet) {
String key = entry.getKey();
String value = entry.getValue();
System.out.println(key + ":" + value);
}// 关闭连接,连接池回收资源
jedis.close();
// 关闭连接池
pool.close();
2.操作集群redis-cluster
(1)创建集合列表,用来存放集群中的每一个redis实例
Set<HostAndPort> nodes = new Hash<HostAndPort>();
nodes.add(new HostAndPort(ip.port));
..以此类推,添加每一个redis实例
(2)第一步获得集合列表之后,创建redis集群实例对象
JedisCluster jedisCluster = new JedisCluster(nodes);//需要将redis的节点列表作为作为构造参数传递,创建集群对象
(3)集群中的每一个redis对象是通过数据槽进行区分的(redis-3.0.0中总共有0--16384个槽位),因此获得集群对象之后,可以对集群进行操作,每一个redis被访问的几率是相00的。
jedisCluster.set(String key,String value);
String value = jedisCluster.get(key);
(4)在系统关闭之前,将jedisCluster对象关闭。
jedisCluster.close();
代码:
@Test
public void testRedis_cluster() {
// 创建set集合
Set<HostAndPort> nodes = new HashSet<>();
// 将每一个节点的ip地址和端口号添加到集合中
nodes.add(new HostAndPort("192.168.xx.xxx", port));
nodes.add(new HostAndPort("192.168.xx.xxx", port));
nodes.add(new HostAndPort("192.168.xx.xxx", port));
nodes.add(new HostAndPort("192.168.xx.xxx", port));
nodes.add(new HostAndPort("192.168.xx.xxx", port));
nodes.add(new HostAndPort("192.168.xx.xxx", port));
// 创建jedisCluster对象,需要将创建的redis集合列表作为参数传递
JedisCluster jedisCluster = new JedisCluster(nodes);
// 通过集群对象操作redis
jedisCluster.set("address", "北京市长安街");
String value = jedisCluster.get("address");
// 打印结果
System.out.println(value);
// 系统关闭前,关闭jedisCluster对象
jedisCluster.close();
}
redis在java客户端的操作的更多相关文章
- 【转载】Redis的Java客户端Jedis的八种调用方式(事务、管道、分布式…)介绍
转载地址:http://blog.csdn.net/truong/article/details/46711045 关键字:Redis的Java客户端Jedis的八种调用方式(事务.管道.分布式…)介 ...
- Redis(九):Redis的Java客户端Jedis
Redis的Java客户端Jedis导航目录: 安装JDK 安装Eclipse Jedis所需要的Jar包 Jedis常用操作 JedisPool 安装JDK tar -zxvf jdk-7u67-l ...
- 9.Redis的Java客户端Jedis
Redis的Java客户端Jedis Jedis所需jar包 commons-pool-1.6.jar jedis-2.1.0.jar 1.Jedis常用操作(jedis中的api 和 我们在 l ...
- Redis解读(2):Redis的Java客户端
Redis的Java客户端 Redis不仅使用命令客户端来操作,而且可以使用程序客户端操作,其实配置和实现起来也非常容易. 现在基本上主流的语言都有客户端支持,比如Java.C.C#.C++.php. ...
- Tedis:淘宝的Redis的Java客户端开发包
Tedis:淘宝的Redis的Java客户端开发包 http://www.open-open.com/lib/view/open1389880631976.html Tedis Tedis是另 ...
- 使用Redis的Java客户端Jedis
转载自:http://aofengblog.blog.163.com/blog/static/631702120147298317919/ 前一篇文章<Redis命令指南>讲解了通过命令行 ...
- [转载] 使用Redis的Java客户端Jedis
转载自http://aofengblog.blog.163.com/blog/static/631702120147298317919/ 在实际的项目开发中,各种语言是使用Redis的客户端库来与Re ...
- Redis之Java客户端Jedis
导读 Redis不仅使用命令客户端来操作,而且可以使用程序客户端操作. 现在基本上主流的语言都有客户端支持,比如Java.C.C#.C++.php.Node.js.Go等. 在官方网站里列一些Java ...
- Zookeeper学习笔记(三)——java客户端代码操作
Zookeeper客户端java代码操作 上篇博客记录了shell命令操作zookeeper集群的方式,这次尝试采用java代码来操作.通过查阅API,发现并不困难. 1. 首先获得客户端与服务器的连 ...
随机推荐
- python之集合,深浅copy
一. 集合 集合是无序的,不重复的数据集合,它里面的元素是可哈希的(不可变类型),但是集合本身是不可哈希(所以集合做不了字典的键)的.以下是集合最重要的两点: 去重,把一个列表变成集合,就自动去重了. ...
- jquery的attr()方法
一.定义和用法 attr() 方法设置或返回被选元素的属性和值. 当该方法用于返回属性值,则返回第一个匹配元素的值. 当该方法用于设置属性值,则为匹配元素设置一个或多个属性/值对. 二.语法 返回属性 ...
- JavaScript实现图片轮播图
<!DOCTYPE html><html> <head> <script > var time; function init(){ //设置定时操作 t ...
- html5之img标签
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 1018关于MySQL复制搭建[异步复制和半同步复制]
转自:http://www.cnblogs.com/ivictor/p/5735580.html 搭建MySQL数据库的主从架构,还是蛮简单的.重要的几个命令整理一下. 主从服务器上: SHOW VA ...
- Javascript中的url编码与解码(详解)
摘要 本文主要针对URI编解码的相关问题做了介绍,对url编码中哪些字符需要编码.为什么需要编码做了详细的说明,并对比分析了Javascript中和编解码相关的几对函数escape / unescap ...
- $.ajax()方法详解 jquery
$.ajax()方法详解 jquery中的ajax方法参数总是记不住,这里记录一下. 1.url: 要求为String类型的参数,(默认为当前页地址)发送请求的地址. 2.type: 要求为Str ...
- .NET Core Community 首个千星项目诞生:CAP
项目简介 在我们构建 SOA 或者 微服务系统的过程中,我们通常需要使用事件来对各个服务进行集成,在这过程中简单的使用消息队列并不能保证数据的最终一致性, CAP 采用的是和当前数据库集成的本地消息表 ...
- 运用正则+replace+substring将一段英语的字母大写 angurlar运用自定义指令filter完成首字母大写
复习下js基础并运用正则+replace+substring将一段英语的字母大写 <!DOCTYPE html><html> <head> <meta cha ...
- hibernate--hibernate.cfg.xml常用配置详解
在hibernate中最重要的两个配置文件就是hibernate.cfg.xml和xxx.hbm.xml文件,前者是一些配置信息,后者是配置表和对象的映射关系,可以通过注解的方式来取代. 本篇文章主要 ...