Jedis介绍及常见问题分析

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
云数据库 Tair(兼容Redis),内存型 2GB
云原生多模数据库 Lindorm,多引擎 多规格 0-4节点
简介: 本文主要介绍Jedis的使用方法及常见问题的排查分析方法

Jedis介绍

Jedis是一个开源的Redis数据库客户端,兼容Redis 2.8.x和3.xx,Jedis提供了以下特性:

  • 排序
  • 链接管理
  • 不同类型的value的命令处理
  • String类型的命令处理
  • Hashes类型的命令处理
  • Lists类型的命令处理
  • Sets类型的命令处理
  • Sorted Sets类型的命令处理
  • 事务
  • 批量命令处理
  • 订阅/发布
  • 持久化的控制命令
  • 远程控制命令
  • 分片(MD5,MurmurHash)
  • 集群的Key-tags功能
  • 集群的批量命令处理
  • 脚本的批量命令处理
  • Redis集群支持

如何使用

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

直连模式

import redis.clients.jedis.Jedis;
public class jedistest {
public static void main(String[] args) {
    try {
        String host = "xx.kvstore.aliyuncs.com";//控制台显示访问地址
        int port = 6379;
        Jedis jedis = new Jedis(host, port);
        //鉴权信息
        jedis.auth("password");//password
        String key = "redis";
        String value = "aliyun-redis";
        //select db默认为0
        jedis.select(1);
        //set一个key
        jedis.set(key, value);
        System.out.println("Set Key " + key + " Value: " + value);
        //get 设置进去的key
        String getvalue = jedis.get(key);
        System.out.println("Get Key " + key + " ReturnValue: " + getvalue);
        jedis.quit();
        jedis.close();
    } catch (Exception e) {
        e.printStackTrace();
    }
}
}

连接池模式

JedisPoolConfig config = new JedisPoolConfig();
//最大空闲连接数, 应用自己评估,不要超过ApsaraDB for Redis每个实例最大的连接数
config.setMaxIdle(200);
//最大连接数, 应用自己评估,不要超过ApsaraDB for Redis每个实例最大的连接数
config.setMaxTotal(300);
config.setTestOnBorrow(false);
config.setTestOnReturn(false);
String host = "*.aliyuncs.com";
String password = "密码";
JedisPool pool = new JedisPool(config, host, 6379, 3000, password);
Jedis jedis = null;
try {
    jedis = pool.getResource();
    /// ... do stuff here ... for example
    jedis.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 {
    if (jedis != null) {
        jedis.close();
    }
}
/// ... when closing your application:
pool.destroy();

常见出错问题排查

连接池错误

使用Jedis连接池模式的时候容易出现的错误是无法获取连接池

redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource from the pool

对于这类问题的原因有几类,可以根据以下一一进行排查

网络检查

首先检查是否网络问题,可以通过telnet host 6379进行简单测试,连上之后auth 密码回车查看是否返回+OKrn,如果能够正确返回继续检查ping请求或者读写请求是否正常返回,操作多次排查网络问题影响。

JedisPool连接数设置检查

JedisPool使用的时候需要进行连接池的设置,用户在超过MaxTotal连接数的时候也会出现获取不到连接池的情况,这个时候可以在访问客户端上通过netstat -an | grep 6379 | grep EST | wc -l 查看链接的客户端链接数目,并且比较这个数目和JedisPool配置的MaxTotal的值,如果没有明显超过或者接近就可以排除JedisPool连接池配置的影响。

JedisPool连接池代码检查

对于JedisPool连接池的操作,每次getResource之后需要调用returnResource或者close进行归还,可以查看代码是否有正确使用,代码sample可以参考上面的

检查是否发生nf_conntrack丢包

通过dmesg检查客户端是否有异常

nf_conntrack: table full, dropping packet

如果发生nf_conntract丢包可以通过修改设置sysctl -w net.netfilter.nf_conntrack_max=120000

检查是否TIME_WAIT问题

通过ss -s 查看time wait链接是否过多
screenshot.png
如果TIME_WAIT过多可以修改以下参数

sysctl -w net.ipv4.tcp_max_tw_buckets=180000
sysctl -w net.ipv4.tcp_tw_recycle=1

检查是否DNS问题

通过在/etc/hosts文件直接绑定host地址,绑定完成之后查看问题是否还存在,如果还存在则不是DNS解析问题

192.168.1.1  *.redis.rds.aliyuncs.com

总结

如果按照上面排查之后还有问题可以通过抓包并将报错时间点,报错信息,抓包文件发送给阿里云售后同学进行分析。抓包命令为sudo tcpdump -i eth0 tcp and port 6379 -n -nn -s 74 -w redis.cap。

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
3月前
|
NoSQL 安全 Java
Lettuce的特性和内部实现问题之Lettuce连接与Jedis连接在线程安全性的问题如何解决
Lettuce的特性和内部实现问题之Lettuce连接与Jedis连接在线程安全性的问题如何解决
|
4月前
|
NoSQL Java Redis
|
4月前
|
Java Redis 数据安全/隐私保护
Redis14----Redis的java客户端-jedis的连接池,jedis本身是线程不安全的,并且频繁的创建和销毁连接会有性能损耗,最好用jedis连接池代替jedis,配置端口,密码
Redis14----Redis的java客户端-jedis的连接池,jedis本身是线程不安全的,并且频繁的创建和销毁连接会有性能损耗,最好用jedis连接池代替jedis,配置端口,密码
|
NoSQL Java Linux
|
弹性计算 NoSQL 安全
Jedis那么低性能,还在用?赶紧换上 lettuce 吧!
Jedis那么低性能,还在用?赶紧换上 lettuce 吧!
|
NoSQL Java 中间件
Jedis基础详解
Jedis基础详解
108 0
|
NoSQL Java Redis
jedis-jedis 常规操作演示 | 学习笔记
快速学习jedis-jedis 常规操作演示
|
NoSQL 数据可视化 Java
jedis-jedis 简介 | 学习笔记
快速学习 jedis-jedis 简介
|
监控 NoSQL Java
jedis-程序代码实现| 学习笔记
快速学习 jedis-程序代码实现
|
NoSQL JavaScript Java
手写一个Jedis以及JedisPool
手写一个Jedis以及JedisPool
131 0