JSP应用在Ubuntu上的日志管理
JSP应用在Ubuntu上的日志管理

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈
一 日志来源与存放位置
要管好日志,首先得知道它们从哪来、往哪去。对于运行在Ubuntu上的JSP应用,日志主要来自两个层面。
- 容器与应用日志:JSP通常运行在Apache Tomcat之上,因此Tomcat的日志是首要关注点。它们通常位于 /var/log/tomcat9/ 目录下。几个核心文件需要记住:
catalina.out(记录了标准输出和错误信息)、localhost.(主机相关日志)、以及.log localhost_access_log.(访问日志)。这些文件覆盖了从启动、部署到运行期的各种异常和访问轨迹,堪称排查问题的“第一现场”。如果你是通过包管理器安装的Tomcat,日志默认就会写入这个目录。.txt - 应用内日志:除了容器日志,业务逻辑产生的日志同样关键。最佳实践是使用日志框架,将业务日志输出到独立的目录,例如 /var/log/yourapp/。这样做的好处是,能将应用日志与Tomcat实例的生命周期解耦,也更方便与系统级的日志管理策略进行统一。
二 在JSP中输出日志
知道了日志去哪,接下来就是如何产生它们。在JSP页面里写日志,有几种主流框架可以选择,各有千秋。
- 使用ja va.util.logging(JUL)
- 这是JDK内置的日志工具,零依赖,非常适合轻量级场景。来看一个简单的代码示例:
<%@ page import="ja va.util.logging.Logger" %> <% Logger log = Logger.getLogger(request.getServletPath()); log.info("JSP loaded, sessionId=" + session.getId()); try { int x = 1 / 0; } catch (Exception e) { log.severe("Unhandled error: " + e.getMessage()); } %> - 它的配置也足够灵活,完全可以通过配置文件实现按文件大小或时间进行滚动切割,满足基本需求。
- 这是JDK内置的日志工具,零依赖,非常适合轻量级场景。来看一个简单的代码示例:
- 使用Log4j 1.x
- 作为经典的一代日志框架,Log4j 1.x在社区中仍有广泛使用。首先需要引入依赖(以Ma ven为例):
log4j log4j 1.2.17 - 接着是配置文件(
src/main/resources/log4j.properties),这里配置了一个按大小滚动的文件追加器:log4j.rootLogger=INFO, FILE log4j.appender.FILE=org.apache.log4j.RollingFileAppender log4j.appender.FILE.File=/var/log/yourapp/app.log log4j.appender.FILE.MaxFileSize=10MB log4j.appender.FILE.MaxBackupIndex=7 log4j.appender.FILE.layout=org.apache.log4j.PatternLayout log4j.appender.FILE.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n - 在JSP页面中即可调用:
<%@ page import="org.apache.log4j.Logger" %> <% Logger log = Logger.getLogger("MyJspPage"); log.info("Log4j info from JSP"); %> - 这样一来,日志文件达到10MB后会自动滚动,并最多保留7个历史文件,管理起来非常省心。
- 作为经典的一代日志框架,Log4j 1.x在社区中仍有广泛使用。首先需要引入依赖(以Ma ven为例):
- 使用Log4j2
- 作为Log4j的现代化继承者,Log4j2在性能和功能上都有显著提升。依赖如下(示例版本2.17.1):
org.apache.logging.log4j log4j-api 2.17.1 org.apache.logging.log4j log4j-core 2.17.1 - 其XML配置(
src/main/resources/log4j2.xml)也更加强大,支持同时按时间和大小触发滚动: - JSP中的使用方式与Log4j 1.x类似:
<%@ page import="org.apache.logging.log4j.LogManager, org.apache.logging.log4j.Logger" %> <% Logger log = LogManager.getLogger(request.getServletPath()); log.info("Log4j2 info from JSP"); %> - 选择Log4j2,意味着你能获得更完善的日志管理功能,包括高性能的异步日志记录,这对于生产环境尤其有价值。
- 作为Log4j的现代化继承者,Log4j2在性能和功能上都有显著提升。依赖如下(示例版本2.17.1):
三 系统级日志轮转与权限
应用能写日志了,但如果不加管理,日志文件会无限膨胀,最终拖垮磁盘。这时候,系统级的日志轮转工具就该上场了。
- 使用logrotate集中管理应用日志(推荐)
- Linux自带的
logrotate工具是管理日志的不二之选。为你的应用创建一个专属配置,比如/etc/logrotate.d/yourapp:/var/log/yourapp/*.log { daily rotate 7 compress missingok notifempty create 640 tomcat adm copytruncate } - 这里有几点需要特别注意:
- 选择
copytruncate:这个选项非常关键。对于像Tomcat这样可能长期持有日志文件句柄的Ja va应用,直接移动(move)日志文件会导致日志写入失败。copytruncate会先复制原文件内容,然后清空原文件,从而避免这个问题。 - 信号重载:如果你的应用支持通过接收信号(如SIGHUP或USR1)来重新打开日志文件,那么可以去掉
copytruncate,改用postrotate脚本发送信号,这样效率更高。 - 权限设置:注意
create 640 tomcat adm这一行。它确保了新创建的日志文件权限为640,属主是Tomcat的运行用户(通常是tomcat),属组是adm,既保证了Tomcat有写入权限,又便于系统管理员读取。
- 选择
- Linux自带的
- 容器日志轮转
- 别忘了Tomcat自身产生的日志,尤其是那个可能变得巨大的
catalina.out。同样可以用logrotate来管理(路径为 /var/log/tomcat9/catalina.out),策略可以设置为按日轮转并压缩,保留7到30天的历史数据,防止单个文件占用过多空间。
- 别忘了Tomcat自身产生的日志,尤其是那个可能变得巨大的
四 集中式日志与日常运维
当日志分散在多台服务器或多个应用中时,集中管理就成了必然选择。同时,掌握几个日常命令能让运维工作事半功倍。
- 集中式日志
- 对于稍具规模的环境,强烈建议搭建集中式日志系统。将日志统一发送到ELK Stack(Elasticsearch, Logstash, Kibana)或Graylog这样的平台。好处显而易见:可以实现日志的统一采集、快速检索、可视化分析,甚至设置关键错误告警。这对于管理多实例、多环境的复杂系统至关重要。
- 日常运维命令
- 实时查看容器日志:这是最常用的命令,能让你看到应用实时的输出和错误。
sudo tail -f /var/log/tomcat9/catalina.out - 查看系统日志:如果应用配置了将日志输出到系统日志(syslog/journald),可以用这些命令查看。
sudo tail -f /var/log/syslog journalctl -u tomcat9 -f - 查看访问日志:分析流量模式、响应状态码和潜在攻击,访问日志是金矿。
sudo tail -f /var/log/tomcat9/localhost_access_log.*.txt - 检查磁盘与增长趋势:定期检查,防患于未然。
df -h du -sh /var/log/yourapp /var/log/tomcat9 - 安全建议:最后,必须警惕日志安全。绝对避免在日志中打印密码、API密钥、个人身份信息等敏感数据。同时,务必为日志目录和文件设置最小必要权限(例如640),严格控制访问。
- 实时查看容器日志:这是最常用的命令,能让你看到应用实时的输出和错误。
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
Overlay网络中的带宽分配机制
Overlay网络带宽分配机制全景 一、核心机制分类 面对复杂的网络需求,Overlay网络的带宽分配并非只有单一解法。下面这几种核心机制,基本覆盖了从底层调度到上层应用的全景。 层级化队列与多级带宽分配(HQoS):这套机制的精髓在于“分层管理”。它先将物理链路带宽虚拟成多条逻辑链路,在第一层,带
nohup命令如何避免僵尸进程的产生
nohup命令如何避免僵尸进程的产生 在Linux系统管理中,nohup命令堪称后台任务的“守护神”——它能让程序在终端关闭后依然持续运行。但话说回来,这个强大的工具如果用得不对,也可能带来一个经典的系统管理难题:僵尸进程。简单来说,僵尸进程就是那些已经执行完毕、却还“赖”在系统进程表里等待父进程来
dmesg中内核崩溃原因分析
dmesg:解读Linux内核崩溃的“黑匣子” 在Linux世界里,当系统深处发生严重故障时,内核会留下关键的线索。这些线索就记录在dmesg(即display message或driver message)的输出里。这个命令堪称系统的“黑匣子”,专门用于显示内核启动过程以及运行时的各种状态信息。一
如何通过dmesg查看磁盘状态
dmesg:洞察Linux磁盘状态的利器 在Linux世界里,dmesg(即display message或driver message)堪称系统诊断的“黑匣子”。这个命令行工具能实时展示内核从启动到运行期间的各种信息,其中就包含了关于磁盘硬件的关键动态——从设备检测、驱动加载,到运行中可能出现的错
Ubuntu PHP日志格式怎么修改
如何修改Ubuntu中PHP日志的格式 想给Ubuntu系统里的PHP日志换个格式?这事儿其实不复杂,核心操作就是编辑PHP的配置文件——php ini。下面咱们一步步来,保证你能搞定。 首先,打开终端。记住这个万能快捷键:Ctrl + Alt + T,几乎能应对所有Linux桌面环境。 接下来,得
- 日榜
- 周榜
- 月榜
1
2
3
4
5
6
7
8
9
10
1
2
3
4
5
6
7
8
9
10
相关攻略
2015-03-10 11:25
2015-03-10 11:05
2021-08-04 13:30
2015-03-10 11:22
2015-03-10 12:39
2022-05-16 18:57
2025-05-23 13:43
2025-05-23 14:01
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程
热门话题

