- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我的 Python Web 应用程序有多个连接注册到同一个 MongoDb 服务器,但有 3 个不同的数据库。该应用程序由 4 个 Gunicorn 工作人员运行。
我正在使用副本集。
当主节点关闭时,当前查询失败,并在 MongoReplicaSetClient 中安排刷新(2.8,但我猜在 3.2 中也是一样)。如果此时选择了新的主节点并且 MonitorThread 获取有关它更新客户端连接的信息,则下一个查询可能会成功。
但是刷新只影响这个客户端。连接到同一个 MongoDB 服务器的其他客户端不受影响——每个客户端都会发生同样的情况。这意味着如果每个工作人员都连接到同一个 MongoDB 服务器上的 3 个数据库,并且我重复同一个 HTTP 请求,该请求在主数据库发生故障时使用所有 3 个数据库,则需要无限期的时间来更新所有连接的客户端。如果每个 HTTP 请求轮询到 4 个中的每个工作人员,我们需要 12 个请求来更新每个 Mongo 客户端。但实际上请求不会循环。
查看 PyMongo 代码 MongoReplicaSetClient._send_message_with_response
我看到当主服务器关闭时,调用了 self.disconnect
调用 self.__schedule_refresh
.此方法有参数 sync
,它允许“阻塞直到刷新完成”。
我的想法是捕获 AutoReconnect
异常并调用 __schedule_refresh(sync=True)
在连接到失败的主节点的所有客户端上并阻塞直到新的副本集配置到位。因此在数据库正常之前不会处理 HTTP 请求(结果为 500)。
但是__schedule_refresh
是一个私有(private)方法。我也不知道在所有客户端上按顺序调用它是否会很快——看起来 MonitorThread
是按时间间隔工作的。
或者也许我可以使用 MongoReplicaSetClient.refresh
.
你觉得这个想法怎么样?它有缺点吗?
你能帮我实现吗?
最佳答案
有趣的问题。
如果您在一个有大量请求传入的环境中运行,我建议反对让任何工作人员阻止 IO,尤其是像等待这样的网络调用让小学上来。
我建议尝试从您的 mongo 客户端捕获可能表明服务器已关闭的异常,并将 503 返回给调用者。 503 通常是传达资源不可用并建议稍后重试的好方法。
您的 mongo 数据库将在使用过程中停机,让应用服务器检测到这一点,转储请求并返回 503s 是一种处理流量的方法,否则流量将开始阻塞、线程耗尽并终止应用服务器。让应用服务器摆脱所有这些会导致等待和可能失败的调用。
这是 REST 服务中常用的习惯用法:http://www.restpatterns.org/HTTP_Status_Codes/503_-_Service_Unavailable
您甚至可以添加“Retry-After” header 以指示客户端将来何时应尝试重试。有关 Retry-After header 以及某些浏览器如何解释它的更多信息:
Retry-after HTTP response header - does it affect anything?
HTH
关于python - 阻塞直到新的副本集配置到位,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34632127/
不确定我的标题措辞是否正确,但请耐心等待,所有内容都会得到解释... 我们有一组代码不是在这里发明的,它使用进程间通信(IPC 消息传递)。该方案的大致轮廓是这样的: comms.c 包含: stat
你怎么能列出所有的颠覆合并? 例如: Trunk ____9_____14____20___ \ \ \ \______\_____\___
是否有一个集合的标准 Java(1.5+)实现(即无第三方),允许我将多个集合粘合到一个集合中? 这是其工作原理的草图: final SomeCollection x = new SomeCollec
有没有办法让sql查询返回拆分行。我什至不知道怎么问。下面有'index_tag'。 select event.name, tb_ev.start_time, tb_ev.end_time from
我正在尝试使用 postgresql COPY 命令从 CSV 加载一些数据。诀窍是我想在用户标识(包含在 CSV 中)上实现 Multi-Tenancy 。加载 csv 时,是否有一种简单的方法告诉
我正在尝试使用 bash 脚本将文件复制到当前目录。 为了处理需要转义的路径,使用了一个变量,该变量被转义然后提供给 cp 命令。 cp 命令提示: usage: cp [-R [-H | -L |
我正在尝试每 20 毫秒向给定的 x 和 y 坐标添加一次 CAShapelayer。我希望形状在一秒钟内消失(就像示踪剂一样)。我创建的功能有效,形状在正确的位置创建并消失。但是我留下了额外的形状,
我是 Python 新手。我正在尝试创建一个程序来打印我通常每周手动打印的一组文档,但是我遇到了几个问题: 这是代码: import os file_list = os.listdir("C:/Pyt
我有一个大小为 10 的 ArrayList l1。我将 l1 分配给新的列表引用类型 l2。 l1 和 l2 会指向同一个 ArrayList 对象吗?或者是 ArrayList 对象的副本分配给
我这周花了一个自由职业者创建的 Mongo 4.4 PSA 副本来工作。我放弃了,从所有三台服务器上删除了完整的 mongod,然后按照 Mongo doc 从头开始安装。 .唯一的变化是在副本初
设置信息: 我有两个数据中心,每个 DC 中有 5 个节点。 我知道插入到表中的每一行都是根据使用的数据分区方案存储的;生成必要的副本并将它们存储在集群中的其他节点(根据复制策略选择节点)上。给定一行
我对 XSLT 完全陌生,所以请耐心等待。 我有两个 xml 文件,我试图使用 XSLT 将它们连接在一起。我想合并这些文件,以便第二个文件中指定的任何值覆盖第一个文件。例如 firstFile.xm
这里肯定有一个初学者问题,为什么 F# 编译器会制作不必要的 DateTimeOffset 副本,我该如何阻止它?我不记得这是个问题,但也许自从我在 F# 中使用 DateTimeOffset 以来已
我有一个用 C# 编写的 WinForms 应用程序,在将数据从 SQL 数据库导出到模板的工作表之前,它使用以下代码打开 Excel 模板。 Microsoft.Office.Interop.Exc
我从这个 post 得到的 xsl 中有这个函数 用“换行符”替换“cr” 我是这样调用它的: 我正在做文章链接,点击文本“阅读更多”
所以这可能有点难以解释...... 目前我这样做: SomeInterface xyz1 = SomeInterface.method(data); SomeInterfaceCopy xyz2 =
我有一个包含指针 p 的类型 var。我需要在另一个与 var 类型相同的变量 var1 上复制 var(通过在引号中执行 var1 "="var,因为我不知道这是否是正确的方法,请参见下文)。 在我
出于某种原因,我需要同时运行两个 xampp 副本。我在互联网上阅读了很多教程,但如果我需要运行另一个,他们最终会告诉我关闭当前的 xampp。这有可能实现吗? 最佳答案 您可以使用不同的端口同时运行
在aws中,“upload-part-copy”具有字节范围选项。如果我想将两个对象的一部分复制到云中的新对象,我可以使用“upload-part-copy”命令进行复制。 我找不到任何此类方法或机制
我有一个带栏的表 foo foo --- bar 我使用 Postgres 的 Copy 命令 COPY (select * from foo) TO 'complete_file_path' WIT
我是一名优秀的程序员,十分优秀!