Docs 菜单
Docs 主页
/
MongoDB Manual
/ / /

shutdown

在此页面上

  • 兼容性
  • 语法
  • 命令字段
  • 行为
  • 访问控制
  • 示例

5.0 版本中的更改

shutdown

shutdown 命令会清理所有数据库资源,然后终止进程。shutdown您必须针对 管理员数据库发出命令。

此命令可用于以下环境中托管的部署:

  • MongoDB Atlas:用于云中 MongoDB 部署的完全托管服务

重要

M 0 、M 2 、M 5和 M 10 + 集群不支持此命令。 有关更多信息,请参阅不支持的命令。

该命令具有以下语法:

db.adminCommand(
{
shutdown: 1,
force: <boolean>
timeoutSecs: <int>,
comment: <any>
}
)

该命令使用以下字段:

字段
说明

指定 1

可选。指定 true 以强制关闭 mongodmongos。强制关闭会中断 mongodmongos 上正在进行的任何操作,并可能导致意外行为。

您可以使用force 暂停和恢复正在进行的索引构建。有关更多信息,请参阅有关副本集节点的shutdown

可选。

从 MongoDB 5.0 开始,mongodmongos 进入静默期,以允许所有正在进行的数据库操作在关闭之前完成。

如果一个 mongod 主节点收到关闭请求,则主节点:

  1. 尝试降级到从节点。

    如果降级失败,并且:

    • 运行了 shutdowndb.shutdownServer() 命令,如果字段为 true,mongod 仅继续执行关闭步骤,或者

    • SIGTERM 信号已发送到 mongodmongod 始终继续执行关闭步骤。

  2. 进入静默期。

  3. 结束所有剩余的数据库操作。

  4. 关闭。

对于 mongod 从节点mongos 关闭请求,在请求关闭之后进入静默期。

静止期由以下各项指定:

mongodmongos 关闭时,客户端无法新建相关连接。

timeoutSecs 指定一个时间段(以秒为单位)。默认为:

  • 从 MongoDB 5.0 开始为 15 秒。

  • 在 MongoDB 5.0 以前的版本中为 10 秒。

mongod使用 timeoutSecs,如下所示:

从MongoDB5.0 开始,mongos 使用 timeoutSecs 作为静默期,以允许完成现有操作。新操作将发送到其他 节点。在mongos 之前的MongoDB版本中。5 、0 mongos会立即关闭且不使用 timeoutSecs。

comment

可选。用户提供的待附加到该命令的注释。设置后,该注释将与该命令的记录一起出现在以下位置:

注释可以是任何有效的 BSON 类型(字符串、整型、对象、数组等)。

提示

另请参阅:

对于mongod 在自托管部署上使用身份验证 启动shutdown 的 ,您必须通过经过身份验证的连接运行 。有关详细信息,请参阅访问控制

对于 在自管理部署上mongod shutdown启动 但未进行 身份验证的 ,您必须从连接到本地主机接口的客户端运行 。示例,在与 相同的托管上运行带有 选项的mongosh --host "127.0.0.1"{mongod

如果副本集节点正在运行某些操作(例如索引构建),则 shutdown 将失败。您可以指定 force: true 来强制节点将索引构建进度保存到磁盘。mongod 在重新启动时会恢复索引构建,并从保存的检查点继续运行。

从 MongoDB 5.0 开始,mongodmongos 进入静默期,以允许所有正在进行的数据库操作在关闭之前完成。

如果一个 mongod 主节点收到关闭请求,则主节点:

  1. 尝试降级到从节点。

    如果降级失败,并且:

  2. 进入静默期。

  3. 结束所有剩余的数据库操作。

  4. 关闭。

对于 mongod 从节点mongos 关闭请求,在请求关闭之后进入静默期。

静止期由以下各项指定:

mongodmongos 关闭时,客户端无法新建相关连接。

timeoutSecs指定了一个时间段(以秒为单位)。默认为:

  • 从 MongoDB 5.0 开始为 15 秒。

  • 在 MongoDB 5.0 以前的版本中为 10 秒。

mongod 按如下方式使用 timeoutSecs

  • 如果当前节点是副本集的主节点,则 mongod 会等待 timeoutSecs 字段指定的秒数,以便可选举节点跟上,然后再降级主节点。有关追赶时间的详情,请参阅复制延迟。

  • 如果当前节点在退出主节点后处于SECONDARY状态,则 timeoutSecs 中指定的任何剩余时间将作为静默期,以允许完成现有操作。新操作将发送到其他副本集节点。

从 MongoDB 5.0 开始,mongos 使用 TimeoutSecs 作为静默期,这会允许现有操作完成。新操作将发送到其他 mongos 节点。在 MongoDB 5.0 以前的版本中,mongos 立即关闭并且不使用 timeoutSecs

警告

强制关闭主节点可能会导致所有尚未复制到从节点的写入操作发生回滚

要在实施对自管理部署进行身份验证mongod 上运行 shutdown,经过身份验证的用户必须具有 shutdown权限。例如,具有内置角色 hostManager 的用户拥有适当权限。

db.adminCommand({ "shutdown" : 1 })
db.adminCommand({ "shutdown" : 1, "force" : true })
db.adminCommand({ "shutdown" : 1, timeoutSecs: 60 })

后退

setUserWriteBlockMode