Java项目无法启动排查
- 1.启动服务发现 无法写入日志也无法启动项目
- 2.df查看磁盘占用情况 、free -h查看内存占用、top查看CPU使用率负载率
- 3.此时磁盘满
- 4.清理磁盘
- 5.定时任务
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.定时任务
- 首先,你需要把脚本保存为一个.sh文件,比如
clean_log.sh
,然后赋予它可执行权限,比如chmod +x clean_log.sh
。 - 然后,你可以直接运行这个脚本,比如
./clean_log.sh
,或者使用bash命令运行它,比如bash clean_log.sh
。 - 如果你想要把这个脚本设置成定时任务,你可以使用crontab命令编辑你的定时任务列表,比如crontab -e,然后在文件末尾添加一行,比如
0 0 * * * /path/to/clean_log.sh
,这样就可以每天凌晨执行一次清理日志的脚本了。
查看任务
- 你可以使用tail -f /var/log/cron命令查看定时任务的执行日志,找到你的脚本的执行记录,比如CROND[12345]: (root) CMD (/path/to/clean_log.sh),这表示这个脚本被执行了。
- 你可以使用ps -ef | grep clean_log.sh命令查看你的脚本的进程信息,找到你的脚本的进程号,比如root 12345 1 0 00:00 ? 00:00:00 /bin/bash /path/to/clean_log.sh,这表示这个脚本正在运行。
如有错误欢迎指正