商城首页欢迎来到中国正版软件门户

您的位置:首页 >JSP应用在Ubuntu上的日志管理

JSP应用在Ubuntu上的日志管理

  发布于2026-04-23 阅读(0)

扫一扫,手机访问

JSP应用在Ubuntu上的日志管理

JSP应用在Ubuntu上的日志管理

一 日志来源与存放位置

要管好日志,首先得知道它们从哪来、往哪去。对于运行在Ubuntu上的JSP应用,日志主要来自两个层面。

  • 容器与应用日志:JSP通常运行在Apache Tomcat之上,因此Tomcat的日志是首要关注点。它们通常位于 /var/log/tomcat9/ 目录下。几个核心文件需要记住:catalina.out(记录了标准输出和错误信息)、localhost..log(主机相关日志)、以及 localhost_access_log..txt(访问日志)。这些文件覆盖了从启动、部署到运行期的各种异常和访问轨迹,堪称排查问题的“第一现场”。如果你是通过包管理器安装的Tomcat,日志默认就会写入这个目录。
  • 应用内日志:除了容器日志,业务逻辑产生的日志同样关键。最佳实践是使用日志框架,将业务日志输出到独立的目录,例如 /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());
      }
      %>
    • 它的配置也足够灵活,完全可以通过配置文件实现按文件大小或时间进行滚动切割,满足基本需求。
  • 使用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个历史文件,管理起来非常省心。
  • 使用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,意味着你能获得更完善的日志管理功能,包括高性能的异步日志记录,这对于生产环境尤其有价值。

三 系统级日志轮转与权限

应用能写日志了,但如果不加管理,日志文件会无限膨胀,最终拖垮磁盘。这时候,系统级的日志轮转工具就该上场了。

  • 使用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有写入权限,又便于系统管理员读取。
  • 容器日志轮转
    • 别忘了Tomcat自身产生的日志,尤其是那个可能变得巨大的catalina.out。同样可以用logrotate来管理(路径为 /var/log/tomcat9/catalina.out),策略可以设置为按日轮转并压缩,保留7到30天的历史数据,防止单个文件占用过多空间。

四 集中式日志与日常运维

当日志分散在多台服务器或多个应用中时,集中管理就成了必然选择。同时,掌握几个日常命令能让运维工作事半功倍。

  • 集中式日志
    • 对于稍具规模的环境,强烈建议搭建集中式日志系统。将日志统一发送到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),严格控制访问。
本文转载于:https://www.yisu.com/ask/37824982.html 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

热门关注