亚洲 国产精品 日韩-亚洲 激情-亚洲 欧美 91-亚洲 欧美 成人日韩-青青青草视频在线观看-青青青草影院

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > Java 并發編程解析 |Java JVM 調優

Java 并發編程解析 |Java JVM 調優

來源:千鋒教育
發布人:qyf
時間: 2022-08-03 15:07:00 1659510420

2

  JVM調優涉及到兩個很重要的概念:吞吐量和響應時間。jvm調優主要是針對他們進行調整優化,達到一個理想的目標,根據業務確定目標是吞吐量優先還是響應時間優先。

  吞吐量:用戶代碼執行時間/(用戶代碼執行時間+GC執行時間)。

  響應時間:整個接口的響應時間(用戶代碼執行時間+GC執行時間),stw時間越短,響應時間越短。

  調優的前提是熟悉業務場景,先判斷出當前業務場景是吞吐量優先還是響應時間優先。調優需要建立在監控之上,由壓力測試來判斷是否達到業務要求和性能要求。 調優的步驟大致可以分為:

  熟悉業務場景,了解當前業務系統的要求,是吞吐量優先還是響應時間優先;

  選擇合適的垃圾回收器組合,如果是吞吐量優先,則選擇ps+po組合;如果是響應時間優先,在1.8以后選擇G1,在1.8之前選擇ParNew+CMS組合;

  規劃內存需求,只能進行大致的規劃。

  CPU選擇,在預算之內性能越高越好;

  根據實際情況設置升級年齡,最大年齡為15;

  根據需要設定相關的JVM日志參數:

  -Xloggc:/path/name-gc-%t.log

  -XX:+UseGCLogFileRotation

  -XX:NumberOfGCLogs=5

  -XX:GCLogFileSize=20M

  -XX:+PrintGCDetails

  -XX:+PrintGCDateStamps

  -XX:+PrintGCCauses

  其中需要注意的是:

  -XX:+UseGCLogFileRotation:GC文件循環使用

  -XX:NumberOfGCLogs=5:使用5個GC文件

  -XX:GCLogFileSize=20M:每個GC文件的大小

  上面這三個參數放在一起代表的含義是:5個GC文件循環使用,每個GC文件20M,總共使用100M存儲日志文件,當5個GC文件都使用完畢以后,覆蓋第一個GC日志文件,生成新的GC文件。

  當cpu經常飆升到100%的使用率,那么證明有線程長時間占用系統資源不進行釋放,需要定位到具體是哪個線程在占用,定位問題的步驟如下(linux系統):

  1.使用top命令常看當前服務器中所有進程(jps命令可以查看當前服務器運行java進程),找到當前cpu使用率最高的進程,獲取到對應的pid;

  2.然后使用top -Hp pid,查看該進程中的各個線程信息的cpu使用,找到占用cpu高的線程pid

  3.使用jstack pid打印它的線程信息,需要注意的是,通過jstack命令打印的線程號和通過top -Hp打印的線程號進制不一樣,需要進行轉換才能進行匹配,jstack中的線程號為16進制,而top -Hp打印的是10進制。

  當內存飆高一般都是堆中對象無法回收造成,因為java中的對象大部分存儲在堆內存中。其實也就是常見的oom問題(Out Of Memory),一般:

  1.jinfo pid,可以查看當前進行虛擬機的相關信息列舉出來

  2.jstat -gc pid ms,多長毫秒打印一次gc信息,打印信息如下,里面包含gc測試,年輕代/老年帶gc信息等

  3. jmap -histo pid | head -20,查找當前進程堆中的對象信息,加上管道符后面的信息以后,代表查詢對象數量最多的20個

  4. jmap -dump:format=b,file=xxx pid,可以生成堆信息的文件,但是這個命令不建議在生產環境使用,因為當內存較大時,執行該命令會占用大量系統資源,甚至造成卡頓。建議在項目啟動時添加下面的命令,在發生oom時自動生成堆信息文件:-XX:+HeapDumpOnOutOfMemory。如果需要在線上進行堆信息分析,如果當前服務存在多個節點,可以下線一個節點,生成堆信息,或者使用第三方工具,阿里的arthas。

  除此之外,我們還可以使用 jvisualvm是jdk自帶的圖形化分析工具,可以對運行進程的線程,堆進行詳細分析。但是這種分析工具可以對本地代碼或者測試環境進行監控分析,不建議在線上環境使用該工具,因為它會占用系統資源。如果必須要在線上執行,建議當前服務存在多個節點,然后下線其中一個節點進行問題分析。也可以使用第三方收費的圖形分析界面jprofiler。

  注意事項:

  在日常JVM調優常用參數主要如下:

  通用GC常用參數:

  -Xmn:年輕代大小

  -Xms:堆初始大小

  -Xmx:堆最大大小

  -Xss:棧大小

  -XX:+UseTlab:使用tlab,默認打開,涉及到對象分配問題

  -XX:+PrintTlab:打印tlab使用情況

  -XX:+TlabSize:設置Tlab大小

  -XX:+DisabledExplictGC:java代碼中的System.gc()不再生效,防止代碼中誤寫,導致頻繁觸動GC,默認不起用。

  -XX:+PrintGC(+PrintGCDetails/+PrintGCTimeStamps) : 打印GC信息(打印GC詳細信息/打印GC執行時間)

  -XX:+PrintHeapAtGC打印GC時的堆信息

  -XX:+PrintGCApplicationConcurrentTime: 打印應用程序的時間

  -XX:+PrintGCApplicationStopedTime: 打印應用程序暫停時間

  -XX:+PrintReferenceGC: 打印回收多少種引用類型的引用

  -verboss:class : 類加載詳細過程

  -XX:+PrintVMOptions : 打印JVM運行參數

  -XX:+PrintFlagsFinal(+PrintFlagsInitial) -version | grep : 查找想要了解的命令

  -X:loggc:/opt/gc/log/path : 輸出gc信息到文件

  -XX:MaxTenuringThreshold : 設置gc升到年齡,最大值為15

  Parallel GC 常用參數:

  -XX:PreTenureSizeThreshold 多大的對象判定為大對象,直接晉升老年代

  -XX:+ParallelGCThreads 用于并發垃圾回收的線程

  -XX:+UseAdaptiveSizePolicy 自動選擇各區比例

  CMS GC 常用參數:

  -XX:+UseConcMarkSweepGC :使用CMS垃圾回收器

  -XX:parallelCMSThreads : CMS線程數量

  -XX:CMSInitiatingOccupancyFraction : 占用多少比例的老年代時開始CMS回收,默認值68%,如果頻繁發生serial old,適當調小該比例,降低FGC頻率

  -XX:+UseCMSCompactAtFullCollection : 進行壓縮整理

  -XX:CMSFullGCBeforeCompaction :多少次FGC以后進行壓縮整理

  -XX:+CMSClassUnloadingEnabled :回收永久代

  -XX:+CMSInitiatingPermOccupancyFraction :達到什么比例時進行永久代回收

  -XX:GCTimeTatio : 設置GC時間占用程序運行時間的百分比,該參數只能是盡量達到該百分比,不是肯定達到

  -XX:MaxGCPauseMills : GCt停頓時間,該參數也是盡量達到,而不是肯定達到

  G1 GC 常用參數:

  -XX:+UseG1 : 使用G1垃圾回收器

  -XX:MaxGCPauseMills : GCt停頓時間,該參數也是盡量達到,G1會調整yong區的塊數來達到這個值

  -XX:+G1HeapRegionSize : 分區大小,范圍為1M~32M,必須是2的n次冪,size越大,GC回收間隔越大,但是GC所用時間越長

  更多關于“java培訓”的問題,歡迎咨詢千鋒教育在線名師。千鋒教育多年辦學,課程大綱緊跟企業需求,更科學更嚴謹,每年培養泛IT人才近2萬人。不論你是零基礎還是想提升,都可以找到適合的班型,千鋒教育隨時歡迎你來試聽。

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
国产乱子伦一区二区三区| 爆乳JK美女脱内衣裸体网站| ZOOM与人性ZOOM视频| 公的粗大挺进了我的密道视频| 国内久久婷婷五月综合欲色广啪| 久久狠色AV噜噜狠狠狠狠97| 欧美国产日本高清不卡| 三上悠亚AV影院在线看| 亚洲AV成人片无码www电影| 亚洲中文无码A∨在线观看| CF穿越火线女去衣看奶| 国产成人一区二区精品视频| 精品一区二区三区在线播放视频| 女强人被春药精油按摩4| 色综合天天综合欧美综合| 亚洲国产成人AV网站| 99W乳液78W78W永久| 国产激情精品一区二区三区| 久久久久99精品成人片三人毛片| 亲子乱AⅤ一区二区三区| 无码专区—VA亚洲V天堂| 呦女IUU极品资源| 大学生酒店呻吟在线观看| 黑人大雞巴XXOO视频| 欧美激情视频一区| 午夜亚洲福利在线老司机| 在线观看AV黄网站永久| 风流老太婆大BBWBBWHD| 久久久久亚洲精品无码系列| 日韩Av无码一区二区| 亚洲欧洲日产国码无码AV一 | 香蕉97超级碰碰碰视频| 中文字幕久久久久人妻中出| 国产精品亚洲VA在线| 男人的天堂在线视频| 无人区码一码二码三码区别在哪里| 中国VIDEOSEX高潮对白H| 国产丰满大乳无码免费播放| 美女内射毛片在线看| 无码AV高潮喷水无码专区线| 中国XXXX真实偷拍| 国产毛片精选好视频| 欧美成人精品一区二区三区| 亚洲AV无码XXX麻豆艾秋| AV无码国产在线看免费网站 | 成人免费无码大片A毛片18| 精品无码AV无码免费专区| 日日摸日日碰人妻无码老牲| 一本一道AV无码中文字幕| 跪下吃他胯下的体育生H| 蜜芽AV在线新地址| 亚洲AV无码熟妇在线观看| 把腿张开老子CAO烂你NP皇宫| 久久EE热这里只有精品| 天天躁日日躁狠狠躁2018| 2018天天拍拍天天爽视频| 国内精品久久久久久久97牛牛| 人人做人人爽国产视| 一区二区三区欧美| 国产人与Z0XXⅩⅩ另类| 日本精品少妇一区二区三区| 野花社区日本免费图片| 国产另类TS人妖一区二区| 人妻少妇偷人精品视频| 永久免费观看国产裸体美女| 国产午夜高清高清在线观看| 日本熟妇乱人伦XXXX| 中文字幕人妻在线中字| 国精产品砖一区二区三区糖心| 日日AV色欲香天天综合网| 2023国精产品一二二线精华液| 妓女妓女影院妓女影库妓女网| 丝袜老师办公室里做好紧好爽| 97人人超碰国产精品最新o | 亚洲午夜精品一区二区| 国产乱妇乱子在线视频| 日韩乱码人妻无码超清蜜桃丨| √8天堂资源地址中文在线| 人人人爽人人澡人人高潮| 亚洲中文字幕无码第一区| 国产无套内射普通话对白| 色狠狠AV老熟女| A级毛片免费观看网站| 久久午夜夜伦鲁鲁片无码免费| 亚洲AV无码一区二区密桃精品| 国产JJIZZ女人多水喷水| 人妻有码ΑV中文字幕久久琪琪布| 真人无码作爱免费视频| 久久99精品久久久久久野外| 小妖精抬起臀嗯啊H军人| 公的粗大挺进了我的密道视频| 青草青草久热精品视频国产4| 中文字幕久久精品无码| 久久亚洲中文不卡AV一区二区| 亚洲精品456在线播放| 国产亚洲精品自在久久VR| 玩弄人妻少妇500系列视频| 成人永久免费福利视频免费| 欧洲人激情毛片无码视频| √最新版天堂资源网在线| 老赵抱着月月在厨房做视频| 亚洲综合小说区图片区| 精品欧美黑人久久久久| 亚洲爆乳无码一区二区三区| 国产男男GAY做受XXX| 无码人妻精品一区二区蜜桃温柔乡| 大色综合色综合网站| 日韩中文无码有码免费视频| 成人免费一区二区三区视频| 日本娇小枯瘦XXXX| 边做边爱免费完整版视频播放| 拍摄AV现场失控高潮数次| FREE嫩白18SEX性HD处| 欧美乱人伦中文字幕在线| 97久久精品无码一区二区| 男生把QQ放进女生的QQ里韩剧| 中文字幕人妻高清乱码| 男男射精控制PLAY小说| 97碰碰碰人妻无码视频| 欧美顶级METART裸体全部自| 99V久久综合狠狠综合久久| 欧美日韩乱一区二区三区| ASS年轻少妇BBWPICS| 欧美精品天堂一区二区不卡| JAPANESE日本护士XXX| 人妻丰满熟妇AV无码区动漫| 宝宝握住坐下~它会自己动| 日本人妻JAPANESEXXX| 大白肥妇BBVBBW高潮| 天天狠天天透天天伊人| 国产乱沈阳女人高潮乱叫老 | 国产女主播喷水视频在线观看| 香蕉视频一直看一直爽| 黑人又粗又大又 ╳乂| 亚洲欧洲精品无码AV| 久久婷婷五月综合丁香人人爽| 真实国产乱人伦在线视频播放| 你看桌子上都是你流的| А天堂最新版中文网| 色欲AV综合久久一区二区三区| 国产成人丝袜视频在线观看| 午夜性色一区二区三区不卡视频 | 亚洲METART人体欣赏| 久久精品国产99精品亚洲 | 成人区人妻精品一区二区不卡| 天堂…中文在线最新版在线| 国产麻豆剧果冻传媒| 亚洲精品国产精品乱码不卡√| 久久综合噜噜激激的五月天| AV无码人妻无码男人的天堂| 日韩精品一区二区三区色欲AV| 国产极品美女高潮无套| 亚洲国产一区二区A毛片| 老头发狂的吸住她的乳尖| BGMBGMBGM日本XX| 少妇CHINA中国人妻VIDE| 国产特级毛片AAAAAAA高清| 亚洲一区波多野结衣在线APP| 女人的选择HD中字| 大荫蒂又大又长又硬又紧| 亚洲AⅤ熟女高潮30P| 久久亚洲精品无码GV| А√在线天堂官网| 无码人妻一区二区中文| 久久成人国产精品免费软件| 99久久精品免费看国产| 舔高中女生奶头内射视频| 精产国品一二三产品区别视频手机| 真实国产乱子伦精品一区二区三区| 日本高清无卡码一区二区| 国产午夜精品一区二区三区极品| 一本加勒比HEZYO中文无码| 人妻蜜と1~4中文字幕月野定规| 国产精品门事件AV| 伊人久久大香线蕉午夜AV| 日本工口里番H彩色无遮挡全彩 | 国产乱人伦偷精品视频免| 一边做饭一边躁狂怎么办呢69| 人妻系列无码专区69影院| 国产亚洲日韩在线三区| 最新高清中文字幕免费MV| 少妇人妻88久久中文字幕| 九九在线中文字幕无码| 爸爸10岁幼儿TREE小学生| 亚洲AV无码成人精品| 男女差差差差差打扑克视频| 国产成人无码精品一区二区三区| 亚洲熟妇无码爱V在线观看| 人人妻人人澡人人爽人人精品浪潮| 国产人澡人澡澡澡人碰视| 18禁丝瓜视频安卓版| 我一边做饭一边被躁了怎么回事| 久久久久亚洲AV综合波多野结衣 | SQUIRT VIDEO喷水抽| 亚洲AV无码精品色午夜蜜芽| 欧美ZC0O人与善交的最新章节| 国产精品亚韩精品无码A在线| 337P日本欧洲亚洲大胆| 性丰满ⅩXXOOO性HD亚洲| 欧美激情一区二区三区|