一、配置 Maven 依赖项

Jedis也通过Sonatype作为Maven Dependency 分发。要配置它,只需将以下 XML 代码段添加到您的 pom.xml 文件中。

<dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>2.9.0</version><type>jar</type><scope>compile</scope>
</dependency>

二、基本用法示例

1、在多线程环境中使用 Jedis

您不应该使用来自不同线程的同一实例,因为会出现奇怪的错误。有时创建大量Jedis实例还不够好,因为这意味着大量的套接字和连接,这也会导致奇怪的错误。单个Jedis实例不是线程安全的!为了避免这些问题,您应该使用JedisPool,这是一个线程安全的网络连接池。如果完成后将Jedis实例返回到池中,则可以使用池可靠地创建多个Jedis示例。通过这种方式,您可以克服这些奇怪的错误并获得出色的性能。

要使用它,请初始化一个池:

JedisPool pool = new JedisPool(new JedisPoolConfig(), "localhost");

您可以将池静态存储在某个位置,它是线程安全的。

JedisPoolConfig 包括许多有用的 Redis 特定连接池默认值。JedisPool基于Commons Pool 2,所以你可能想看看Commons Pool的配置

您可以通过以下方式使用它:

/// Jedis implements Closeable. Hence, the jedis instance will be auto-closed after the last statement.
try (Jedis jedis = pool.getResource()) {/// ... do stuff here ... for examplejedis.set("foo", "bar");String foobar = jedis.get("foo");jedis.zadd("sose", 0, "car"); jedis.zadd("sose", 0, "bike"); Set<String> sose = jedis.zrange("sose", 0, -1);
}
/// ... when closing your application:
pool.close();

如果您不能在资源中使用try,您仍然可以使用Jedis.close()。

Jedis jedis = null;
try {jedis = pool.getResource();/// ... do stuff here ... for examplejedis.set("foo", "bar");String foobar = jedis.get("foo");jedis.zadd("sose", 0, "car"); jedis.zadd("sose", 0, "bike"); Set<String> sose = jedis.zrange("sose", 0, -1);
} finally {// You have to close jedis object. If you don't close then// it doesn't release back to pool and you can't get a new// resource from pool.if (jedis != null) {jedis.close();}
}
/// ... when closing your application:
pool.close();

如果 Jedis 是从池中借来的,它将以正确的方法返回到池中,因为它已经确定发生了 JedisConnectionException。 如果 Jedis 不是从池中借来的,它将被断开并关闭。

2、设置主/从分配

启用复制

Redis 主要用于主/从分发。这意味着写入请求必须显式发送到主服务器(redis 服务器),后者将更改复制到从服务器(也是 redis 服务器)。然后,读取请求可以(但不一定)发送给从站,从而减轻了主站的负担。

您可以使用主控形状,如上所示。为了启用复制,有两种方法可以告诉从站它将是给定主服务器的“slaveOf”:

  • 在 Redis 服务器的 Redis 配置文件的相应部分中指定它

  • 在给定的 jedis 实例上(见上文),调用 slaveOf 方法并将 IP(或“localhost”)和端口作为参数传递:

jedis.slaveof("localhost", 6379);  //  if the master is on the same PC which runs your code
jedis.slaveof("192.168.1.35", 6379); 

注意:由于 Redis 2.6 从站默认为只读,因此对它们的写入请求将导致错误。

如果您更改该设置,它们的行为将像普通的 redis 服务器一样,并接受写入请求而不会出错,但更改不会被复制,因此,如果您混合使用 jedis 实例,这些更改有被静默覆盖的风险。

禁用复制/主服务器出现故障时,升级从属服务器

万一你的主人倒下了,你可能想提拔一个奴隶成为新的主人。您应该首先(尝试)首先禁用脱机主服务器的复制,然后,如果您有多个从站,请启用剩余从站到新主站的复制:

slave1jedis.slaveofNoOne();
slave2jedis.slaveof("192.168.1.36", 6379); 

三、高级用法

1、事务

要在Jedis中执行事务,必须将操作包装在事务块中,这与pipelining非常类似:

jedis.watch (key1, key2, ...);
Transaction t = jedis.multi();
t.set("foo", "bar");
t.exec();

注意:当你有任何返回值的方法时,你必须这样做:

Transaction t = jedis.multi();
t.set("fool", "bar");
Response<String> result1 = t.get("fool");t.zadd("foo", 1, "barowitch"); t.zadd("foo", 0, "barinsky"); t.zadd("foo", 0, "barikoviev");
Response<Set<String>> sose = t.zrange("foo", 0, -1);   // get the entire sortedset
t.exec();                                              // dont forget itString foolbar = result1.get();                       // use Response.get() to retrieve things from a Response
int soseSize = sose.get().size();                      // on sose.get() you can directly call Set methods!// List<Object> allResults = t.exec();                 // you could still get all results at once, as before

请注意,响应对象不包含调用 t.exec() 之前的结果(它是一种未来)。忘记执行会给你例外。在最后一行中,您将看到在版本 2 之前如何处理事务/管道。您仍然可以这样做,但随后您需要从列表中提取对象,该列表还包含 Redis 状态消息。

注 2:Redis 不允许在同一事务中使用事务的中间结果。这不起作用:

// this does not work! Intra-transaction dependencies are not supported by Redis!
jedis.watch(...);
Transaction t = jedis.multi();
if(t.get("key1").equals("something"))t.set("key2", "value2");
else t.set("key", "value");

但是,有一些命令(如setnx)包含此类条件执行。这些当然在事务中得到支持。您可以使用 eval/ LUA 脚本构建自己的自定义命令。

2、Pipelining

有时您需要发送一系列不同的命令。一种非常酷的方法是使用Pipelining,它比简单的方法具有更好的性能。这样,您就可以发送命令而无需等待响应,而且您实际上可以在最后读取响应,这会更快。

Pipeline p = jedis.pipelined();
p.set("fool", "bar");
p.zadd("foo", 1, "barowitch");  p.zadd("foo", 0, "barinsky"); p.zadd("foo", 0, "barikoviev");
Response<String> pipeString = p.get("fool");
Response<Set<String>> sose = p.zrange("foo", 0, -1);
p.sync(); int soseSize = sose.get().size();
Set<String> setBack = sose.get();

3、发布/订阅

要在 Redis 中订阅频道,请创建一个 JedisPubSub 实例并在 Jedis 实例上调用订阅:

class MyListener extends JedisPubSub {public void onMessage(String channel, String message) {}public void onSubscribe(String channel, int subscribedChannels) {}public void onUnsubscribe(String channel, int subscribedChannels) {}public void onPSubscribe(String pattern, int subscribedChannels) {}public void onPUnsubscribe(String pattern, int subscribedChannels) {}public void onPMessage(String pattern, String channel, String message) {}
}MyListener l = new MyListener();jedis.subscribe(l, "foo");

请注意,订阅是一个阻塞操作,因为它将轮询 Redis 以获取调用订阅的线程上的响应。单个 JedisPubSub 实例可用于订阅多个频道。您可以在现有的 JedisPubSub 实例上调用订阅或订阅来更改您的订阅。

欢迎来到Doker,欢迎点赞和评论!或者加微信进入技术群聊!

Jedis 使用详解(官方原版)相关推荐

  1. Redis安装详解—官方原版

    一般redis安装于linux服务器,故本例介绍的是Linux下的安装 一. Redis下载 1. 官网下载tar包 可以到​​ ​redis的官网​​​找到各个Redis版本的下载地址,如: htt ...

  2. Shiro——从零开始进行详解官方入门案例

    首先进入shiro的官网下载源码http://mirror.bit.edu.cn/apache/shiro/1.5.0/shiro-root-1.5.0-source-release.zip 下载完毕 ...

  3. java jedis_Java操作Redis之Jedis用法详解

    Redis(Remote Dictionary Server,远程数据字典服务器)是一个开源的高性能内存数据库,常用作缓存缓存服务器使用,也已做消息队列使用.因其高性能.丰富的数据类型.可扩展等特性受 ...

  4. QGIS源码编译步骤详解——官方新方案

    目录 源码下载 环境下载 Cygwin64 OSGeo4W CMAKE Visual Studio 2017 环境配置 配置 编译   方案详细可见源码文件中INSTALL.md. 源码下载   QG ...

  5. 软考之信息安全工程师(包含2016-2018历年真题详解+官方指定教程+VIP视频教程)

    软考-中级信息安全工程师2016-2018历年考试真题以及详细答案,同时含有信息安全工程师官方指定清华版教程.信息安全工程师高清视频教程.持续更新后续年份的资料.请点赞!!请点赞!!!绝对全部货真价实 ...

  6. 软考之信息系统项目管理师(包含2005-2018历年真题详解+官方指定第三版教程+高清学习视频)

    基本搜集整理了全网所有的信息系统项目管理师资料,建议不要各位再浪费时间去各个网站下载找寻了,时间宝贵!!!全网独此一家,不要倒卖,收集不易!!!!谢谢!!!! 持续更新后续年份的资料.请点赞!!请点赞 ...

  7. Spring和Redis整合详解

    Spring和Redis整合详解 官方主页 Spring Spring Redis 概述 Redis是一个开源(BSD许可)的内存数据结构存储,用作数据库,缓存和消息代理. 简单来说,它是一个以(ke ...

  8. 【C++】Google Protocol Buffer(protobuf)详解(二)

    代码走读:caffe中protobuf的详细使用过程 [一]proto文件,以caffe.proto中BlobShape为例 syntax = "proto2"; //指明prot ...

  9. Apache Kafka-初体验Kafka(02)-Centos7下搭建单节点kafka_配置参数详解_基本命令实操

    文章目录 安装JDK 安装zookeeper 安装kafka 下载解压 配置hosts 启动kafka服务 server.properties核心配置详解 基本命令 创建主题 发送消息 消费消息 查看 ...

最新文章

  1. 线段树 ---- H. AND = OR (或和与的性质之1的个数 + 线段树)
  2. 发布【规模化产品开发方法-产品线工程.pdf】
  3. 对CAS机制的理解(二)
  4. 前端数据可视化可绘制地图等插件:Highcharts、Echarts和D3
  5. keepalived实现高可用nginx反向代理的简单案例
  6. Nginx的Web管理界面收集
  7. 华为云企业级Redis讲解第16期:超越开源Redis的ACID“真“事务
  8. 触发器_触发器第三弹
  9. 用servlet编写下载程序
  10. docker中 system limit for_java中的split函数的坑
  11. 03_安装和配置 kubectl
  12. Exce批量发送邮件功能:发件人设置的操作
  13. [除一波线段树和平衡树的草]
  14. 手机查看企业qq邮件服务器,QQ企业邮箱怎么用?手机QQ邮箱收发邮件的方法
  15. 外星人17r4原版系统_外星人17r4重装系统
  16. C语言编程:三(n)子棋游戏
  17. Linux永久删除文件恢复
  18. 跨部门不配合工作_跨部门对接很难?同事不配合你?来,我教你怎么搞定!
  19. C++ 实验二 NO.4 字符串合并:输入两个已经按从小到大顺序排列好的字符串,编写一个合并两个字符串的函数,使合并后的字符串,仍然是从小到大排列。
  20. 没错, Python杀死了Excel

热门文章

  1. 数据库实验六 触发器实验
  2. uni-app微信小程序结合腾讯地图获取定位导航以及城市选择器
  3. mysql自增列修改方法_如何修改自增列值以及相应的解决方法
  4. 所有的事情都会趋于平淡
  5. 世事无常?还是......
  6. 复杂场景下智能汽车目标检测心得体会
  7. 产品:关键词与分类---人人都是产品经理day02
  8. 素描初学者选择画笔,这些坑别踩
  9. idea导入Moudle时,报错:Module “xxx” must not contain source root ““. The root already belongs to module ““
  10. 中景合天部分工作内容摘要