gpt4 book ai didi

c# - C# 的 TIBCO EMS 故障转移重新连接 (TIBCO.EMS.dll)

转载 作者:可可西里 更新时间:2023-11-01 08:23:09 30 4
gpt4 key购买 nike

我们有一个 TIBCO EMS 解决方案,它在 2-4 服务器环境中使用内置服务器故障转移。如果 TIBCO 管理员将服务从一台 EMS 服务器故障转移到另一台,则连接应该会在 EMS 服务级别自动转移到新服务器。对于我们使用 EMS 服务的 C# 应用程序,这不会发生 - 我们的用户连接在故障转移后不会转移到新服务器,我们不确定原因。

我们的应用程序仅在启动时连接到 EMS,因此如果 TIBCO 管理员在用户启动我们的应用程序后发生故障转移,他们的用户需要重新启动应用程序才能重新连接到新服务器(我们的 EMS 连接使用的服务器字符串包括所有 4生产 EMS 服务器 - 如果第一次尝试失败,它将移动到字符串中的下一个服务器并再次尝试。

我正在寻找一种自动方法,如果它检测到连接已断开,将尝试定期重新连接到 EMS,但我不确定如何最好地做到这一点。

有什么想法吗?我们使用的是 TIBCO.EMS.dll 版本 4.4.2 和 .Net 2.x(SmartClient 应用程序)

如有任何帮助,我们将不胜感激。

最佳答案

首先,是的,我正在回答我自己的问题。然而,重要的是要注意,如果没有 ajmastrean,我将无处可去。非常感谢!

一个:ConnectionFactory.SetReconnAttemptCount、SetReconnAttemptDelay、SetReconnAttemptTimeout 应适当设置。我认为默认值重试太快(重试之间大约 1/2 秒)。由于网络存储等原因,我们的 EMS 服务器可能需要很长时间才能进行故障转移 - 因此以 1/2 秒的间隔重试 5 次远远不够长。

两个:我认为启用客户端-服务器和服务器-客户端心跳很重要。无法验证,但如果没有这些,客户端可能不会收到服务器离线或切换到故障转移模式的通知。当然,这是 EMS 的服务器端设置。

三:您可以通过设置 Tibems.SetExceptionOnFTSwitch(true) 来监视故障转移事件;然后连接一个异常事件处理程序。在单服务器环境中时,您将看到“连接已终止”消息。但是,如果您处于容错多服务器环境中,您将看到:“连接已执行容错切换到”。您并非严格需要此通知,但它可能很有用(尤其是在测试中)。

四个:EMS 文档中显然不清楚,连接重新连接在单服务器环境中不起作用。您需要处于多服务器、容错环境中。然而,有一个技巧。您可以将同一台服务器放入连接列表两次 - 我知道这很奇怪,但它可以工作,并且可以启用内置的重新连接逻辑。

一些代码:

private void initEMS()
{
Tibems.SetExceptionOnFTSwitch(true);
_ConnectionFactory = new TIBCO.EMS.TopicConnectionFactory(<server>);
_ConnectionFactory.SetReconnAttemptCount(30); // 30retries
_ConnectionFactory.SetReconnAttemptDelay(120000); // 2minutes
_ConnectionFactory.SetReconnAttemptTimeout(2000); // 2seconds
_Connection = _ConnectionFactory.CreateTopicConnectionM(<username>, <password>);
_Connection.ExceptionHandler += new EMSExceptionHandler(_Connection_ExceptionHandler);
}
private void _Connection_ExceptionHandler(object sender, EMSExceptionEventArgs args)
{
EMSException e = args.Exception;
// args.Exception = "Connection has been terminated" -- single server failure
// args.Exception = "Connection has performed fault-tolerant switch to <server url>" -- fault-tolerant multi-server
MessageBox.Show(e.ToString());
}

关于c# - C# 的 TIBCO EMS 故障转移重新连接 (TIBCO.EMS.dll),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/187857/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com