stompest客户端启动时不自动重连ActiveMQ

最近几个月来,每当迁移ActiveMQ的时候,就遇到worker进程重启的时候无法连接上ActiveMQ. 今天调试了下,终于发现了原因。

调试环境

  • ActiveMQ 5.8,部署两个实例
  • stompest 2.1.6

现象

failover uri差不多是这样的:

failover:(tcp://10.153.75.143:61613,tcp://10.15.227.106:61613)?randomize=false

其中,10.153.75.143这个ActiveMQ实例处于未运行状态,10.15.227.106这个ActiveMQ实例处于正常运行状态。

当stompest客户端使用上面的failover配置连接ActiveMQ服务器的时候,出现如下异常:

Connecting to 10.153.75.143:61613 ...
Could not connect to 10.153.75.143:61613 [Could not establish connection [[Errno 61] Connection refused]]
Reconnect failed [Reconnect timeout: 0 attempts]
Traceback (most recent call last):
  File "main.py", line 14, in <module>
    client = BaseMQClient.factory(config)
  File "/Users/liuxiong/src/maslino/test/mq_client.py", line 67, in factory
    return cls(mq_config)
  File "/Users/liuxiong/src/maslino/test/mq_client.py", line 81, in __init__
    self.connect()
  File "/Users/liuxiong/src/maslino/test/mq_client.py", line 88, in connect
    self.client.connect(heartBeats=(0, 10 * 1000), connectTimeout=60, connectedTimeout=60)
  File "/Users/liuxiong/virtualenvs/test/lib/python2.7/site-packages/stompest/sync/client.py", line 85, in connect
    for (broker, connectDelay) in self._failover:
  File "/Users/liuxiong/virtualenvs/test/lib/python2.7/site-packages/stompest/protocol/failover.py", line 50, in __iter__
    yield broker, self._delay()
  File "/Users/liuxiong/virtualenvs/test/lib/python2.7/site-packages/stompest/protocol/failover.py", line 85, in _delay
    raise StompConnectTimeout('Reconnect timeout: %d attempts' % self._maxReconnectAttempts)
stompest.error.StompConnectTimeout: Reconnect timeout: 0 attempts

从上面的异常可以看出,stompest客户端尝试连接了服务器10.153.75.143,发现连接被拒绝,然后就抛出了个连接超时异常。

我们不是使用了failover配置吗?stompest客户端在发现服务器10.153.75.143连接不上的时候,怎么不去尝试连接服务器10.15.227.106?

解决办法

经过一番搜索,终于发现了原因所在。

ActiveMQ的文档http://activemq.apache.org/failover-transport-reference.html对连接参数startupMaxReconnectAttempts这样解释道:

A value of **-1
** denotes that the number of connection attempts at startup should be unlimited.
A value of  **>=0 
**denotes the number of reconnect attempts at startup that will be made after which an error is sent back to the client when the client makes a subsequent reconnect attempt.

大致意思是,当startupMaxReconnectAttempts为-1时,不限制初始连接重试次数;当startupMaxReconnectAttempts为0时,不重试;当startupMaxReconnectAttempts大于0时,就重试startupMaxReconnectAttempts次。并且,ActiveMQ文档描述的默认值是-1.

然后,我们看看当failover uri中没有指定startupMaxReconnectAttempts参数的时候,stompest给的默认值是多少。在stompest的代码中,有这么一段:

_SUPPORTED_OPTIONS = {
    'initialReconnectDelay': _configurationOption(int, 10)
    , 'maxReconnectDelay': _configurationOption(int, 30000)
    , 'useExponentialBackOff': _configurationOption(_bool, True)
    , 'backOffMultiplier': _configurationOption(float, 2.0)
    , 'maxReconnectAttempts': _configurationOption(int, -1)
    , 'startupMaxReconnectAttempts': _configurationOption(int, 0)
    , 'reconnectDelayJitter': _configurationOption(int, 0)
    , 'randomize': _configurationOption(_bool, True)
    , 'priorityBackup': _configurationOption(_bool, False)
    #, 'backup': _configurationOption(_bool, False), # initialize and hold a second transport connection - to enable fast failover
    #, 'timeout': _configurationOption(int, -1), # enables timeout on send operations (in miliseconds) without interruption of reconnection process
    #, 'trackMessages': _configurationOption(_bool, False), # keep a cache of in-flight messages that will flushed to a broker on reconnect
    #, 'maxCacheSize': _configurationOption(int, 131072), # size in bytes for the cache, if trackMessages is enabled
    #, 'updateURIsSupported': _configurationOption(_bool, True), # determines whether the client should accept updates to its list of known URIs from the connected broker
}

发现stompest给参数startupMaxReconnectAttempts设置的默认值是0,也就是说,当stompest刚开始连接ActiveMQ服务器时并不重试。

知道了原因,把failover uri修改成这样再试试:

failover:(tcp://10.153.75.143:61613,tcp://10.15.227.106:61613)?randomize=false,startupMaxReconnectAttempts=-1

连接日志如下:

Connecting to 10.153.75.143:61613 ...
Could not connect to 10.153.75.143:61613 [Could not establish connection [[Errno 61] Connection refused]]
Delaying connect attempt for 10 ms
Connecting to 10.15.227.106:61613 ...
Connection established
Sending CONNECT frame [headers={u'passcode': 'transcode', u'login': 'vtc', u'heart-beat': '0,10000', u'host': '', u'accept-version': '1.0,1.1'}, version=1.0]
Received CONNECTED frame [headers={u'session': u'ID:liuxiong-test-dev001-bjdxt9.qiyi.virtual-49666-1479094899264-2:3', u'heart-beat': u'10000,0', u'version': u'1.1', u'server': u'ActiveMQ/5.10.0'}, version=1.0]
Connected to stomp broker [session=ID:liuxiong-test-dev001-bjdxt9.qiyi.virtual-49666-1479094899264-2:3, version=1.1]

可见,加上参数startupMaxReconnectAttempts=-1之后,stompest客户端在发现第一个ActiveMQ实例连接不上后会尝试连接第二个ActiveMQ实例。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,319评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,801评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,567评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,156评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,019评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,090评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,500评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,192评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,474评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,566评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,338评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,212评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,572评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,890评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,169评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,478评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,661评论 2 335

推荐阅读更多精彩内容