🧭说明
logger 是 Linux 系统中一个非常实用的命令行工具,用于将消息写入系统日志。它提供了与系统日志服务(如 syslog 或 rsyslog)交互的接口,特别适合在脚本中记录运行状态或关键事件。
下面这个表格汇总了 logger 命令最常用的选项。
💻 核心选项速览
| 选项 | 说明 | 示例 |
|---|---|---|
-p, --priority |
指定日志的设施 和级别 ,格式为 facility.level。默认为 user.notice。 |
-p local0.error |
-t, --tag |
为日志条目添加一个标签。默认使用当前用户名。 | -t MyBackupScript |
-i, --id |
在日志中记录写入该条目的 logger 进程的 ID (PID)。 | -i |
-f, --file |
读取指定文件的内容,并将其每一行作为一条日志消息写入。 | -f /tmp/status.txt |
-s, --stderr |
在将日志写入系统日志的同时,也输出到标准错误流,通常会在终端显示。 | -s |
-n, --server |
将日志消息发送到指定的远程 syslog 服务器。 | -n 192.168.1.100 |
详细用法与场景示例
1. 基础用法:记录简单消息
最基本的用法是直接在命令后跟上要记录的消息。
bash
logger "服务器备份任务已开始执行"
这行命令会将消息记录到默认的系统日志文件(如 /var/log/syslog)中。
2. 脚本实践:添加标签和优先级
在脚本中使用时,强烈建议使用 -t 选项添加一个唯一标签,并使用 -p 选项区分日志级别,这样便于后续筛选和排查问题。
bash
#!/bin/bash
SCRIPT_TAG="MyApp_Backup"
logger -t $SCRIPT_TAG -p user.info "备份脚本启动"
# 执行备份逻辑...
if [ $? -eq 0 ]; then
logger -t $SCRIPT_TAG -p user.info "备份成功完成"
else
logger -t $SCRIPT_TAG -p user.error "备份过程中发生错误"
fi
关于优先级 (-p)
优先级由两部分组成:
- 设施 (Facility) :指明消息来自系统的哪个部分,例如
kern(内核),mail(邮件),cron(计划任务),local0-local7(保留给本地使用) 等。 - 级别 (Level) :表示消息的严重程度,从低到高依次有
debug,info,notice,warning,err,crit,alert,emerg。
例如,-p cron.err 表示一个来自计划任务的错误消息。
3. 高级功能:记录文件内容与远程日志
-
从文件记录日志 :使用
-f选项可以方便地将一个文件的全部内容快速记录到日志中。bashlogger -t "ConfigDump" -f /etc/myapp/config.conf -
发送日志到远程服务器 :在分布式环境中,可以使用
-n选项将日志集中发送到一台远程 syslog 服务器,默认使用 UDP 514 端口。bashlogger -n loghost.example.com -t "WebServer01" "用户登录成功"
4. 查看记录结果
日志记录后,通常可以使用 grep 命令在日志文件中查看。系统的日志文件一般为 /var/log/syslog 或 /var/log/messages,具体位置取决于系统配置。
bash
# 查看带有特定标签的日志条目
grep "MyBackupScript" /var/log/syslog
# 或者使用 tail -f 实时监控
tail -f /var/log/syslog | grep "MyBackupScript"