• 首次使用Redis记录【3】


    根据上文配置使用后 

    会出现如下问题:

        this.jedis = this.jedisPool.getResource();方法长时间无响应且控制台不报错,方法堵塞。

     实际情况:

        大概调用了该方法八九次之后就会开始堵塞,无响应。

    原因:类似数据库连接池获取事务或者IO流对象,用完之后需要关闭。 

    解决:每次使用完资源之后关闭资源,this.jedis.close()后即可。

    网上参考:

    jedisPool.getResource()方法长时间无响应并且不报错,方法阻塞

      这个锅真的是蓝瘦,,,表现是项目重启后一开始可以,过段时间,哎,不行了,,,,查了一半天发现,原因在于jedis连接用完了,然后默认给阻塞了,然后直到获得连接。看下我的错误代码

    //获得连接
    Jedis jedis = jedisPool.getResource();
    log.info("get jedis success");
    jedis.set(wlId, encryUser);
    jedis.expire(wlId,1800);

    然后我跑了200个for循环,调用他,排查错误,大概就是到48次的时候,阻塞掉了,不报错也没反应,说明jedis连接池在我电脑配置上是开了48个以内。
    查看他的官网文档,其中有一段new JedisCluster(hpset, 30)中默认了MaxWaitMillis为-1。,

    BlockWhenExhausted:连接耗尽时是否阻塞, false报异常,ture阻塞直到超时, 默认true
    MaxWaitMillis:获取连接时的最大等待毫秒数(如果设置为阻塞时
    BlockWhenExhausted,如果超时就抛异常,小于零:阻塞不确定的时间, 默认-1

    BlockWhenExhauste这个方法默认参数-1,就是说当阻塞的时候我阻塞多久啊,默认永久阻塞。而一开始没有阻塞是因为一开始连接并没有耗尽,这个就是原因所在。咱们修改配置使得阻塞短时间或者不阻塞或者在你用完jedis的时候关闭连接就好了啊,具体情况视你的业务场景而定,我是把我的连接给关闭了。
      修改后的代码

    //获得连接
    Jedis jedis = jedisPool.getResource();
    log.info("get jedis success");
    jedis.set(wlId, encryUser);
    jedis.expire(wlId,1800);
    //用完后乖乖的关掉,就是因为它
    jedis.close();

  • 相关阅读:
    【Oracle11g】06_网络配置
    【Python3 爬虫】U20_正则表达式爬取古诗文网
    【Oracle11g】05_完整性约束
    【Python3 爬虫】U19_正则表达式之re模块其他函数
    【Python3 爬虫】U18_正则表达式之group分组
    【Python3 爬虫】U17_正则表达式之转义字符和原生字符
    【Python3 爬虫】U16_正则表达式之开始结束和或语法
    常见的概率分布
    广义线性模型
    gamma函数及相关其分布
  • 原文地址:https://www.cnblogs.com/UUUz/p/10907356.html
Copyright © 2020-2023  润新知