1. 程式人生 > >基於etcd的Rabbitmq隊列訂閱負載均衡

基於etcd的Rabbitmq隊列訂閱負載均衡

執行 發布 scrip man 終端 imp wget require 存在

go-qb

Load balancer for rabbitmq queue subscribing

Feature

  • Rabbitmq queue subscription load balancing based on etcd

Installation

install:

go get -u github.com/vc60er/go-qb

import:

import "github.com/vc60er/go-qb"

Quickstart

type MyQueueOnMsg struct {
}

func (pthis *MyQueueOnMsg) OnMsg(msg []byte
) { log.Info("OnMsg:", string(msg)) } func main() { flag.Parse() msg := &MyQueueOnMsg{} endpoints := []string{"http://127.0.0.1:2379", "http://127.0.0.1:22379", "http://127.0.0.1:32379"} amqp := "amqp://guest:[email protected]:5672/" queue_ids := []string
{"queue.1", "queue.2", "queue.3", "queue.4", "queue.5", "queue.6", "queue.7", "queue.8"} ip := "127.0.0.1" port := 8800 qb, err := qb.NewQueueBalance(endpoints, amqp, msg, queue_ids, ip, port) if err != nil
{ log.Fatalf("%s: %s", msg, err) } defer qb.Close() qb.Run() c := make(chan os.Signal, 1) signal.Notify(c, os.Interrupt) s := <-c log.Info(s) }

Architecture diagram

技術分享圖片

選型

embedding etcd
好處:
省的部署etcd服務
不存在與etcd直接的連接,所以不會擔心這裏出故障

壞處:
只有兩個服務,且出現連接故障時候,難以選master


etcd:
好處
配置信息可以通過終端查看
配置服務與執行服務分離

測試

安裝rabbitmq

wget https://dl.bintray.com/rabbitmq/rpm/erlang/20/el/7/x86_64/erlang-20.1.7.1-1.el7.centos.x86_64.rpm
wget https://github.com/rabbitmq/rabbitmq-server/releases/download/v3.7.2/rabbitmq-server-3.7.2-1.el7.noarch.rpm.asc
wget https://github.com/rabbitmq/rabbitmq-server/releases/download/v3.7.2/rabbitmq-server-3.7.2-1.el7.noarch.rpm


rpm -i erlang-20.1.7.1-1.el7.centos.x86_64.rpm
yum install  rabbitmq-server-3.7.2-1.el7.noarch.rpm

rabbitmq-plugins enable rabbitmq_management

/etc/rabbitmq/rabbitmq.conf 
loopback_users.guest = false

http://59.110.154.248:15672
guest
guest

cd example

運行etcd
goreman start

運行consuer1
make run1

運行consuer2
make run2

運行consuer3
make run2

向mq發布消息
make pub

觀察運行狀態
make watch
Every 1.0s: ./cli.sh get --prefix /qb                                                                                                                     chengningMBP.lan: Thu Jan 18 20:48:05 2018

/qb/consumer_require_queue_count/consumer_127.0.0.1_3632541266441280445
3
/qb/consumer_require_queue_count/consumer_127.0.0.1_3632541266441280505
3
/qb/consumer_require_queue_count/consumer_127.0.0.1_4703553552825333576
2
/qb/consumer_status/consumer_127.0.0.1_3632541266441280445
queue.7,queue.8,queue.4
/qb/consumer_status/consumer_127.0.0.1_3632541266441280505
queue.2,queue.5,queue.6
/qb/consumer_status/consumer_127.0.0.1_4703553552825333576
queue.1,queue.3
/qb/keeper_api
http://127.0.0.1:8800
/qb/lock/keeper/326961092a2e1bbd

/qb/lock/keeper/326961092a2e1bf9

/qb/lock/keeper/414661092a2e3748

/qb/queue_status/queue.1
{"Name":"queue.1","Messages":0,"Consumers":1}
/qb/queue_status/queue.2
{"Name":"queue.2","Messages":0,"Consumers":1}
/qb/queue_status/queue.3
{"Name":"queue.3","Messages":0,"Consumers":1}
/qb/queue_status/queue.4
{"Name":"queue.4","Messages":0,"Consumers":1}
/qb/queue_status/queue.5
{"Name":"queue.5","Messages":0,"Consumers":1}
/qb/queue_status/queue.6
{"Name":"queue.6","Messages":0,"Consumers":1}
/qb/queue_status/queue.7
{"Name":"queue.7","Messages":0,"Consumers":1}
/qb/queue_status/queue.8
{"Name":"queue.8","Messages":0,"Consumers":1}

基於etcd的Rabbitmq隊列訂閱負載均衡