jmap (Java Virtual Machine Memory Map) est un outil de ligne de commande fourni par le JDK qui peut générer un fichier de vidage d'instantané de vidage de tas de la machine virtuelle Java. De plus, la commande jmap peut également afficher des informations détaillées sur la file d'attente d'exécution de finalisation, le tas Java et la zone de méthode, telles que l'utilisation de l'espace, le garbage collector actuellement utilisé, l'état de la génération, etc.
Comme la commande jinfo, il existe encore certaines restrictions sur son utilisation sur les systèmes Windows. Dans les systèmes Windows sans dbgeng.dll
, les outils de débogage pour Windows doivent être installés pour que la commande jinfo fonctionne correctement, et la variable d'environnement PATH doit contenir l'emplacement de jvm.dll. dbgeng.dll
的Windows系统中,必须安装用于Windows的调试工具才能使jinfo命令正常工作,PATH环境变量应该包含jvm.dll的位置。
命令语法:
jmap [options] pid
命令参数说明:
option
:jmap命令的可选参数。如果没有指定这个参数,jinfo命令会显示Java虚拟机进程的内存映像信息,如下图:
pid
:要打印配置信息的Java虚拟机的进程ID。
想要要获取运行的Java虚拟机进程的列表,可以使用ps命令(Linux系统中)或tasklist命令(Windows系统中),如果Java虚拟机进程没有在单独的docker实例中运行,可以使用jps命令。
option
都有哪些参数呢?我们来看一下。
显示Java堆的如下信息:
被指定的垃圾回收算法的信息,包括垃圾回收算法的名称和垃圾回收算法的详细信息。
堆的配置信息,可能是由命令行选项指定,或者由Java虚拟机根据服务器配置选择的。
堆的内存空间使用信息,包括分代情况,每个代的总容量、已使用内存、可使用内存。如果某一代被继续细分(例如,年轻代),则包含细分的空间的内存使用信息。
比如:
显示Java堆中对象的统计信息,包括:对象数量、占用内存大小(单位:字节)和类的完全限定名。比如:
要获得某个对象的大小,可以将其总大小除以该对象类型的数量。如果指定了live
参数,则只计算活动的对象。比如:
显示Java堆中元空间的类加载器的统计信息,包括:
class_loader:当Java虚拟机运行时,类加载器对象的地址
classes:已加载类的数量
bytes:该类加载器加载的所有类的元数据所占的字节数
parent_loader:父类加载器对象的地址,如果没有显示null
。
alive:是否存活的标识,表示类加载器对象是否将被垃圾回收。
type:该类加载器的类名。
比如:
显示在F-Queue中等待Finalizer线程执行finalize方法的对象。比如:
生成Java虚拟机的堆转储快照dump文件。具体说明如下:
live
参数是可选的,如果指定,则只转储堆中的活动对象;如果没有指定,则转储堆中的所有对象。
format=b
表示以hprof二进制格式转储Java堆的内存。
file=<filename></filename>
用于指定快照dump文件的文件名。
比如:
强制模式。如果指定的pid没有响应,可以配合-dump
或-histo
Syntaxe de la commande :
rrreeeoption
: Paramètres facultatifs de la commande jmap. Si ce paramètre n'est pas spécifié, la commande jinfo affichera les informations sur l'image mémoire du processus de la machine virtuelle Java, comme indiqué ci-dessous :
pid
: L'ID de processus de la machine virtuelle Java pour imprimer les informations de configuration. 🎜🎜Pour obtenir la liste des processus de machine virtuelle Java en cours d'exécution, vous pouvez utiliser la commande ps (dans les systèmes Linux) ou la commande tasklist (dans les systèmes Windows). Si le processus de machine virtuelle Java ne s'exécute pas dans une instance Docker distincte, vous peut utiliser la commande jps. 🎜🎜Quels sont les paramètres de option
? Jetons un coup d'oeil. 🎜🎜-heap🎜🎜Affiche les informations suivantes du tas Java : 🎜live
est spécifié, seuls les objets vivants sont comptés. Par exemple : 🎜🎜🎜🎜-clstats 🎜 🎜Affiche les statistiques du chargeur de classe dans le métaespace du tas Java, notamment : 🎜🎜class_loader : lorsque la machine virtuelle Java est en cours d'exécution, l'adresse de l'objet chargeur de classenull
n'est pas affiché. live
est facultatif S'il est spécifié, seuls les objets actifs dans le tas seront vidés ; sinon Si spécifié, tous les objets du tas sont vidés. 🎜format=b
signifie vider la mémoire tas Java au format binaire hprof. 🎜file=<filename></filename>
est utilisé pour spécifier le nom de fichier du fichier de vidage d'instantané. 🎜-dump
ou -histo
. Dans ce mode, le paramètre live n'est pas pris en charge. Par exemple : 🎜🎜🎜🎜🎜-h et -help🎜🎜affichent les informations d'aide pour la commande jinfo. 🎜Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!