Linux命令-logger(将消息写入系统日志)

🧭说明

logger 是 Linux 系统中一个非常实用的命令行工具,用于将消息写入系统日志。它提供了与系统日志服务(如 syslogrsyslog)交互的接口,特别适合在脚本中记录运行状态或关键事件。

下面这个表格汇总了 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 选项可以方便地将一个文件的全部内容快速记录到日志中。

    bash 复制代码
    logger -t "ConfigDump" -f /etc/myapp/config.conf
  • 发送日志到远程服务器 :在分布式环境中,可以使用 -n 选项将日志集中发送到一台远程 syslog 服务器,默认使用 UDP 514 端口。

    bash 复制代码
    logger -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"
相关推荐
智驾2 小时前
嵌入式Linux DMA深度解析:原理、应用与性能优化实践
linux·dma
Trouvaille ~3 小时前
【Linux】线程同步与互斥(一):线程互斥原理与mutex详解
linux·运维·服务器·c++·算法·线程·互斥锁
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.3 小时前
Keepalived 双主(Active‑Active)模式
运维·服务器
HalvmånEver3 小时前
Linux:进程 vs 线程:资源共享与独占全解析(线程四)
java·linux·运维
yuanjj883 小时前
域格移芯平台模块Linux下RNDIS、ECM拨号及网口名称修改
linux·rndis·ecm·ttyacm
zzzsde3 小时前
【Linux】进程(2):进程概念与操作理解
linux·运维·服务器
郝学胜-神的一滴3 小时前
Linux Socket模型创建流程详解
linux·服务器·开发语言·网络·c++·程序人生
天才奇男子3 小时前
《深度解析HAProxy七层代理:原理、配置与最佳实践》
linux·运维·微服务·云原生
交换机路由器测试之路3 小时前
交换机专题:什么是ALS(激光器自动关断)
运维·网络·以太网·交换机·节能