欢迎来到第壹文秘! | 帮助中心 分享价值,成长自我!
第壹文秘
全部分类
  • 幼儿/小学教育>
  • 中学教育>
  • 高等教育>
  • 研究生考试>
  • 外语学习>
  • 资格/认证考试>
  • 论文>
  • IT计算机>
  • 法律/法学>
  • 建筑/环境>
  • 通信/电子>
  • 医学/心理学>
  • ImageVerifierCode 换一换
    首页 第壹文秘 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    Redis常见客户端异常汇总(Jedis篇).docx

    • 资源ID:1033014       资源大小:22.27KB        全文页数:7页
    • 资源格式: DOCX        下载积分:5金币
    快捷下载 游客一键下载
    账号登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    下载资源需要5金币
    邮箱/手机:
    温馨提示:
    快捷下载时,如果您不填写信息,系统将为您自动创建临时账号,适用于临时下载。
    如果您填写信息,用户名和密码都是您填写的【邮箱或者手机号】(系统自动生成),方便查询和重复下载。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    Redis常见客户端异常汇总(Jedis篇).docx

    JediS是RediS的java版本的客户端实现。在RediS客户端的使用过程中,无论是客户端使用不当或者RediS服务端出现问题,客户端会反应出一些异常,本文分析了Jedis使用过程中常见的异常情况。一、无法从连接池获取到连接JediSPooI中的JediS对象个数是有限的,默认是8个。这里假设使用的默认配置,如果有8个JediS对象被占用,并且没有归还,如果调用者还要从JediSPoOl中借用Jedis,就需要进行等待(例如设置了maxWaitMillis>O),如果在maxWaitMillis时间内仍然无法获取到Jedis对象就会抛出如下异常。redis.clients.jedis.exceptions.JedisconnectionExceptionzcouldnotgetaresourcefromthepool.Causedbyijava.Uti1.NosuchElementExceptionzTmons.pool2.impl.GenericObjectPool.borrowObject(GenericObjectPool.java:449)还有一种情况,就是设置了blockWhenExhausted=false,那么调用者发现池子中没有资源时,会立即抛出异常不进行等待下面的异常就是blockWhenExhausted=false时的效果。redis.clients.jedis.exceptions.JedisconnectionExceptionzcouldnotgetaresourcefromthepool.Causedby:java.util.NoSuchElementException:Pmons.pool2.impl.GenericObjectPool.borrowObject(GenericObjectPool.java:464)对于这个问题,需要重点讨论的是为什么连接池没有资源了,造成没有资源的可能的原因非常多1 .客户端:高并发下连接池设置过小,出现供不应求,所以会出现上面的错误,但是正常情况下只要比默认的最大连接数(8个)多一些即可,因为正常情况下JediSPOoI以及Jedis的处理效率足够高。2 .客户端:没有正确使用连接池,比如没有进行释放,例如下面代码所示:定义JediSPOol,使用默认的连接池配置。GenericObjectPoolConfigpoolConfig=newGenericObjectPoolConfig();JedisPooljedisPool=newJedisPool(poolConfig,"l27.0.0.,6379)jJedisPool借用8次连接,但是没有执行归还操作。for(inti=0;i<8;i+)Jedisjedis=null;tryjedisjedisPool.getResource();jedis.ping();Catch(Exceptione)e.printStackTrace();)当调用者再向连接池借用Jedis时(如下操作),就会抛出异常:jedisPool.getResource().ping();3 .客户端:存在慢查询操作,这些慢查询持有的Jedis对象归还速度会比较慢,造成池子满了。4 .服务端:客户端是正常的,但是RediS服务端由于一些原因造成了客户端命令执行过程的阻塞,也会使得客户端抛出这种异常。可以看到造成这个异常的原因是多个方面的,不要被异常的表象所迷惑,而且并不存在万能钥匙能解决所有问题,开发和运维只能不断加强对于RediS的理解,顺藤摸瓜逐渐找到问题所在。二、客户端读写超时JediS在调用RediS时,如果出现了读写超时后,会出现下面的异常:redis.clients.jedis.exceptions.JedisConnectionException:.SocketTimeoutExceptioniReadtimedout造成该异常的原因也有以下几种:读写超时设置的过短。命令本身就比较慢。客户端与服务端网络不正常。Redis自身发生阻塞。三、客户端连接超时JediS在调用RediS时,如果出现了读写超时后,会出现下面的异常:redis.clients.jedis.exceptions.JedisConnectionExceptionJ.SocketTimeoutExceptioniconnecttimedout造成该异常的原因也有以下几种:连接超时设置的过短。RediS发生阻塞,造成tcp-backlog已满,造成新的连接失败。客户端与服务端网络不正常。四、客户端缓冲区异常JediS在调用RediS时,如果出现客户端数据流异常,会出现下面的异常。redis.clients.jedis.exceptions.JedisConnectionException:Unexpectedendofstream造成这个异常原因可能有如下几种:1 .输出缓冲区满。例如将普通客户端的输出缓冲区设置为IMIM60:configsetclient-output-buffer-limit,'nonall048576104857660slave2684354566710886460PUbSUb33554432838860860”如果使用get命令获取一个bigkey(例如3M),就会出现这个异常。2 .长时间闲置连接被服务端主动断开,可以查询timeout配置的设置以及自身连接池配置是否需要做空闲检测。3 .不正常并发读写:JediS对象同时被多个线程并发操作,可能会出现上述异常。五、1.Ua脚本正在执行如果Redis当前正在执行1.ua脚本,并且超过了lua-time-limit,此时JediS调用RediS时,会收到下面的异常。对于如何处理这类问题(1.UaIUa-time-limit配置之前章节已经介绍了)redis.clients.jedis.exceptions.JedisDataException:BUSYRedisisbusyrunningascript.YoucanonlycallSCRIPTKI1.1.orSHUTDOWNNOSAVE.六、RediS正在加载持久化文件JediS调用RediS时,如果RediS正在加载持久化文件,那么会收到下面的异常。redis.clients.jedis.exceptions.JedisDataExceptioni1.OADINGRedisisloadingthedatasetinmemory七、Redis使用的内存超过maxmemory配置Jedis调用Redis执行写操作时,如果Redis的使用内存大于maxmemory的设置,会收到下面的异常,此时应该调整maxmemory并找到造成内存增长的原因(maxmemory之前章节已经介绍了)redis.clients.jedis.exceptions.JedisDataException:OOMcommandnotallowedwhenusedmemory>,maxmemory'.八、客,端连接数过大如果客户端连接数超过了maxclients,新申请的连接就会出现如下异常:redis.clients.jedis.exceptions.JedisDataException:ERRmaxnumberofclientsreached此时新的客户端连接执行任何命令,返回结果都是如下:127.0.0.k6379>gethello(error)ERRmaxnumberofclientsreached这个问题可能会比较棘手,因为此时无法执行RediS命令,一般来说可以从两个方面进行着手。1 .客户端:如果maxclients参数不是很小的话,应用方的客户端连接数基本不会超过maxclients,通常来看是由于应用方对于Redis客户端使用不当造成的。此时如果应用方是分布式结构的话,可以通过下线部分应用节点(例如占用连接较多的节点),使得Redis的连接数先降下来。从而让绝大部分节点可以正常运行,此时在再通过查找程序bug或者调整maxclients进行问题的修复。2 .服务端:如果此时客户端无法处理,而当前Redis为高可用模式(例如RedisSentinel和RedisCluster),可以考虑将当前Redis做故障转移。此问题不存在确定的解决方式,但是无论从哪个方面进行处理,故障的快速恢复极为重要,当然更为重要的是找到问题的所在,否则一段时间后客户端连接数依然会超过maxclientso附GenericobjectPoolConfig的重要属性序号参数名含义默认值1maxActive连接池中最大连接数82maxldle连接池中最大空闲的连接数83minldle连接池中最少空闲的连接数04maxWaitMillis当连接池资源用尽后,调用者的最大等待时间(单位为毫秒),一般不建议使用默认值-1:表示永远不超时,一直等。5JmxEnabled是否开启jmx监控,如果应用开启了jmx端口并且JmxEnabled设置为true,就可以通过jconsole或者jvisualvm看到关于连接池的相关统计,有助于了解连接池的使用情况,并且可以针对其做监控统计true6minEvictableIdleTimcMillis连接的最小空闲时间,达到此值后空闲连接将被移除30分钟7numTestsPerEvictionRun做空闲连接检测时,每次的采样数38IestOnBorrow向连接池借用连接时是否做连接有效性检测(Ping),无效连接会被移除,每次借用多执行一次ping命令false序号参数名含义默认值9IestOnRetum向连接池归还连接时是否做连接有效性检测(Ping),无效连接会被移除,每次归还多执行一次ping命令false10IestWhileIdIe向连接池借用连接时是否做连接空闲检测,空闲超时的连接会被移除false11timeBetweenEvictionRunsMillis空闲连接的检测周期(单位为毫秒)-1:表示不做检测12blockWhenExhausted当连接池用尽后,调用者是否要等待,这个参数是和maxWaitMillis对应的,只有当此参数为true时,InaxWaitMillis才会生效Redis客户端处理介绍了有关RediS如何从网络层的角度处理客户端的信息:连接,超时,缓冲区以及其他类似主题。本文包含的信息仅适用于Redis版本2.6或更高版本。如何接受客户端的连接?Redis通过监听一个TCP端口或者Unixsocket的方式来接收客户端的连接,当一个新的客户端连接建立后,RedisServer会执行以下一些操作:客户端socket会被设置为非阻塞模式,因为Redis在网络事件处理上采用的是非阻塞多路复用模型。设置TCP_N0DE1.AY属性,禁用Nagle算法,确保在我们的连接不要延迟创建一个可读的文件事件,以便于SOCket传送新数据时立即收集客户端查询初始化客户端连接后,Redis核实可能同时处理的连接数是否已达到上限,这个上限是在RediS.conf配置文件中通过maxclients命令来设置的。万一因为已达到最大连接数的上限而不能

    注意事项

    本文(Redis常见客户端异常汇总(Jedis篇).docx)为本站会员(p**)主动上传,第壹文秘仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知第壹文秘(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2023 1wenmi网站版权所有

    经营许可证编号:宁ICP备2022001189号-1

    本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。第壹文秘仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知第壹文秘网,我们立即给予删除!

    收起
    展开