核心内容摘要
法国满天星《护士急救法》:生命链上的璀璨星辰,守护与希望的温柔触碰
说明logger是 Linux 系统中一个非常实用的命令行工具用于将消息写入系统日志。
它提供了与系统日志服务如syslog或rsyslog交互的接口特别适合在脚本中记录运行状态或关键事件。
下面这个表格汇总了logger命令最常用的选项。
核心选项速览选项说明示例-p, --priority指定日志的设施和级别格式为facility.level。
默认为user.notice。
-p local
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.
100详细用法与场景示例
基础用法记录简单消息最基本的用法是直接在命令后跟上要记录的消息。
logger服务器备份任务已开始执行这行命令会将消息记录到默认的系统日志文件如/var/log/syslog中。
脚本实践添加标签和优先级在脚本中使用时强烈建议使用-t选项添加一个唯一标签并使用-p选项区分日志级别这样便于后续筛选和排查问题。
#!/bin/bashSCRIPT_TAGMyApp_Backuplogger -t$SCRIPT_TAG-p user.info备份脚本启动# 执行备份逻辑...if[$?-eq0];thenlogger -t$SCRIPT_TAG-p user.info备份成功完成elselogger -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表示一个来自计划任务的错误消息。
高级功能记录文件内容与远程日志从文件记录日志使用-f选项可以方便地将一个文件的全部内容快速记录到日志中。
logger -tConfigDump-f /etc/myapp/config.conf发送日志到远程服务器在分布式环境中可以使用-n选项将日志集中发送到一台远程 syslog 服务器默认使用 UDP 514 端口。
logger -n loghost.example.com -tWebServer01用户登录成功
查看记录结果日志记录后通常可以使用grep命令在日志文件中查看。
系统的日志文件一般为/var/log/syslog或/var/log/messages具体位置取决于系统配置。
# 查看带有特定标签的日志条目grepMyBackupScript/var/log/syslog# 或者使用 tail -f 实时监控tail-f /var/log/syslog|grepMyBackupScript