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"
相关推荐
~黄夫人~30 分钟前
Linux 权限管理:用户组 + 特殊权限 + ACL 解析
linux·运维·计算机·学习笔记·权限管理
2501_907136821 小时前
手搓仓库管理系统Senbar-1.0.4(附带财务管理板块)
运维·服务器·软件需求
盟接之桥2 小时前
盟接之桥EDI软件:API数据采集模块深度解析,打造企业数据协同新引擎
java·运维·服务器·网络·数据库·人工智能·制造
2501_907136823 小时前
离线工具箱 内含53个小工具
linux·服务器·网络
时空潮汐3 小时前
神卓N600 NAS身份核验功能深度解析
linux·运维·网络·神卓nas·神卓n600 pro·家庭轻nas
哈哈浩丶3 小时前
安卓系统全流程启动
android·linux·驱动开发
小李独爱秋3 小时前
模拟面试:用自己的话解释一下lvs的工作原理
linux·运维·面试·职场和发展·操作系统·lvs
百锦再3 小时前
Jenkins 全面精通指南:从入门到脚本大师
运维·后端·python·servlet·django·flask·jenkins
隔壁老王的代码3 小时前
Jenkins的流水线详解
运维·servlet·jenkins
一路往蓝-Anbo3 小时前
第 7 章:内存地图 (Memory Map) 深度设计——DDR 与 SRAM
linux·stm32·单片机·嵌入式硬件·网络协议