您的位置:首页 >Ubuntu中Java日志管理怎么做
发布于2026-04-26 阅读(0)
扫一扫,手机访问

处理Ja va应用的日志,可不是简单地把信息打印出来就完事了。一个健壮的日志管理体系,需要从应用内部到操作系统,再到集中化平台,层层递进。下面就来拆解一下这套组合拳该怎么打。
先说几个核心判断。一套完整的日志管理方案,通常遵循“分层治理”的原则:
logrotate,对日志文件进行二次轮转、压缩和定期清理,从根本上杜绝磁盘被撑爆的风险。journalctl 就是查看和检索服务日志的利器,能提供统一的入口。应用内的日志配置是基础,选对框架并做好设置,后续工作会轻松很多。
%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
logs/app.log
logs/app.%d{yyyy-MM-dd}.%i.log
30
100MB
%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n
ja va -Dja va.util.logging.config.file=logging.properties -jar myapp.jar
配置文件(logging.properties)参考:
handlers=ja va.util.logging.FileHandler, ja va.util.logging.ConsoleHandler
ja va.util.logging.FileHandler.pattern=/var/log/myapp/ja va.log
ja va.util.logging.FileHandler.limit=10485760
ja va.util.logging.FileHandler.count=5
ja va.util.logging.FileHandler.formatter=ja va.util.logging.SimpleFormatter
ja va.util.logging.ConsoleHandler.level=ALL
ja va.util.logging.ConsoleHandler.formatter=ja va.util.logging.SimpleFormatter
.level=INFO
以上配置示例,基本覆盖了从 Log4j/Logback/SLF4J 到原生 JUL 的常见用法,可以作为快速上手的模板。
应用框架自身的滚动策略可能还不够,尤其是当日志文件积累在系统目录时。这时,就该 Ubuntu 自带的 logrotate 出场了,它专门管理文件日志(注意,它不管理 systemd 的 journal 日志)。
/etc/logrotate.d/ 目录下为你的应用创建一个专属配置文件,比如 /etc/logrotate.d/myapp:
/var/log/myapp/*.log {
daily
rotate 7
compress
delaycompress
missingok
notifempty
create 0640 myapp myapp
sharedscripts
postrotate
# 若应用支持信号重载;不支持时可省略或改为重启
kill -USR1 $(cat /var/run/myapp.pid 2>/dev/null) 2>/dev/null || true
endscript
}
sudo logrotate -vf /etc/logrotate.d/myapp 可以强制运行一次并显示详细信息,用于验证配置是否正确。/etc/cron.daily/logrotate 计划任务每日自动执行。create 指令确保轮转后创建的新日志文件,其所有者和组(如 myapp:myapp)与应用运行时用户一致,避免出现权限问题导致应用无法写入。postrotate 脚本的作用。它通常用于通知应用重新打开日志文件(例如通过发送 USR1 信号)。如果你的应用不支持这种热重载,可能需要改为重启服务,或者使用 copytruncate 指令(但需注意,这种方式在复制和清空原文件的间隙可能有丢失日志的风险,需谨慎评估)。这就是利用 logrotate 进行系统级日志管理的标准流程和核心注意事项。
将 Ja va 应用托管为 systemd 服务是生产环境的常见做法,好处之一就是能无缝集成系统日志服务。
/etc/systemd/system/myapp.service。关键在于将标准输出和错误输出重定向到 journal:
[Unit]
Description=My Ja va App
After=network.target
[Service]
Type=simple
User=myapp
ExecStart=/usr/bin/ja va -jar /opt/myapp/myapp.jar
StandardOutput=journal
StandardError=journal
SuccessExitStatus=143
Restart=on-failure
[Install]
WantedBy=multi-user.target
journalctl 就成了查看日志的瑞士军刀:
sudo journalctl -u myapp.service -f,这个命令在排查问题时非常有用。sudo journalctl -u myapp.service --since “2025-12-01 10:00:00” -u myapp.service --until “2025-12-01 12:00:00”,精准定位某个时间段的日志。sudo journalctl -u myapp.service -p err -b,快速过滤出本次启动以来的所有错误日志。Restart=on-failure),这能有效提升服务的自愈能力和可用性。上述命令组合,足以应对日常通过 systemd 和 journal 管理服务日志的绝大多数场景。
当应用部署到多台服务器,或者需要对日志进行深度分析和长期报表时,集中化日志平台就从“可选”变成了“必选”。
sudo apt update && sudo apt install elasticsearch logstash kibana/etc/logstash/conf.d/ja va-log.conf,定义输入、过滤和输出。
input {
file {
path => “/var/log/myapp/*.log”
start_position => “beginning”
sincedb_path => “/var/lib/logstash/sincedb-myapp”
codec => “json_lines” # 若应用输出 JSON;否则用 plain 并配合 grok
}
}
filter {
# 如非 JSON,可用 grok 解析;示例模式可按需调整
# grok { match => { “message” => “%{COMBINEDAPACHELOG}” } }
# date { match => [ “timestamp”, “dd/MMM/yyyy:HH:mm:ss Z” ] }
}
output {
elasticsearch {
hosts => [“localhost:9200”]
index => “myapp-%{+YYYY.MM.dd}”
}
stdout { codec => rubydebug }
}
sudo systemctl start elasticsearch logstash kibana。http://localhost:5601,在 Kibana 中创建索引模式(如 myapp-*),之后就可以进行搜索和创建可视化图表了。以上便是基于 ELK 栈在 Ubuntu 上实现集中化日志采集与分析的基本路径,可以作为项目日志架构升级的起点。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9