文学は、JVMの設定パラメータやツールになります

様々な以前の分析の後、我々は、このようなバージョン情報、クラスのロード、ヒープ、メソッドエリア、ガベージコレクションなどのように、JVMに関する多くの知識を知っているが、常にいくつかの本当のものを見ていないので、私の心は、実用的ではないことを感じました。

そこで、この記事では、我々はこれらの要素を視覚的に応じて設定の方法をいくつか含めて、私たちの前に表示されているかについての良いチャットに行きます。OK、行こう!

8.1 JVMパラメータ

8.1.1標準的なパラメータ

-版

-助けて

-サーバ

-cp

8.1.2 -Xパラメータ

JDKのさまざまなバージョンに変更する可能性がある非標準的なパラメータ、

-Xint解釈

ネイティブコードにコンパイル初めて-Xcomp

決定する-Xmixed混合モード、JVM

8.1.3 -XXパラメータ

最も使用されているパラメータの型

非標準化パラメータは、比較的不安定であり、主にチューニングJVMのデバッグのために使用されています

a.Booleanタイプ

フォーマット:-XX:[+ - ] <名前> +または - name属性が有効か無効を示しています

たとえば、-XX:+ UseConcMarkSweepGCをCMSがガベージコレクタの種類を表す有効

-XX:+ UseG1GC有効G1は、ガベージコレクタのタイプを表します

B。非ブール型の

フォーマット:-XXは、name属性の値を表し、<名前> = <値>が値であります

たとえば、-XX:MaxGCPauseMillis = 500

あなたが設定したい場合は、まず、デフォルトのJVMパラメータに関連する情報を知っている必要があります

以下は、このプロセスのためのJavaです

Javaの-XX:+ PrintFlagsFinal -version> flags.txt

あなたが実行中のJVMパラメータに関連する情報を表示したい場合はJinfoのを使用しますが、最初のIDのJavaプロセスを知ることができます。

そのようなTomcatを出発物質として、そのPIDが2908、図に示す以下の処理です。

あなたはjinf 0によってより多くのを見たい場合は

設定パラメータの一般的な方法

*このようIDEA、Eclipseなどの開発ツールのセット

*ときのjarパッケージを実行します。java -XX:+ UseG1GC xxx.jar

* TomcatなどのWebコンテナは、スクリプト内で設定することができます

* 通过jinfo实时调整某个java进程的参数(参数只有被标记为manageable的flags可以被实时修改)

8.1.4 其他参数

-Xms1000等价于-XX:InitialHeapSize=1000

-Xmx1000等价于-XX:MaxHeapSize=1000

-Xss100等价于-XX:ThreadStackSize=100

所以这块也相当于是-XX类型的参数

8.1.5 说明

一般要设置参数,可以先查看一下当前参数是什么,值得注意的是"="表示默认值,":="表示被用户或JVM修改后的值。

8.1.6 单位换算

1Byte(字节)=8bit(位)

1KB=1024Byte(字节)

1MB=1024KB

1GB=1024MB

1TB=1024GB

8.1.7 常用参数含义

8.2 常用命令

官网Search

<https://docs.oracle.com/apps/search/search.jspcategory=java&q=>

8.2.1 jps

查看java进程

The jps command lists the instrumented Java HotSpot VMs on the target system. The command is limited to reporting information on JVMs for which it has the access permissions.

8.2.2 jinfo

实时查看和调整JVM配置参数

The jinfo command prints Java configuration information for a specified Java process or core file or a remote debug server. The configuration information includes Java system properties and Java Virtual Machine (JVM) command-line flags.

查看用法

jinfo -flag name PID     查看某个java进程的name属性的值

比如:

jinfo -flag MaxHeapSize PID

jinfo -flag UseG1GC PID

调整用法

参数只有被标记为manageable的flags可以被实时修改

jinfo -flag [+|-] PID

jinfo -flag <name>=<value> PID

查看曾经赋过值的一些参数

jinfo -flags PID

8.2.3 jstat

查看虚拟机性能统计信息

The jstat command displays performance statistics for an instrumented Java HotSpot VM. The target JVM is identified by its virtual machine identifier, or vmid option.

查看类装载信息

jstat -class PID 1000 10      查看某个java进程的类装载信息,每1000毫秒输出一次,共输出10次

比如:

jstat -class PID 1000 10

查看垃圾收集信息

jstat -gc PID 1000 10

8.2.4 jstack

查看线程堆栈信息

The jstack command prints Java stack traces of Java threads for a specified Java process, core file, or remote debug server.

用法

jstack PID

8.2.5 jmap

生成堆转储快照

The jmap command prints shared object memory maps or heap memory details of a specified process, core file, or remote debug server.

打印出堆内存相关信息

jmap -heap PID

dump出堆内存相关信息

jmap -dump:format=b,file=heap.hprof PID

关于dump下来的文件

一般dump下来的文件直接看有些费力,可以结合MAT工具来分析。

`一般在开发中,JVM参数可以加上下面两句,这样内存溢出时,会自动dump出该文件`

-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=heap.hprof

8.3 常用工具

8.3.1 jconsole

JConsole工具是JDK自带的可视化监控工具。查看java应用程序的运行概况、监控堆信息、永久区使用情况、类加载情况等。

8.3.2 jvisualvm

(1)可以监控本地的java进程的CPU,类,线程等

(2)也可以监控远端java进程,比如监控远端tomcat

如果是连接远端tomcat[也可以是任意Java进程],比如部署在阿里云服务器上的tomcat,可以按照以下步骤

(1)在visualvm中选中“远程”,右击“添加”>

(2)主机名上写服务器的ip地址,比如39.100.39.63

(3)右击该主机,添加“JMX”,也就是通过JMX技术具体监控远端服务器哪个Java进程

(4)要想让服务器上的tomcat被连接,需要改一下Catalina.sh这个文件

`注意下面的8998不要和服务器上其他端口冲突`> ```

JAVA_OPTS="$JAVA_OPTS -Dcom.sun.management.jmxremote

-Djava.rmi.server.hostname=39.100.39.63

-Dcom.sun.management.jmxremote.port=8998

-Dcom.sun.management.jmxremote.ssl=false

-Dcom.sun.management.jmxremote.authenticate=true

-Dcom.sun.management.jmxremote.access.file=../conf/jmxremote.access

-Dcom.sun.management.jmxremote.password.file=../conf/jmxremote.password"

(5)在../conf文件中添加两个文件jmxremote.access和jmxremote.password

jmxremote.access

guest readonly

manager readwrite

jmxremote.password

guest guest

manager manager>

`授予权限`:`chmod 600 *jmxremot*`

(6)将连接服务器地址改为公网ip地址

hostname -i   查看输出情况

172.26.225.240 172.17.0.1

vim /etc/hosts

172.26.255.240 39.100.39.63

(7)查看8998监听情况,可以发现多开了几个端口

lsof -i:8998    得到PID

netstat -antup | grep PID

(8)设置上述端口对应的阿里云安全策略和防火墙策略

(9)启动tomcat,可以查看一下日志情况

(6)在刚才的JMX中输入8998端口,并且输入用户名和密码则登录成功

8.3.3 内存分析MAT

8.3.4  GC日志分析工具

要想分析日志的信息,得先拿到GC日志文件才行,所以得先配置一下,根据前面的参数,下面的配置很容易看懂

XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintGCDateStamps

-Xloggc:$CATALINA_HOME/logs/gc.log

在线

http://gceasy.io

GCViewer

おすすめ

転載: www.cnblogs.com/xueSpring/p/11611535.html