linux

nohup命令的输出日志如何分割

小樊
68
2025-10-03 04:42:59
栏目: 编程语言

nohup 命令用于在后台运行程序,即使关闭终端或断开连接,程序也会继续运行。默认情况下,nohup 会将输出重定向到名为 nohup.out 的文件中。如果你想要分割这个日志文件,可以使用 logrotate 工具或者自定义脚本来实现。

使用 logrotate 分割日志

  1. 确保你的系统已经安装了 logrotate。在大多数 Linux 发行版中,它通常是预装的。如果没有,你可以使用包管理器(如 aptyumpacman)来安装它。

  2. 创建一个 logrotate 配置文件,例如 /etc/logrotate.d/myapp,并添加以下内容:

    /path/to/your/nohup.out {
        daily
        rotate 7
        compress
        missingok
        notifempty
        create 0640 user group
    }
    

    这个配置表示每天分割一次日志文件,保留最近 7 天的日志,压缩旧日志,如果日志文件不存在则不报错,如果日志文件为空则不进行分割,并创建一个新的日志文件,权限为 0640,属主和属组分别为 user 和 group。

  3. 重新加载 logrotate 配置以应用更改:

    sudo logrotate -f /etc/logrotate.conf
    

使用自定义脚本分割日志

你还可以编写一个简单的 shell 脚本来定期分割 nohup.out 文件。以下是一个示例脚本:

#!/bin/bash

LOG_FILE="/path/to/your/nohup.out"
BACKUP_DIR="/path/to/your/log_backup"

# 创建备份目录(如果不存在)
mkdir -p "$BACKUP_DIR"

# 获取当前日期
CURRENT_DATE=$(date +"%Y-%m-%d")

# 分割日志文件
split -l 100000 --numeric-suffixes --additional-suffix=".log" "$LOG_FILE" "${BACKUP_DIR}/nohup.out."

# 清空原始日志文件
> "$LOG_FILE"

将此脚本保存为 rotate_nohup.sh,并使用 chmod +x rotate_nohup.sh 使其可执行。然后,你可以使用 cron 定时任务来定期运行此脚本。例如,每天凌晨 1 点运行脚本:

0 1 * * * /path/to/rotate_nohup.sh

将此行添加到 /etc/crontab 文件中,或者创建一个新的 cron 任务文件(如 /etc/cron.d/rotate_nohup)并添加此行。

0
看了该问题的人还看了