- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在 .net Core 2.1 中编写一个控制台应用程序,我的目的是监听 ServiceBus 中某个主题的消息,并使用 NEST api 处理到达 Elasticsearch 的新消息(NEST 可能与我的问题无关,但我想保持透明)。
我在 ServiceBus 中的主题实体称为“test”,我有一个订阅也称为“test”(完整路径为“test/subscriptions/test”)。
在我的 .net Core 控制台应用程序中,我有以下 NuGet 引用:
<PackageReference Include="Microsoft.Azure.ServiceBus" Version="3.2.1" />
<PackageReference Include="NEST" Version="6.4.1" />
<PackageReference Include="Newtonsoft.Json" Version="12.0.1" />
在使用 .net Standard ServiceBus Api 时,我遇到一个非常奇怪的问题,经常出现更新锁定错误:
Message handler encountered an exception Microsoft.Azure.ServiceBus.MessageLockLostException
我已将代码剥离回一个非常可重现的示例:
using System;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using Elasticsearch.Net;
using Microsoft.Azure.ServiceBus;
using Nest;
using Newtonsoft.Json;
namespace SampleApp
{
public class Program
{
private static SubscriptionClient _subscriptionClient;
private static IElasticClient _elasticClient;
private static string ServiceBusConnectionString = "[connectionString]";
private static string TopicName = "test";
private static string SubscriptionName = "test";
public static void Main(string[] args)
{
var elasticsearchSettings = new ConnectionSettings(new SingleNodeConnectionPool(new Uri("http://does.not.exist:9200"))).DefaultIndex("DoesNotExistIndex");
_elasticClient = new ElasticClient(elasticsearchSettings);
_subscriptionClient = new SubscriptionClient(ServiceBusConnectionString, TopicName, SubscriptionName);
// Configure the message handler options in terms of exception handling, number of concurrent messages to deliver, etc.
var messageHandlerOptions = new MessageHandlerOptions(ExceptionReceivedHandler)
{
// Maximum number of concurrent calls to the callback ProcessMessagesAsync(), set to 1 for simplicity.
// Set it according to how many messages the application wants to process in parallel.
MaxConcurrentCalls = 1,
MaxAutoRenewDuration = TimeSpan.FromSeconds(400),
// Indicates whether the message pump should automatically complete the messages after returning from user callback.
// False below indicates the complete operation is handled by the user callback as in ProcessMessagesAsync().
AutoComplete = false
};
// Register the function that processes messages.
_subscriptionClient.RegisterMessageHandler(ProcessMessagesAsync, messageHandlerOptions);
Console.WriteLine("INFO: Process message handler registered, listening for messages");
Console.Read();
}
private static async Task ProcessMessagesAsync(Message message, CancellationToken token)
{
// Message received.
var content = Encoding.UTF8.GetString(message.Body);
var messageBody = JsonConvert.DeserializeObject<string[]>(content);
Console.WriteLine($"INFO: Message arrived: {message}");
Console.WriteLine($"INFO: Message body: \"{string.Join(",", messageBody)}\"");
try
{
var response = _elasticClient.Ping();
if (!response.IsValid && response.OriginalException != null)
Console.WriteLine($"ERROR: ElasticSearch could not be reached, error was \"{response.OriginalException.Message}\"");
else
Console.WriteLine("INFO: ElasticSearch was contacted successfully");
}
catch (Exception e)
{
Console.WriteLine("!ERROR!: " + e);
}
await _subscriptionClient.CompleteAsync(message.SystemProperties.LockToken);
Console.WriteLine("INFO: Message completed");
}
// Use this handler to examine the exceptions received on the message pump.
private static Task ExceptionReceivedHandler(ExceptionReceivedEventArgs exceptionReceivedEventArgs)
{
Console.WriteLine($"Message handler encountered an exception {exceptionReceivedEventArgs.Exception}: " +
$"{exceptionReceivedEventArgs.ExceptionReceivedContext.Action}: " +
$"{exceptionReceivedEventArgs.ExceptionReceivedContext.EntityPath}");
return Task.CompletedTask;
}
}
此代码与此处的示例几乎相同: https://learn.microsoft.com/en-us/azure/service-bus-messaging/service-bus-dotnet-how-to-use-topics-subscriptions
我故意“ping”一个不存在的 Elasticsearch 实例,以产生套接字异常,以帮助我重现问题。
我注意到的一件事是,当我创建一个新主题并设置 EnabledPartioning = false 时,问题不会发生。
有人见过这个吗?似乎是 ServiceBus 代码本身的深层问题。
注意:我尝试使用接收器使用“ReceiveAsync”读取消息,在这种情况下我也收到此错误。另外,我的测试驱动程序是将 .net Framework ServiceBus 客户端(它与分区一起使用)移至 .net Core 版本。
提前感谢您的指点!!
最佳答案
在我上面的例子中,问题是由于对我的配置的轻微误解造成的。在 Azure 中,如果您导航到:
资源组 > ServiceBusInstance > 主题 > testTopic > testSubscription
您可以找到订阅属性。在这里您将看到发送消息时锁定的持续时间。默认为 60 秒,但我将长时间运行的过程延长到最长 5 分钟,如下所示:
然后在代码中,当连接我的订阅客户端的属性时,我需要确保 MaxAutoRenewDuration
属性设置正确。
我假设这个属性意味着,如果你为此定义了 30 秒,那么在内部,订阅客户端将每 30 秒更新一次锁定,因此,如果你的最大到期时间是 5 分钟,那么锁定将更新只要当您处理消息时...
事实上,该属性的实际含义是订阅客户端内部发生锁定更新的最大时间。
因此,如果您将其设置为 24 小时,例如Timespan.FromHours(24)
如果您的处理需要 12 小时,则会更新。但是,如果您使用 Timespan.FromHours(12)
将其设置为 12 小时你的代码运行了 24 秒,当你去完成消息时,它会给出一个 lockLost 异常(因为我在较短的时间间隔内得到了上面的结果!)。
我做过的一件事很容易实现,就是动态拉动 LockDuration
从运行时的订阅属性(我的所有主题可能有不同的配置)并应用 MaxAutoRenewDuration
适本地使用这个。
代码示例:
sbNamespace.Topics.GetByName(“test”).Subscriptions.GetByName(“test”).LockDurationInSeconds
注意 - 我正在使用 Azure.Management.Fluent 包来构建 sbNamespace。
希望对其他人有帮助!
关于c# - 使用 ServiceBus SubscriptionClient 时出现 RenewLock 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53853306/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!