成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

String類竟然是導致生產環境頻繁內存溢出的罪魁禍首!!

存儲 存儲軟件
作者個人研發的在高并發場景下,提供的簡單、穩定、可擴展的延遲消息隊列框架,具有精準的定時任務和延遲隊列處理功能。自開源半年多以來,已成功為十幾家中小型企業提供了精準定時調度方案,經受住了生產環境的考驗。

[[346987]]

作者個人研發的在高并發場景下,提供的簡單、穩定、可擴展的延遲消息隊列框架,具有精準的定時任務和延遲隊列處理功能。自開源半年多以來,已成功為十幾家中小型企業提供了精準定時調度方案,經受住了生產環境的考驗。為使更多童鞋受益,現給出開源框架地址:

https://github.com/sunshinelyz/mykit-delay

寫在前面

最近,一名小伙伴跟我說:他寫的程序在測試環境一點問題沒有,但是發到生產環境卻會頻繁出現內存溢出的情況,這個問題都困擾他一周多了。于是乎,周末我便開始幫他排查各種問題。

小伙伴的疑問

問題確定

排查問題的整個過程相當耗時,這里,我就直接說定位到的問題吧。后面,我會單獨寫一篇詳細的排查問題過程的文章!

在排查問題的過程中,我發現這位小伙伴使用的JDK還是1.6版本。開始,我也沒想那么多,繼續排查他寫的代碼,也沒找出什么問題。但是一旦啟動生產環境的程序,沒過多久,JVM就拋出了內存溢出的異常。

這就奇怪了,怎么回事呢?

啟動程序時加上合理的JVM參數,問題依然存在。。。

沒辦法,繼續看他的代碼吧!無意間,我發現他寫的代碼中,大量使用了String類的substring()方法來截取字符串。于是,我便跟到JDK中的代碼查看傳遞進來的參數。

這無意間點進來的一次查看,竟然找到了問題所在!!

JDK1.6中String類的坑

經過分析,竟然發現了JDK1.6中String類的一個大坑!為啥說它是個坑呢?就是因為它的substring()方法會把人坑慘!不多說了,我們先來看下JDK1.6中的String類的substring()方法。

  1. public String substring(int bedinIndex, int endIndex){ 
  2.     if(beginIndex < 0){ 
  3.         throw new StringIndexOutOfBoundsException(beginIndex); 
  4.     } 
  5.     if(endIndex > count){ 
  6.         throw new StringIndexOutOfBoundsException(endIndex); 
  7.     } 
  8.     if(beginIndex > endIndex){ 
  9.           throw new StringIndexOutOfBoundsException(endIndex - beginIndex); 
  10.     } 
  11.     return ((beginIndex == 0) && (endIndex == count)) ? this : new String(offset + beginIndex, endIndex - beginIndex, value); 

接下來,我們來看看JDK1.6中的String類的一個構造方法,如下所示。

  1. String(int offset, int countchar[] value){ 
  2.     this.value = value; 
  3.     this.offset = offset; 
  4.     this.count = count

看到,這里,相信細心的小伙伴已經發現了問題,導致問題的罪魁禍首就是下面的一行代碼。

  1. this.value = value; 

在JDK1.6中,使用 String 類的構造函數創建子字符串的時候,并不只是簡單的拷貝所需要的對象,而是每次都會把整個value引用進來。如果原來的字符串比較大,即使這個字符串不再被應用,這個字符串所分配的內存也不會被釋放。 這也是我經過長時間的分析代碼得出的結論,確實是太坑了!!

既然問題找到了,那我們就要解決這個問題。

升級JDK

既然JDK1.6中的String類存在如此巨大的坑,那最直接有效的方式就是升級JDK。于是,我便跟小伙伴說明了情況,讓他將JDK升級到JDK1.8。

同樣的,我們也來看下JDK1.8中的String類的substring()方法。

  1. public String substring(int beginIndex, int endIndex) { 
  2.     if (beginIndex < 0) { 
  3.         throw new StringIndexOutOfBoundsException(beginIndex); 
  4.     } 
  5.     if (endIndex > value.length) { 
  6.         throw new StringIndexOutOfBoundsException(endIndex); 
  7.     } 
  8.     int subLen = endIndex - beginIndex; 
  9.     if (subLen < 0) { 
  10.         throw new StringIndexOutOfBoundsException(subLen); 
  11.     } 
  12.     return ((beginIndex == 0) && (endIndex == value.length)) ? this 
  13.         : new String(value, beginIndex, subLen); 

在JDK1.8中的String類的substring()方法中,也調用了String類的構造方法來生成子字符串,我們來看看這個構造方法,如下所示。

  1. public String(char value[], int offset, int count) { 
  2.     if (offset < 0) { 
  3.         throw new StringIndexOutOfBoundsException(offset); 
  4.     } 
  5.     if (count <= 0) { 
  6.         if (count < 0) { 
  7.             throw new StringIndexOutOfBoundsException(count); 
  8.         } 
  9.         if (offset <= value.length) { 
  10.             this.value = "".value; 
  11.             return
  12.         } 
  13.     } 
  14.     // Note: offset or count might be near -1>>>1. 
  15.     if (offset > value.length - count) { 
  16.         throw new StringIndexOutOfBoundsException(offset + count); 
  17.     } 
  18.     this.value = Arrays.copyOfRange(value, offset, offset+count); 

 

在JDK1.8中,當我們需要一個子字符串的時候,substring 生成了一個新的字符串,這個字符串通過構造函數的 Arrays.copyOfRange 函數進行構造。這個是沒啥問題。

優化JVM啟動參數

這里,為了更好的提升系統的性能,我也幫這位小伙伴優化了JVM啟動參數。

經小伙伴授權, 我簡單列下他們的業務規模和服務器配置:整套系統采用分布式架構,架構中的各業務服務采用集群部署,日均訪問量上億,日均交易訂單50W~100W,訂單系統的各服務器節點配置為4核8G。目前已將JDK升級到1.8版本。

根據上述條件,我給出了JVM調優后的參數配置。

  1. -Xms3072M -Xmx3072M -Xmn2048M -Xss1M -XX:MetaspaceSize=256M -XX:MaxMetaspaceSize=256M 

至于,為啥會給出上述JVM參數配置,后續我會單獨寫文章來具體分析如何根據實際業務場景來進行JVM參數調優。

經過分析和解決問題,小伙伴的程序在生產環境下運行的很平穩,至少目前還未出現內存溢出的情況!!

結論

如果在程序中創建了比較大的對象,并且我們基于這個大對象生成了一些其他的信息,此時,一定要釋放和這個大對象的引用關系,否則,就會埋下內存溢出的隱患。

JVM優化的目標就是:盡可能讓對象都在新生代里分配和回收,盡量別讓太多對象頻繁進入老年代,避免頻繁對老年代進行垃圾回收,同時給系統充足的內存大小,避免新生代頻繁的進行垃圾回收。

本文轉載自微信公眾號「冰河技術」,可以通過以下二維碼關注。轉載本文請聯系冰河技術公眾號。

 

責任編輯:武曉燕 來源: 冰河技術
相關推薦

2022-01-04 08:33:33

Kafka消息發送

2015-11-23 10:29:48

app隱藏通信安卓耗電

2019-06-04 14:19:53

AWS谷歌巖機

2020-08-18 08:20:49

應用程序

2011-04-21 16:34:56

打印亂碼接口

2019-05-27 10:22:26

Oracle日志數據庫

2020-10-26 16:35:53

內存JavaThreadLocal

2009-10-12 19:44:40

Windows 7閃屏解決辦法

2009-06-03 08:48:26

2011-06-28 10:21:47

2021-12-12 21:51:54

人工智能銀行內卷

2015-10-14 11:32:55

機房空調制冷

2023-07-25 13:40:46

AI模型

2015-02-26 13:34:28

2009-03-20 16:10:15

2009-02-25 08:58:30

裁員上網本微軟

2020-12-01 06:58:29

富領域模型服務

2011-08-12 10:04:52

數據中心宕機EPO

2018-09-10 09:43:26

2010-03-30 09:21:24

Windows 7系統漏洞
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美美女爱爱视频 | 久色网| 久久综合一区二区 | 久久专区| 三级黄色大片网站 | 日韩手机在线视频 | 久久成人一区二区三区 | 日韩久草 | а天堂中文最新一区二区三区 | 色网在线观看 | 欧美精品网| 亚洲高清视频在线观看 | 综合色婷婷 | 日韩中文字幕在线观看视频 | 精品欧美乱码久久久久久 | 日韩在线| 久久大| 91精品国产综合久久国产大片 | 欧美激情欧美激情在线五月 | 一本大道久久a久久精二百 国产成人免费在线 | 国产精品毛片无码 | 国产在线精品一区二区三区 | 欧美三级三级三级爽爽爽 | 亚洲一一在线 | 日韩一区二区三区av | 国产精品一区二区视频 | 久久精品久久久久久 | 久久久久久蜜桃一区二区 | 人人性人人性碰国产 | 欧美在线观看一区二区 | 久久国产精品偷 | 国产成人精品网站 | 偷拍自拍网站 | 国产一级特黄视频 | 国产美女免费视频 | 精品一区二区三区四区外站 | 日韩欧美国产成人一区二区 | 国产精品一区一区 | 天堂亚洲网 | 99精品一区 | 精品99在线 |