Jedis介绍及常见问题分析

    xiaoxiao2026-02-22  16

    Jedis介绍

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

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

    如何使用

    下载官方最新编译的稳定版本代码: http://github.com/xetorthio/jedis/releases 直接在maven工程里面配置依赖如下: <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链接是否过多如果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。

    相关资源:python入门教程(PDF版)
    最新回复(0)