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

logRotate

在此页面上

  • 定义
  • 兼容性
  • 语法
  • 命令字段
  • 限制
  • 行为
  • 示例
logRotate

logRotate 命令是一条管理命令,它允许切换 MongoDB server 日志和/或审核日志,以防止单个日志文件占用过多磁盘空间。

您必须对logRotate 管理员数据库 发出 命令。

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

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

重要

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

该命令具有以下语法:

db.adminCommand(
{
logRotate: <integer or string>,
comment: <string>
}
)

该命令接受以下字段:

字段
类型
说明
logRotate
整数或字符串

要轮换的一个或多个日志,按以下方式进行:

  • 1 -- 切换服务器和审核日志

  • "server" -- 仅轮换服务器日志

  • "audit" -- 仅切换审核日志

comment
字符串
可选。日志轮换时服务器记录到日志文件和审核文件的消息。

您也可以通过向 mongod 进程发送 SIGUSR1 信号来轮换日志。

例如,如果正在运行的 mongod 实例的进程 ID (PID) 为 2200,则以下命令在 Linux 上为该实例轮转日志文件:

kill -SIGUSR1 2200

systemLog.logRotate 设置或 --logRotate 选项指定 logRotate 的行为。

systemLog.logRotate--logRotate 设置为 rename 时,logRotate 通过在文件名中添加当前时间戳来重命名现有日志文件。添加的时间戳具有以下形式:

<YYYY>-<mm>-<DD>T<HH>-<MM>-<SS>

然后,logRotate 创建一个新的日志文件,其名称与 systemLog.path 设置为 mongodmongos 最初指定的名称相同。

systemLog.logRotate--logRotate 设置为 reopen 时,logRotate 遵循典型的 Linux/Unix 行为,只需关闭日志文件然后重新打开同名的日志文件即可。利用 reopenmongod 期望另一个进程在轮换之前重命名该文件,并且重新打开会创建一个新文件。

下面的示例同时轮换服务器日志和审核日志:

db.adminCommand( { logRotate: 1 } )

以下示例仅轮换审核日志,并在轮换时向日志文件提供自定义消息:

db.adminCommand( { logRotate: "audit", comment: "Rotating audit log" } )

后退

listIndexes