Java项目无法启动排查





请添加图片描述

1.启动服务发现 无法写入日志也无法启动项目

2.df查看磁盘占用情况 、free -h查看内存占用、top查看CPU使用率负载率

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

3.此时磁盘满

如果磁盘满了,jar服务可能无法启动,因为可能会导致无法创建临时文件或者pid文件等。你可以尝试以下方法解决这个问题:

  • 删除一些不必要的文件或者移动一些文件到其他位置,释放磁盘空间。
  • 检查哪些目录或者文件占用了较多的磁盘空间,比如日志文件,定期清理或者压缩。
  • 重启服务器,进入单用户模式,查看并修复磁盘问题。

jps会读取java临时文件,而临时文件会存储对应jar启动的各种参数信息等。

4.清理磁盘

我的日志文件存放在/usr/local/tomcat/logs下,文件名以.log结尾,我想保留一个月的日志文件,把清理日志的脚本设置成每天执行一次。

把它保存为一个.sh文件,比如clean_log.sh,然后赋予它可执行权限,比如chmod +x clean_log.sh,然后把它添加到crontab中,比如crontab -e,然后在文件末尾添加一行,比如0 0 * * * /path/to/clean_log.sh,这样就可以每天凌晨执行一次清理日志的脚本了。以下是脚本的内容:

#!/bin/bash
# Define the log directory and the file pattern,日志位置
LOG_DIR=/usr/local/tomcat/logs
# 日志正则
LOG_FILE=*.log
# Define the date format and the retention period
# 时间判断
DATE_FORMAT=%Y%m%d
# 保存30天
RETENTION=30
# Find the log files that are older than the retention period and delete them
# 发现并且删除
find $LOG_DIR -name "$LOG_FILE" -type f -mtime +$RETENTION -exec rm -f {} \;
# Exit with success
exit 0

5.定时任务

  1. 首先,你需要把脚本保存为一个.sh文件,比如clean_log.sh,然后赋予它可执行权限,比如chmod +x clean_log.sh
  2. 然后,你可以直接运行这个脚本,比如./clean_log.sh,或者使用bash命令运行它,比如bash clean_log.sh
  3. 如果你想要把这个脚本设置成定时任务,你可以使用crontab命令编辑你的定时任务列表,比如crontab -e,然后在文件末尾添加一行,比如0 0 * * * /path/to/clean_log.sh,这样就可以每天凌晨执行一次清理日志的脚本了。

查看任务

  1. 你可以使用tail -f /var/log/cron命令查看定时任务的执行日志,找到你的脚本的执行记录,比如CROND[12345]: (root) CMD (/path/to/clean_log.sh),这表示这个脚本被执行了。
  2. 你可以使用ps -ef | grep clean_log.sh命令查看你的脚本的进程信息,找到你的脚本的进程号,比如root 12345 1 0 00:00 ? 00:00:00 /bin/bash /path/to/clean_log.sh,这表示这个脚本正在运行。






如有错误欢迎指正

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要使用Arthas来排查Java项目的内存泄漏问题,你可以按照以下步骤进行操作: 1. 下载和启动Arthas:你可以在Arthas的官方网站(https://arthas.aliyun.com/)上下载最新版本的Arthas,并按照前面提到的步骤启动Arthas。 2. 选择目标进程:输入`select <pid>`命令,其中`<pid>`是你想诊断的Java进程的进程ID。 3. 开启HeapDump:输入`heapdump`命令,Arthas将会生成一个Heap Dump文件,用于分析内存使用情况。 4. 分析Heap Dump文件:将Heap Dump文件下载到本地,并使用Java内存分析工具,如Eclipse Memory Analyzer(MAT)或VisualVM等,打开该文件进行分析。这些工具可以帮助你定位内存泄漏的原因和具体的对象引用关系。 5. 使用Arthas命令:在Arthas中,你可以使用`jmap`命令查看Java堆内存的使用情况,使用`jclassloader`命令查看类加载器信息,使用`dashboard`命令查看实时的性能指标等等。这些命令可以帮助你进一步分析内存泄漏问题。 6. 根据分析结果进行修复:根据内存分析工具和Arthas的结果,定位到可能引起内存泄漏的代码或对象,然后进行相应的修复,如释放资源、修正错误的引用等。 请注意,内存泄漏问题的排查并不是一项简单的任务,需要结合工具和分析技巧进行深入分析。同时,也建议在项目开发过程中注意内存使用和资源释放,以避免潜在的内存泄漏问题的产生。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一只小小狗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值