JVM的一些工具的簡要使用

来源:https://www.cnblogs.com/godoforange/archive/2019/09/22/11569594.html
-Advertisement-
Play Games

JConsole(可視化工具) 運行 JConsole記憶體監控 測試代碼 這裡看到我們有倆個線程。 JPS(JVM Process status) JPS是使用的頻率最高的工具,和linux下的ps命令差不多(把J去掉就是一個ps)。 因為我這裡開啟了一個eclipse,所以運行結果如下所示: 如果 ...


JConsole(可視化工具)

運行

JConsole記憶體監控

測試代碼

import java.util.ArrayList;
import java.util.List;

public class A {
    byte[] b1 = new byte[128*1024];
    public static void main(String[] args) {
        try {
            Thread.sleep(5000);
        }catch(Exception e) {
            
        }
        System.out.println("start...");
        fill(1000);
    }
    private static void fill(int n) {
        List<A> jlist = new ArrayList<A>();
        for(int i=0;i<n;i++) {
            try {
                Thread.sleep(100);
            }catch(Exception e) {
                jlist.add(new A());
            }
        }
    }
}

然後開啟jconsole進行連接。

連接後執行一次GC後會發現Eden區域直降一次。

JConsole線程監控。

測試代碼:

import java.util.Scanner;

public class A {
    byte[] b1 = new byte[128*1024];
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        sc.next();
        new Thread(()->{
            while(true) {
                
            }
        },"while true線程").start();  
        new Thread(()->{
            synchronized(A.class) {
                try {
                    Thread.sleep(60000000);
                }catch(InterruptedException e) {
                    e.printStackTrace();
                }   
            }
        },"wait 線程").start();
        
    }
}

這裡看到我們有倆個線程。

JPS(JVM Process status)

JPS是使用的頻率最高的工具,和linux下的ps命令差不多(把J去掉就是一個ps)。

因為我這裡開啟了一個eclipse,所以運行結果如下所示:

如果打開任務管理器,就會發現這裡的11612就是我們的pid

因此JPS能夠查看:本地虛擬機唯一ID(lvmid local virtual machine id)

測試代碼:

import java.util.Scanner;

public class A {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        sc.next();
    }
}

使用jps -l 查看主類

jps -l

使用jps -m 查看運行時的參數

jps -m

使用jps -v 查看虛擬機參數

jps -v

(上次寫的程式還留著參數,所以看起來會有很多)

使用mlv就能查看所有參數。

jps -mlv

Jstat(JVM state)

能看到類載入,記憶體,垃圾收集。

jstat -gcutil

能查指定id的GC

看這個就已經矇蔽了,所以我們來看一下官方文檔。

鏈接在這

看完之後翻譯一下:
|參數|作用|
|----|----|
|S0|Survivor空間0的利用率占當前容量的百分比|
|S1|Survivor空間1的利用率占當前容量的百分比|
|E|Eden區域。。。|
|O|老年代|
等等

jstat -gcutil 8082 1000

每隔1000ms導出一次gc

元空間:本質和永久代類似,都是對JVM規範中方法區的實現。不過元空間與永久代的最大區別在於:元空間並不在虛擬機中,而是使用本地記憶體。因此,預設情況下,元空間的大小僅受本地記憶體限制。

jinfo

實時查看和調整虛擬機的各種參數。

jinfo -flag UseG1GC 8082

我們可以看到eclipse使用的就是G1收集器。

還可以動態的去修改JVM參數設置。

jmap

將jvm堆記憶體dump下來

jmap -dump:format=b,file=C:\Users\GodofOrange\Desktop\a.bin 8082

顯示堆中的統計信息。

jmap -histo 8028 > a.txt

jstack

列印線程信息

jstack -F 8028

列印棧信息

jstack -m 8028


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 上篇文章 "SpringBoot自動裝配原理解析" 中,我們分析了SpringBoot的自動裝配原理以及 註解的原理,本篇文章則繼續基於上篇文章中的main方法來分析 這個類 點擊 方法一路跟蹤下來,發現首先做的是實例化 對象實例 1. 首先看一下 方法 大抵意思就是根據當前項目中是否存在上方的幾個 ...
  • 最近將萬方數據的爬取代碼進行了重構,速度大概有10w每小時吧,因為屬於公司項目,代碼暫時就不開源了,所以在這裡先說說思路和一些註意事項吧,順帶吐槽一下萬方。 先上圖: 其實邏輯也蠻簡單的,醫學類的期刊分了16個大類,那麼首先手動將這16大類所對應的唯一id拿下來拼接出該類型的url,然後翻頁請求它就 ...
  • 函數概述 qsort 為quick sort的簡寫,意為快速排序,主要用於對各種數組的排序,在頭文件stdlib.h中。 因為數組的元素可能是任何類型的,甚至是結構或者聯合,所以必須高數函數qsort如何確定兩個數組元素哪一個“更小”,這就需要我們給出比較的規則,即什麼算大,什麼算小。 通過編寫比較 ...
  • 在 Spring Cloud 微服務系統中,一種常見的負載均衡方式是,客戶端的請求首先經過負載均衡(Ngnix),再到達服務網關(Zuul 集群),然後再到具體的服務。服務統一註冊到高可用的服務註冊中心集群,服務的所有的配置文件由配置服務管理,配置服務的配置文件放在 GIT 倉庫,方便開發人員隨時改 ...
  • 前言 越來越多的項目已經使用 "Java 8" 了,毫無疑問, "Java 8" 是Java自Java 5(發佈於2004年)之後的最重要的版本。這個版本包含語言、編譯器、庫、工具和 JVM 等方面的十多個新特性。在本文中我們將學習這些新特性,並用實際的例子說明在什麼場景下適合使用。 引用: 本文參 ...
  • R語言構建蛋白質網路並實現GN演算法 1.蛋白質網路的構建 我們使用與人類HIV相關的蛋白質互作數據hunam HIV PPI.csv來構建這個蛋白質互作網路。 在R中,我們可以從存儲在R環境外部的文件讀取數據。還可以將數據寫入由操作系統存儲和訪問的文件。 R可以讀取和寫入各種文件格式,如:csv,e ...
  • 面試題 如何保證消息的順序性? 面試官心理分析 其實這個也是用 MQ 的時候必問的話題,第一看看你了不瞭解順序這個事兒?第二看看你有沒有辦法保證消息是有順序的?這是生產系統中常見的問題。 面試題剖析 我舉個例子,我們以前做過一個 mysql 同步的系統,壓力還是非常大的,日同步數據要達到上億,就是說 ...
  • 發現模塊和集群的形成 目標 發現節點 Master選舉 組成集群,在Master信息發生變化時及時更新。 故障檢測 細分為幾個子模塊 Discovery發現模塊 Discover是在集群Master節點未知時,互相發現對方的過程,例如新節點的加入或是先前的主節點宕機,如果一個節點不滿足Master資 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...