java

jar

  • 查找jar包中pom文件:jar ftv ks-web-1.0.3.jar |grep pom.xml
  • 查看jar包的目录结构:jar ftv ks-web-1.0.3.jar

jar 命令参数说明

  • 用法: jar {ctxui}[vfmn0PMe] [jar-file] [manifest-file] [entry-point] [-C dir] files ...
  • 选项:
  • -c 创建新档案
  • -t 列出档案目录
  • -x 从档案中提取指定的 (或所有) 文件
  • -u 更新现有档案
  • -v 在标准输出中生成详细输出
  • -f 指定档案文件名
  • -m 包含指定清单文件中的清单信息
  • -n 创建新档案后执行 Pack200 规范化
  • -e 为捆绑到可执行 jar 文件的独立应用程序 指定应用程序入口点
  • -0 仅存储; 不使用任何 ZIP 压缩
  • -P 保留文件名中的前导 '/' (绝对路径) 和 ".." (父目录) 组件
  • -M 不创建条目的清单文件
  • -i 为指定的 jar 文件生成索引信息
  • -C 更改为指定的目录并包含以下文件

如果任何文件为目录, 则对其进行递归处理。 清单文件名, 档案文件名和入口点名称的指定顺序 与 'm', 'f' 和 'e' 标记的指定顺序相同。

  • 示例 1: 将两个类文件归档到一个名为 classes.jar 的档案中:
  • jar cvf classes.jar Foo.class Bar.class
  • 示例 2: 使用现有的清单文件 'mymanifest' 并将 foo/ 目录中的所有文件归档到 'classes.jar' 中:
  • jar cvfm classes.jar mymanifest -C foo/ .

  • 1.提取出内部jar包的指定文件并查看

  • jar xf aaa-0.0.1-SNAPSHOT.jar BOOT-INF/classes/application.properties
  • 2.然后可以修改文件
  • vim BOOT-INF/classes/application.properties

查看java服务使用的内存情况

1. 使用 jmap 工具

jmap(点击查看详情) 是 JDK 自带的工具,能够查看 Java 应用程序的堆内存使用情况。

步骤: 1. 查找 Java 进程的 PID: bash jps 或使用 ps 命令查找: bash ps aux | grep java

  1. 使用 jmap 查看堆内存信息: bash jmap -heap <PID> 这个命令会输出堆的使用情况,包括 Eden、Survivor、Old Gen 等区域的内存分配情况。

  2. 生成堆转储文件以便进一步分析: bash jmap -dump:live,format=b,file=heapdump.hprof <PID> 生成的 .hprof 文件可以通过 VisualVMEclipse Memory Analyzer (MAT) 等工具进行详细分析。

2. 使用 jstat 工具

jstat 可以监控 Java 虚拟机内存和 GC 的情况。

步骤: 1. 查找 Java 进程的 PID: bash jps

  1. 使用 jstat 查看 GC 状态: bash jstat -gc <PID> 1000 这个命令每隔 1 秒打印一次 GC 的统计数据,输出会包含 Eden 区、Survivor 区、Old 区的使用情况。

3. 使用 jconsoleVisualVM 图形化工具

jconsoleVisualVM 是 Java 自带的图形化监控工具,提供实时的内存、线程、GC 状态等信息。

步骤: 1. 启动 jconsolebash jconsole 或启动 VisualVMbash jvisualvm

  1. 连接到你要监控的 Java 进程。

  2. 在内存选项卡中查看实时的堆内存使用情况,并可以执行垃圾回收操作。

4. 通过 JVM 参数监控内存

你还可以使用 JVM 启动参数来让 Java 定期输出内存使用情况。

添加以下 JVM 参数

-XX:+PrintGCDetails -XX:+PrintGCDateStamps -Xloggc:/path/to/gc.log

这些参数会在 gc.log 文件中记录详细的 GC 和内存使用情况,日志可以帮助你分析服务内存的消耗模式。

5. 使用第三方监控工具

如果你需要更高级的内存监控和警报功能,可以使用一些第三方监控工具: - Prometheus + Grafana:通过 JMX 导出 Java 应用的内存使用情况,并在 Grafana 中进行可视化展示。 - New RelicDynatraceAppDynamics 等商业监控工具也支持详细的 Java 内存监控。

总结

  • jmapjstat:适合命令行查看内存使用情况。
  • jconsoleVisualVM:适合图形化界面监控。
  • GC 日志:适合长期跟踪内存和垃圾回收行为。
  • 第三方监控工具:适合生产环境中持续监控并设置报警。