您的位置:首页 > 新闻 > 资讯 > RabbitMQ实践——利用一致性Hash交换器做负载均衡

RabbitMQ实践——利用一致性Hash交换器做负载均衡

2025/3/11 2:46:42 来源:https://blog.csdn.net/breaksoftware/article/details/139666730  浏览:    关键词:RabbitMQ实践——利用一致性Hash交换器做负载均衡

大纲

  • 开启一致性Hash交换器
  • 创建交换器
  • 创建绑定关系
  • 测试
  • 参考资料

在《RabbitMQ实践——交换器(Exchange)和绑定(Banding)》中,我们熟悉了Direct、Fanout、Topic和Header这4种系统默认支持的交换器。这些交换器基本可以满足我们日常的需求。我们还可以添加一些设计,让其支持更加丰富的功能。比如我们可以通过Topic的设计,达到“负载均衡”的功能。
如果不想做这样的设计,可以使用RabbitMQ自身携带,只是未开启的一致性Hash交换器,来实现对队列的平均分流。这样我们让更多消费者订阅不同的队列,来增加整理系统的处理能力。
在这里插入图片描述

开启一致性Hash交换器

在RabbitMQ所在的服务终端上执行:

sudo -H -u rabbitmq bash -c "/usr/lib/rabbitmq/bin/rabbitmq-plugins enable rabbitmq_consistent_hash_exchange"

在这里插入图片描述

创建交换器

这样我们就可以新建该类型交换器
在这里插入图片描述

创建绑定关系

在一致性Hash交换器中,绑定关系的Routing key被当做权重使用。如果数值越大,被路由到对应的队列上的消息也越多。
本例我们测试“负载均衡”的场景,所以把三个队列的路由权重都设置的比较低且一致。
在这里插入图片描述

测试

public boolean sendToXConsistentHashExchange(String exchangeName, Long count) {for (int i = 0; i < count; i++) {int hash = Integer.hashCode(i);rabbitTemplate.convertAndSend(exchangeName, String.valueOf(hash), "Message " + i);}return true;
}

然后发送10,0000条消息
在这里插入图片描述
可以看到消息被相对均衡的路由到各个队列上
在这里插入图片描述

参考资料

  • https://github.com/rabbitmq/rabbitmq-consistent-hash-exchange
  • https://github.com/rabbitmq/rabbitmq-server/tree/main/deps/rabbitmq_consistent_hash_exchange

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com