- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我们有多个服务总线监听器在应用服务内作为连续的 Azure Webjobs 运行。总共有 12 个监听器 Web 作业在同一个 S1 应用服务计划上运行。环境很小,每天总共大约有~1000-10000条消息。最近,我们部署了一个新的监听器(一个定期向原始主题重新发送 DLQ 消息最多 24 小时和 10 次重试(指数退避)的监听器),昨天我们在托管应用服务上收到一条 TCP/IP 耗尽错误消息。在 S1 上,这意味着 Web 作业总共打开了超过 2000 个 TCP 连接。
总而言之,我们无法解释为什么监听器如此渴望 TCP 连接。每个应用程序在其应用程序生命周期中都使用一个 Topic-/QueueReceiver,并且还使用一个单例 HttpClient 来连接到目标 API。从理论上讲,这应该意味着每个监听器永远不会同时打开超过 10 个 TCP 连接。
我分析了代码,但没有发现 TCP 连接需求高的原因。
所有监听器大致都是这样工作的(.NET 控制台应用程序,在应用服务中作为连续的 Azure Webjobs 托管):
public static async Task Main(string[] args)
{
var configuration = GetConfiguration();
// Setup dependencies (e.g. Singleton HttpClient)
IServiceCollection serviceCollection = new ServiceCollection();
ConfigureServices(serviceCollection, configuration);
IServiceProvider serviceProvider = serviceCollection.BuildServiceProvider();
var factory = serviceProvider.GetService<TopicReceiverFactory<Model>>();
var receiver = await factory.CreateAsync();
receiver.ReceiveMessages();
Console.ReadLine();
}
// ctor of the receiver used above
public QueueReceiver(QueueConfiguration configuration, IHandler<T> handler, ILogger<IReceiver> logger)
: base(logger, handler)
{
this.configuration = configuration;
this.Client = new QueueClient(
this.configuration.ConnectionString,
this.configuration.QueueName,
this.configuration.ReceiveMode);
}
// The ReceiveMessages Method used in Main
public void ReceiveMessages()
{
var messageHandlerOptions = new MessageHandlerOptions(this.HandleExceptionReceivedAsync)
{
MaxConcurrentCalls = this.configuration.MaxConcurrentCalls,
AutoComplete = false
};
this.Register(messageHandlerOptions);
}
protected void Register(MessageHandlerOptions messageHandlerOptions)
{
if (messageHandlerOptions == null)
{
throw new ArgumentNullException(nameof(messageHandlerOptions));
}
this.Client.RegisterMessageHandler(this.ProcessMessageAsync, messageHandlerOptions);
}
ProcessMessage大致有这样的逻辑:调用特定实体的处理程序(将消息发布到api),如果成功:完成消息;如果出现严重异常(例如 JsonSerializerException 因为消息格式错误)而失败,则直接死信。轻微异常会导致内置重试(最多十次)。
预计 TCP 连接永远不会耗尽。环境中没有发生太多事情。
最佳答案
我们找到了问题的根源。考虑以下架构:具有多个主题和一个队列的服务总线命名空间。消息将发送到服务总线监听器接收和处理消息的主题。如果无法处理消息,它们将被转发到中央错误处理队列。在此队列上,一个监听器正在接收消息并读取消息上的 DeadLetterSource-Property。在此属性中包含有关原始主题的信息。
现在问题:目前我们正在为每条消息创建一个 TopicClient。发生这种情况是因为这个监听器不需要提前知道有哪些主题,从而降低了可重用性。然而,正如我们现在发现的那样,这是不可持续的,因为您会耗尽 TCP 连接。
解决方案:我们通过配置引入主题名称,以便该监听器可以为整个应用程序生活方式的每个主题创建一个 TopicClient。本质上有 n-Singleton TopicClient 实例同时运行。
关于c# - Azure 服务总线监听器打开太多 TCP 连接(耗尽),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57321525/
我有一个使用 PHP 和 MariaDB 10.3 的小型大型数据库应用程序。 我有大约 100 个表,大约有 3,000 个 View 。 当超过 1,000 个 View 时,数据库架构就会崩溃并
parsing "\(|.*?)|)" - Too many )'s. 写这个的时候我收到这个错误... private static Regex resourceTextsREGEX = new
我有一个Powershell脚本,它会生成一个包含数据的JSON文件。 我对此文件有问题。它产生两倍的“\”! 你知道我该怎么解决吗? 这是我的生成JSON文件的代码: [ordered]@{ pcn
我不确定为什么会收到此错误,我在不同点使用 str.join() 和 os.path.join()在脚本中,这是原因吗? 使用os.path.join: from os.path import get
一段时间后,在我的应用程序中,似乎出现了一个大问题。有一个来自 Box2D 的 b2Bodys 的构建。我确实在我的应用程序中使用了一些 b2Body 来进行碰撞,但我会说屏幕上一次最多有 10 个。
我正在创建一个包含 6 种不同问题类型的简单数学程序。我想让程序随机显示6种类型中的一种,但有些问题应该出现得比较频繁。我使用加权数组,但从加权数组中选择问题类型后,如果不在 if 语句中使用 10
我想构建一个包含大约 400 个单元的 Controller ,4 列,每列 100 个单元。每个单元格都必须被绘制并响应鼠标事件。这个会不会太重了?我应该为每个单元使用另一种方法,如 CALayer
我是 Haskell 的新手,在编写小程序时,我通常会使用太多的 where 子句来检查函数中的许多内容,因此编写 where 子句是一种很好的做法,或者还有其他好的替代方法吗? 例如,在下面的代码中
我有一个 index.js,其中包含一些导出,每个导出仅包含一个函数。我尝试一次部署其中的几个,CLI 给我以下错误; Error: Too many arguments. Run firebase
我在正则表达式上挣扎了几个小时,似乎没有找到最后一点解决方案。我基本上是逐行解析 C 头文件以查找变量。 以下是我可能遇到的需要传递正则表达式的行的情况: //#define variable_nam
我有一个 html 表单,大约有 1500 个输入字段*(文本或隐藏)。form.action 是 POST 并且每个输入字段都有一个唯一的名称(没有 name=foo[])。 每当我在提交表单后尝试
我很困惑 一劳永逸 VS 添加引用(/net 选项卡)说 dll 的 gac 在这里: 我发现这个包含 GAC 的文件夹:(附注:为什么有 3 个 Gac 类型?) 还有这个包含 GAC 的文件夹:
我有一个实现Comparable的对象列表。 我想对此列表进行排序,这就是我使用Comparable的原因。 每个对象都有一个字段 weight,它由另外 3 个成员 int 变量组成。 对于具有最大
在我们的系统中,有多个“站点”通过 WCF 相互通信。每个站点通过 NetTCP 绑定(bind)公开约 20 个接口(interface)。 当一个站点使用对等站点的接口(interface)时,它
我已经从 http://boost.teeks99.com/ 下载了 boost 1.58.0(预编译,x86,VC 12.0)并安装到C:\local\boost_1_58_0(我也试过自己用msv
所以...我有一个查询,该查询返回在我的网站上使用相同的电子邮件地址、密码和其他信息创建的用户帐户(是的,实现不好,不要问)。它通过从另一个程序获取用户 ID 来实现这一点。 我的 SQL 是 SEL
我知道这是一个有点菜鸟的问题,但我只是想问一下,如果我有太多 Controller ,这是好事还是坏事。假设我有一个网络应用程序,它有大约 12 个 View 。每个 View 都有自己的 Contr
我认为我的项目做了一些可笑的错误。我正在制作一个项目,基本上是一组 View Controller ,其中一些 Controller 上有视频,其他 Controller 上有图像。我创建了一个模型,
嘿,我正在创建一个电子商店并显示类别树和所有产品及其多种价格变化,我制作了 150 多个 mysql_query("SELECT ..."); 在一页上查询。 (如果我计算“while”循环)。 是不
我在 JS 方面遇到了问题。我正在尝试制作按类型排序的三个成分列表(用于酿造药水),所有这些都是标签内的复选框。 您应该选择(选中)三个列表中每一个的一个元素才能酿造一剂药水。如果您选择正确的成分并按
我是一名优秀的程序员,十分优秀!