Linux查看jar包错误日志及持久化运行jar包

一、查看jar包运行信息命令:ps -ef | grep java

如图,给出了所部署jar包的环境变量,服务名称,服务端口信息。

这样便能得到部署的jar包是否在服务器成功运行及基本信息。

二、查看日志

启动信息无误,查看日志是否有报错。

监控命令:tail -fn 200 XXX (XXX为日志根路径) 查看近200日志信息

根据错误日志信息去解决即可。

附加:线上查看服务日志如何更加方便?

一、标准输出

java -jar your-app.jar 命令是在服务器控制台的标准输出,即默认情况下,日志会输出到当前窗口,这是最简单的启动方式。
二、指定日志输出文件.

上面这种方式查看日志并不方便,需要一直盯着服务器的输出内容来找报错信息。

那是不是将日志信息存入一个文件中查询会更加方便呢?是的,我们可以将日志重定向输出到指定文件中:使用 > 或 >> 符号

例:java -jar chat-1.0-SNAPSHOT.jar > chat.log 2>&1

(2>&1的作用是同时捕获错误输出(stderr),可以将两个输出合并)

进入chat.log,这样我们就能更加方便查看成功与错误日志。

三、指定日志输出文件并持久化运行

虽然2能帮助我们更加方便的查看日志信息,但是还有一个缺点就是服务器关闭后,jar包也会随之停止运行,不能实时检测我们的运行信息。怎么解决?那就是后台运行并持久化日志。

可以使用 nohup 命令可以使程序在后台运行并且不会因为关闭SSH会话而停止,同时日志会写入 nohup.out 文件。

例:nohup java -jar chat-1.0-SNAPSHOT.jar > custom.log 2>&1 &

  • 此时正在运行的服务一方面不会因为我们关闭服务器而关闭
  • 另一方面也能更加方便我们查看该服务日志信息
相关推荐
Web3探索者1 天前
可视化服务器管理和传统命令行区别是什么?新手教程:Linux 运维到底该用图形界面还是 SSH 命令行?
linux·ssh
zylyehuo1 天前
Linux系统中网线与USB网络共享冲突
linux
荣--1 天前
一键部署不是为了省时间 —— 它是把"买来的 PaaS"变成"自己的平台"的拐点
运维·zabbix·工程化·一键部署·平台化·边界设计
江华森1 天前
动手实战学 Docker — 从零到集群编排完全指南
运维
Avan_菜菜2 天前
FRP 内网穿透完整实战:从 HTTP 映射到 HTTPS 自签代理
运维·nginx·https
Sokach10152 天前
Linux Shell 脚本从零到能用:一个新手的一天学习总结
linux
SelectDB3 天前
Litefuse 开源并推出单进程轻量模式,25 秒就能跑起来的 Agent 可观测与评估平台
运维·后端·自动化运维
AlfredZhao3 天前
Docker 容器时区不对,`timedatectl` 不存在怎么办?
linux·timezone
zzzzzz3104 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
XIAOHEZIcode4 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏