目录

一、快速上手

  1.1、导入依赖

  1.2、第一个示例

二、使用Jedis连接池

  2.1、使用示例

  2.2、封装工具类

三、使用Jedis连接Redis集群

  3.1、单纯的JedisCluster

  3.2、配合使用连接池

一、快速上手

1.1、导入依赖

  jedis的github网址:https://github.com/xetorthio/jedis

  maven仓库信息:https://mvnrepository.com/artifact/redis.clients/jedis

  本文所使用的的是最新的3.2.0版本,jedis的maven依赖xml如下:

<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>3.2.0</version>
</dependency>

  

1.2、第一个示例

  测试的时候,使用本地安装的redis,所以先将本地的redis服务器启动

  

  导入以来以后,可以创建一个单元测试类进行测试

package cn.ganlixin.redis;

import org.junit.Test;
import redis.clients.jedis.Jedis; public class JedisExample { @Test
public void testFirstExample() {
// 连接redis
Jedis jedis = new Jedis("localhost", 6379);
// Jedis jedis = new Jedis("localhost"); // 默认6379端口 // string类型
jedis.set("name", "demo");
String name = jedis.get("name"); // list类型
jedis.lpush("myList", "hello");
jedis.rpush("myList", "world");
String lpopVal = jedis.lpop("myList");
String rpopVal = jedis.rpop("myList"); // set类型
jedis.sadd("mySet", "123");
jedis.sadd("mySet", "456");
jedis.sadd("mySet", "789");
jedis.srem("mySet", "789");
jedis.scard("mySet"); // zset类型
jedis.zadd("myZset", 99, "X");
jedis.zadd("myZset", 90, "Y");
jedis.zadd("myZset", 97, "Z");
Double zscore = jedis.zscore("myZset", "Z"); // 其他
jedis.incr("intKey");
jedis.incrBy("intKey", 5);
jedis.del("intKey"); // 触发持久化
// jedis.save();
// jedis.bgsave() // 关闭连接
jedis.close();
}
}

  

  执行完毕后,可以通过redis客户端工具,登录到redis服务器查看存储的值

  

二、使用Jedis连接池

2.1、使用示例

  仍旧使用上面的maven依赖,示例代码如下

package cn.ganlixin.redis;

import org.junit.Test;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig; public class JedisPoolExample { @Test
public void testUsePool() { // 配置连接池
JedisPoolConfig config = new JedisPoolConfig();
config.setMaxTotal(20);
config.setMaxIdle(10);
config.setMinIdle(5); // 创建连接池
JedisPool jedisPool = new JedisPool(config, "localhost", 6379); Jedis jedis = jedisPool.getResource(); // 使用jedis进行操作
jedis.set("name", "otherNameVal"); // 用完之后,一定要手动关闭连接(归还给连接池)
jedis.close();
}
}

2.2、封装工具类

  对于jedis连接池来说,只需要初始化一次即可,所以可以将其在工具类中实现,下面是我写的示例:

package cn.ganlixin.redis.util;

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig; /**
* 描述: Jedis工具类(封装了连接池)
*/
public class JedisUtils { private static JedisPool jedisPool; static {
// 配置连接池
JedisPoolConfig config = new JedisPoolConfig();
config.setMaxTotal(5);
config.setMaxIdle(3);
config.setMinIdle(2); // 创建连接池
jedisPool = new JedisPool(config, "localhost", 6379);
} /**
* 获取redis连接
*/
public static Jedis getJedis() {
return jedisPool.getResource();
}
}

  

  配置项可以从配置文件中获取,下面是使用示例:

package cn.ganlixin.redis;

import cn.ganlixin.redis.util.JedisUtils;
import org.junit.Test;
import redis.clients.jedis.Jedis; public class JedisPoolExample { @Test
public void testJedisPoolUtil() {
Jedis jedis = JedisUtils.getJedis();
jedis.set("name123", "demo"); // 一定要关闭jedis连接
jedis.close();
}
}

  使用Jedis连接池,最重要的就是:一定要手动关闭连接(释放连接),否则会因为连接耗尽而导致操作阻塞

三、使用Jedis连接Redis集群

  要使用jedis操作Redis集群,就必须先有一个redis集群,redis集群的搭建方式,可以参考:Redis集群搭建

3.1、单纯的JedisCluster

  这里的单纯,是指先简单可以下JedisCluster的用法,没有涉及到连接池相关的,后面会与连接池配合使用

package cn.ganlixin.redis;

import org.junit.Test;
import redis.clients.jedis.HostAndPort;
import redis.clients.jedis.JedisCluster; import java.util.HashSet;
import java.util.Set; /**
* Jedis操作Redis集群
*/
public class JedisClusterExample { @Test
public void testExample() {
// 设置redis集群的节点信息
Set<HostAndPort> nodes = new HashSet<>();
nodes.add(new HostAndPort("192.168.1.3", 6379));
nodes.add(new HostAndPort("192.168.1.4", 6379));
nodes.add(new HostAndPort("192.168.1.5", 6379)); // 创建jediscluster,可以理解为jedis对象
JedisCluster cluster = new JedisCluster(nodes); // 和jedis的使用方式几乎一样
cluster.set("name", "nameDemo"); // 使用完毕后,不需要释放连接
// cluster.close();
}
}

  

3.2、配合使用连接池

  JedisCluster增加连接池,只需要配置一下连接池即可,示例如下:

package cn.ganlixin.redis;

import org.junit.Test;
import redis.clients.jedis.HostAndPort;
import redis.clients.jedis.JedisCluster;
import redis.clients.jedis.JedisPoolConfig; import java.util.HashSet;
import java.util.Set; /**
* Jedis操作Redis集群
*/
public class JedisClusterExample { @Test
public void clusterWithPool() { // 设置redis集群的节点信息
Set<HostAndPort> nodes = new HashSet<>();
nodes.add(new HostAndPort("192.168.1.3", 6379));
nodes.add(new HostAndPort("192.168.1.4", 6379));
nodes.add(new HostAndPort("192.168.1.5", 6379)); // 配置连接池
JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
jedisPoolConfig.setMaxTotal(5);
jedisPoolConfig.setMaxIdle(3);
jedisPoolConfig.setMinIdle(2); // 创建jediscluster,传入节点列表和连接池配置
JedisCluster cluster = new JedisCluster(nodes, jedisPoolConfig); // 和jedis的使用方式几乎一样
cluster.set("name", "nameDemo2121"); // 使用完毕后,不需要释放连接
// cluster.close();
}
}

  执行程序,在命令行中登录到redis集群查看

  

  

redis连接池——JedisPool和JedisCluster的介绍与使用的更多相关文章

  1. 三:Redis连接池、JedisPool详解、Redisi分布式

    单机模式: package com.ljq.utils; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; ...

  2. Java与redis交互、Jedis连接池JedisPool

    Java与redis交互比较常用的是Jedis. 先导入jar包: commons-pool2-2.3.jar jedis-2.7.0.jar 基本使用: public class RedisTest ...

  3. redis连接池(JedisPool)资源归还及timeout详解

    转载. https://blog.csdn.net/yaomingyang/article/details/79043019 一.连接池资源类详解都在注释上 package redis.v1.clie ...

  4. java操作redis redis连接池

    redis作为缓存型数据库,越来越受到大家的欢迎,这里简单介绍一下java如何操作redis. 1.java连接redis java通过需要jedis的jar包获取Jedis连接. jedis-2.8 ...

  5. redis连接池操作

    /** * @类描述 redis 工具 * @功能名 POJO * @author zxf * @date 2014年11月25日 */public final class RedisUtil { p ...

  6. Redis连接池

    package com.lee.utils; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPool; impor ...

  7. Redis】Java中使用Jedis操作Redis(Maven导入包)、创建Redis连接池

    如果我们使用Java操作Redis, 需要确保已经安装了 redis 服务及 Java redis 驱动. Maven项目可以直接在pom.xml中加入jedis包驱动: <!-- https: ...

  8. redis连接池 jedis-2.9.0.jar+commons-pool2-2.4.2.jar

    java使用Redis连接池  jar包为 jedis-2.9.0.jar+commons-pool2-2.4.2.jar jar下载地址 package com.test; import redis ...

  9. Java Redis 连接池 Jedis 工具类

    import org.slf4j.Logger; import org.slf4j.LoggerFactory; import redis.clients.jedis.Jedis; import re ...

随机推荐

  1. pgrep,pkill

    pgrep, pkill - look up or signal processes based on name and other attributes 根据名称和其它属性来查找进程 pgrep: ...

  2. USB之设备插入波形变化2

    =============  本系列参考  ============= <圈圈教你玩USB>.<Linux那些事儿之我是USB> 协议文档:https://www.usb.or ...

  3. scrapy框架爬取开源中国项目大厅所有的发布项目。

    本文爬取的字段,项目名称,发布时间,项目周期,应用领域,最低报价,最高报价,技术类型 1,items中定义爬取字段. import scrapy class KaiyuanzhongguoItem(s ...

  4. 实验八 《Coderxiaoban团队》团队作业4:基于原型的团队项目需求调研与分析

    实验八 <Coderxiaoban团队>团队作业4:基于原型的团队项目需求调研与分析 项目 内容 这个作业属于哪个课程 任课教师博客主页链接 这个作业的要求在哪里 实验八 团队作业4:基于 ...

  5. AFL Fuzz安装及完成一次简单的模糊测试

    关于AFL fuzz AFL fuzz是一个模糊测试工具,它封装了一个GCC/CLang编译器,用于对被测代码重新编译的过程中进行插桩.插桩完毕后,AFL fuzz就可以给其编译过的代码输入不同的参数 ...

  6. WebSocket 实现前后端通信的笔记

    之前在做站内信时,用到了 WebSocket ,整理了一些笔记分享如下.本文基于 SpringBoot 2.1.5,本文不涉及环境搭建. 引入依赖 在 Spring 中要使用 WebSocket 功能 ...

  7. P4848 崂山白花蛇草水

    题意:支持修改的矩形第 \(k\) 大. 题解:动态开点权值线段树 套 Kd-tree. 然后也没什么难的但就是写不对...调了两天才调出来然后发现跑的巨慢,于是又%了一发Claris'题解,跑的真快 ...

  8. 2019.12.06 java基础

    JRE:运行环境(包含JVM(Java Virtual Machine)- Java虚拟机和核心类库) JDK: JAVA语言的软件开发工具包(Java Development Kit) Dos命令行 ...

  9. 23-ESP8266 SDK开发基础入门篇--编写Android TCP客户端 , 加入消息处理

    https://www.cnblogs.com/yangfengwu/p/11203546.html 先做接收消息 然后接着 public class MainActivity extends App ...

  10. CF1237C2 【Balanced Removals (Harder)】

    这么妙的题怎么没人发题解啊 首先这是三维的,我们可以对其进行降维打击 先考虑一维怎么做? 我们可以对其该维坐标进行排序,按照顺序输出,可能会多余一个 那拓展到二维呢? 我们可以把它转化成一维,分成很多 ...