当前位置: 首页
编程语言
JSP应用在Ubuntu上的日志管理

JSP应用在Ubuntu上的日志管理

热心网友 时间:2026-04-23
转载

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

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
Overlay网络中的带宽分配机制

Overlay网络中的带宽分配机制

Overlay网络带宽分配机制全景 一、核心机制分类 面对复杂的网络需求,Overlay网络的带宽分配并非只有单一解法。下面这几种核心机制,基本覆盖了从底层调度到上层应用的全景。 层级化队列与多级带宽分配(HQoS):这套机制的精髓在于“分层管理”。它先将物理链路带宽虚拟成多条逻辑链路,在第一层,带

时间:2026-04-24 11:28
nohup命令如何避免僵尸进程的产生

nohup命令如何避免僵尸进程的产生

nohup命令如何避免僵尸进程的产生 在Linux系统管理中,nohup命令堪称后台任务的“守护神”——它能让程序在终端关闭后依然持续运行。但话说回来,这个强大的工具如果用得不对,也可能带来一个经典的系统管理难题:僵尸进程。简单来说,僵尸进程就是那些已经执行完毕、却还“赖”在系统进程表里等待父进程来

时间:2026-04-24 11:27
dmesg中内核崩溃原因分析

dmesg中内核崩溃原因分析

dmesg:解读Linux内核崩溃的“黑匣子” 在Linux世界里,当系统深处发生严重故障时,内核会留下关键的线索。这些线索就记录在dmesg(即display message或driver message)的输出里。这个命令堪称系统的“黑匣子”,专门用于显示内核启动过程以及运行时的各种状态信息。一

时间:2026-04-24 11:27
如何通过dmesg查看磁盘状态

如何通过dmesg查看磁盘状态

dmesg:洞察Linux磁盘状态的利器 在Linux世界里,dmesg(即display message或driver message)堪称系统诊断的“黑匣子”。这个命令行工具能实时展示内核从启动到运行期间的各种信息,其中就包含了关于磁盘硬件的关键动态——从设备检测、驱动加载,到运行中可能出现的错

时间:2026-04-24 11:27
Ubuntu PHP日志格式怎么修改

Ubuntu PHP日志格式怎么修改

如何修改Ubuntu中PHP日志的格式 想给Ubuntu系统里的PHP日志换个格式?这事儿其实不复杂,核心操作就是编辑PHP的配置文件——php ini。下面咱们一步步来,保证你能搞定。 首先,打开终端。记住这个万能快捷键:Ctrl + Alt + T,几乎能应对所有Linux桌面环境。 接下来,得

时间:2026-04-24 11:27
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程