开发者社区 > 云原生 > 正文

当注册十数个以上服务到redis注册中心时,存在很大概率的死锁,程序未能完成所有服务的注册。

当注册十数个以上服务到redis注册中心时,存在很大概率的死锁,程序未能完成所有服务的注册。

@Override
public void doRegister(URL url) {
    String key = toCategoryPath(url);
    String value = url.toFullString();
    String expire = String.valueOf(System.currentTimeMillis() + expirePeriod);
    boolean success = false;
    RpcException exception = null;
    for (Map.Entry<String, JedisPool> entry : jedisPools.entrySet()) {
        JedisPool jedisPool = entry.getValue();
        try {
            Jedis jedis = jedisPool.getResource(); //  **HERE! 卡在这里,jedis资源耗尽了?**
            try {
                jedis.hset(key, value, expire);
                jedis.publish(key, Constants.REGISTER);
                success = true;
                if (!replicate) {
                    break; //  If the server side has synchronized data, just write a single machine
                }
            } finally {
                jedis.close();
            }
        } catch (Throwable t) {
            exception = new RpcException("Failed to register service to redis registry. registry: " + entry.getKey() + ", service: " + url + ", cause: " + t.getMessage(), t);
        }
    }
    if (exception != null) {
        if (success) {
            logger.warn(exception.getMessage(), exception);
        } else {
            throw exception;
        }
    }
}

原提问者GitHub用户the3rd

展开
收起
大圣东游 2023-05-11 20:27:30 215 0
1 条回答
写回答
取消 提交回答
  • 知道了,追加在address后, redis://127.0.0.1:6379?max.total=100

    原回答者GitHub用户Leorowe

    2023-05-12 12:09:32
    赞同 展开评论 打赏

阿里云拥有国内全面的云原生产品技术以及大规模的云原生应用实践,通过全面容器化、核心技术互联网化、应用 Serverless 化三大范式,助力制造业企业高效上云,实现系统稳定、应用敏捷智能。拥抱云原生,让创新无处不在。

相关电子书

更多
Redis在唯品会的应用实践——架构演进与功能定制 立即下载
微博的Redis定制之路 立即下载
云数据库Redis版的开源之路 立即下载