go stomp客户端中ActiveMQ的故障转移URI

时间:2016-03-09 16:18:07

标签: go activemq stomp

我们如何使用Go中的故障转移stomp连接URI连接到ActiveMQ? 使用Go-Stomp客户端,我尝试了以下代码,但无法连接。

if conn, err = stomp.Dial("tcp", "failover:(tcp://10.01.02.03:61613,tcp://10.04.05.06:61613)?startupMaxReconnectAttempts=2"); err != nil {
        panic(fmt.Sprintf("Could not connect to ActiveMQ using brokerUri %v. Can not continue.", Config.Broker.URI))
    }

2 个答案:

答案 0 :(得分:0)

你收到的错误是什么? 我不相信您的拨号格式是正确的: Go-Stomp Dial使用底层的net.Dial

func Dial(网络,addr字符串,opts ... func(* Conn)错误)(* Conn,error){

c,错误:= net.Dial(网络,地址)

底层的net.Dial文档陈述

对于TCP和UDP网络,地址的格式为host:port。如果host是文字IPv6地址,则必须用方括号括起来,如" [:: 1]:80"或" [ipv6-host%zone]:80"。函数JoinHostPort和SplitHostPort以这种形式操作地址。如果主机为空,如":80",则假定本地系统。

没有故障转移:语法

答案 1 :(得分:0)

由于缺乏对故障转移的支持,不得不编写一些代码来实现所需的结果。

//connect to ActiveMQ using failover approach
    var err error
    for _, uri := range ["10.01.02.03:61613","10.04.05.06:61613", {
        if err = connect(uri); err == nil {
            break
        }
    }
    if conn == nil {
        panic(fmt.Sprintf("Could not connect to ActiveMQ using brokerUri. Can not continue."))
    }

func connect(brokerIp string) (err error) {
    log.Printf("Attempting to connect to ActiveMQ node %v", brokerIp)
    if conn, err = stomp.Dial("tcp",
        brokerIp,
        stomp.ConnOpt.Login(Broker.User, Broker.Password)); err != nil {
        log.Printf("Faild to connect to ActiveMQ using %v", brokerIp)
    }
    if err == nil {
        log.Printf("Successfully connected to ActiveMQ node %v", brokerIp)
    }
    return
}