壓測(cè)排查案例-不間斷的CPU驟降,堆內(nèi)存不再增加

壓測(cè)排查案例-不間斷的CPU驟降印颤,堆內(nèi)存不再增加

問題描述

使用nginx分發(fā)兩臺(tái)機(jī)器(4G+4G年輕代)進(jìn)行持續(xù)壓測(cè)请祖,結(jié)果發(fā)現(xiàn)订歪,出現(xiàn)不間斷的CPU驟降,堆內(nèi)存不再增加肆捕。期間服務(wù)端不再響應(yīng)陌粹。總體服務(wù)器TPS為200左右。

問題描述.png

跟蹤問題

通過線程圖表分析掏秩,發(fā)現(xiàn)每次CPU驟降的時(shí)候或舞,都會(huì)有一個(gè)工作線程BLOCK

想到的跟蹤方法是,每次CPU驟降的時(shí)候蒙幻,立刻進(jìn)行手動(dòng)線程dump映凳,把CPU驟降的時(shí)候,線程的狀況打印出來

定位問題

分析當(dāng)時(shí)的打印線程dump

根據(jù)當(dāng)時(shí)BLOCK的線程號(hào)是122邮破,定位到對(duì)應(yīng)的線程日志

"http-nio-8883-exec-122" - Thread t@201
   java.lang.Thread.State: TIMED_WAITING
        at java.lang.Thread.sleep(Native Method)
        at com.mysql.jdbc.ConnectionImpl.connectWithRetries(ConnectionImpl.java:2156)
        at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2090)
        - locked <3406588f> (a com.mysql.jdbc.JDBC4Connection)
        at com.mysql.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:795)
        at com.mysql.jdbc.JDBC4Connection.<init>(JDBC4Connection.java:44)
        at sun.reflect.GeneratedConstructorAccessor68.newInstance(Unknown Source)
        at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
        at java.lang.reflect.Constructor.newInstance(Constructor.java:423)
        at com.mysql.jdbc.Util.handleNewInstance(Util.java:404)
        at com.mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:400)
        at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:327)
        at org.apache.ibatis.datasource.unpooled.UnpooledDataSource$DriverProxy.connect(UnpooledDataSource.java:249)
        at java.sql.DriverManager.getConnection(DriverManager.java:664)
        at java.sql.DriverManager.getConnection(DriverManager.java:208)
        at org.apache.ibatis.datasource.unpooled.UnpooledDataSource.doGetConnection(UnpooledDataSource.java:201)
        at org.apache.ibatis.datasource.unpooled.UnpooledDataSource.doGetConnection(UnpooledDataSource.java:196)
        at org.apache.ibatis.datasource.unpooled.UnpooledDataSource.getConnection(UnpooledDataSource.java:93)
        at org.apache.ibatis.datasource.pooled.PooledDataSource.popConnection(PooledDataSource.java:385)
        - locked <64485760> (a org.apache.ibatis.datasource.pooled.PoolState)
        at org.apache.ibatis.datasource.pooled.PooledDataSource.getConnection(PooledDataSource.java:89)
        at org.springframework.jdbc.datasource.DataSourceUtils.doGetConnection(DataSourceUtils.java:111)
        at org.springframework.jdbc.datasource.DataSourceUtils.getConnection(DataSourceUtils.java:77)
        at org.mybatis.spring.transaction.SpringManagedTransaction.openConnection(SpringManagedTransaction.java:81)
        at org.mybatis.spring.transaction.SpringManagedTransaction.getConnection(SpringManagedTransaction.java:67)
        at org.apache.ibatis.executor.BaseExecutor.getConnection(BaseExecutor.java:315)
        at org.apache.ibatis.executor.SimpleExecutor.prepareStatement(SimpleExecutor.java:75)
        at org.apache.ibatis.executor.SimpleExecutor.doQuery(SimpleExecutor.java:61)
        at org.apache.ibatis.executor.BaseExecutor.queryFromDatabase(BaseExecutor.java:303)
        at org.apache.ibatis.executor.BaseExecutor.query(BaseExecutor.java:154)
        at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:102)
        at org.apache.ibatis.executor.CachingExecutor.query(CachingExecutor.java:82)
        at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:120)
        at org.apache.ibatis.session.defaults.DefaultSqlSession.selectList(DefaultSqlSession.java:113)
        at org.apache.ibatis.session.defaults.DefaultSqlSession.selectOne(DefaultSqlSession.java:73)
        at sun.reflect.GeneratedMethodAccessor147.invoke(Unknown Source)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:498)
        at org.mybatis.spring.SqlSessionTemplate$SqlSessionInterceptor.invoke(SqlSessionTemplate.java:358)
        at com.sun.proxy.$Proxy35.selectOne(Unknown Source)
        at org.mybatis.spring.SqlSessionTemplate.selectOne(SqlSessionTemplate.java:163)
        at org.apache.ibatis.binding.MapperMethod.execute(MapperMethod.java:69)
        at org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:53)
        at com.sun.proxy.$Proxy99.select(Unknown Source)
        at com.baioo.ais.app.service.skill.image.SkillImageService.query(SkillImageService.java:20)
        at com.baioo.ais.app.service.skill.image.SkillImageService$$FastClassBySpringCGLIB$$c0fa6361.invoke(<generated>)
        at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:204)
        at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:720)
        at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:157)
        at org.springframework.aop.aspectj.MethodInvocationProceedingJoinPoint.proceed(MethodInvocationProceedingJoinPoint.java:85)
        at com.baioo.ais.common.monitor.AspectHelper.monitorPerformanceProceed(AspectHelper.java:37)
        at com.baioo.ais.common.monitor.MonitorAspect.logPointPerformance(MonitorAspect.java:57)
        at com.baioo.ais.common.monitor.MonitorAspect.springService(MonitorAspect.java:48)
        at sun.reflect.GeneratedMethodAccessor142.invoke(Unknown Source)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:498)
        at org.springframework.aop.aspectj.AbstractAspectJAdvice.invokeAdviceMethodWithGivenArgs(AbstractAspectJAdvice.java:629)
        at org.springframework.aop.aspectj.AbstractAspectJAdvice.invokeAdviceMethod(AbstractAspectJAdvice.java:618)
        at org.springframework.aop.aspectj.AspectJAroundAdvice.invoke(AspectJAroundAdvice.java:70)
        at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:168)
        at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:92)
        at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
        at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:655)
        at com.baioo.ais.app.service.skill.image.SkillImageService$$EnhancerBySpringCGLIB$$f20c7a4e.query(<generated>)
        at com.baioo.ais.app.service.skills.activity.bdchest.BDChestActionService$ImageTemplateConvert.handleDuerOSTemplateDirective(BDChestActionService.java:140)
        at com.baioo.ais.app.service.skills.activity.bdchest.BDChestActionService.afterActionManagerExecute(BDChestActionService.java:95)
        at com.baioo.ais.app.service.skills.AbstractSkillExecutorService.execute(AbstractSkillExecutorService.java:58)
        at com.baioo.ais.app.service.skills.activity.bdchest.BDChestActionService.execute(BDChestActionService.java:52)
        at com.baioo.ais.app.service.skills.activity.bdchest.BDChestActionService$$FastClassBySpringCGLIB$$f6ac3d7c.invoke(<generated>)
        at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:204)
        at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:720)
        at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:157)
        at org.springframework.aop.aspectj.MethodInvocationProceedingJoinPoint.proceed(MethodInvocationProceedingJoinPoint.java:85)
        at com.baioo.ais.common.monitor.AspectHelper.monitorPerformanceProceed(AspectHelper.java:37)
        at com.baioo.ais.common.monitor.MonitorAspect.logPointPerformance(MonitorAspect.java:57)
        at com.baioo.ais.common.monitor.MonitorAspect.springService(MonitorAspect.java:48)
        at sun.reflect.GeneratedMethodAccessor142.invoke(Unknown Source)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:498)

...

   Locked ownable synchronizers:
        - locked <59a51757> (a java.util.concurrent.ThreadPoolExecutor$Worker)

發(fā)現(xiàn)該線程狀態(tài)是TIMED_WAITING

而且獲得了鎖<64485760>

\- locked <64485760> (a org.apache.ibatis.datasource.pooled.PoolState) 

而且發(fā)現(xiàn)大量其他線程都堵塞在這個(gè)鎖上诈豌,如

"http-nio-8883-exec-108" - Thread t@187
   java.lang.Thread.State: BLOCKED
        at org.apache.ibatis.datasource.pooled.PooledDataSource.pushConnection(PooledDataSource.java:330)
        - waiting to lock <64485760> (a org.apache.ibatis.datasource.pooled.PoolState) owned by "http-nio-8883-exec-122" t@201
        at org.apache.ibatis.datasource.pooled.PooledConnection.invoke(PooledConnection.java:236)

這個(gè)其中,發(fā)現(xiàn)程序使用的PooledDataSource抒和,經(jīng)過查詢矫渔,這個(gè)是Mybatis自己mysql鏈接池。

經(jīng)過考慮摧莽,我們把數(shù)據(jù)庫鏈接池更改成druid庙洼。

再次測(cè)試,問題解決镊辕。TPS高達(dá)460

案例后記

沒有想到鏈接池對(duì)性能的影響這么大油够。

本案例中,因?yàn)閙ysql的鏈接用完征懈,使用Mybatis鏈接池的時(shí)候石咬,線程被柱塞,大大影響其性能卖哎。

雖然換成druid后鬼悠,問題解決,但是現(xiàn)在暫時(shí)沒有深究druid為啥能解決這個(gè)問題亏娜。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末厦章,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子照藻,更是在濱河造成了極大的恐慌袜啃,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,311評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件幸缕,死亡現(xiàn)場(chǎng)離奇詭異群发,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)发乔,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門熟妓,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人栏尚,你說我怎么就攤上這事起愈。” “怎么了?”我有些...
    開封第一講書人閱讀 152,671評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵抬虽,是天一觀的道長(zhǎng)官觅。 經(jīng)常有香客問我,道長(zhǎng)阐污,這世上最難降的妖魔是什么休涤? 我笑而不...
    開封第一講書人閱讀 55,252評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮笛辟,結(jié)果婚禮上功氨,老公的妹妹穿的比我還像新娘。我一直安慰自己手幢,他們只是感情好捷凄,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,253評(píng)論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著围来,像睡著了一般跺涤。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上管钳,一...
    開封第一講書人閱讀 49,031評(píng)論 1 285
  • 那天钦铁,我揣著相機(jī)與錄音软舌,去河邊找鬼才漆。 笑死,一個(gè)胖子當(dāng)著我的面吹牛佛点,可吹牛的內(nèi)容都是我干的醇滥。 我是一名探鬼主播,決...
    沈念sama閱讀 38,340評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼超营,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼鸳玩!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起演闭,我...
    開封第一講書人閱讀 36,973評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤不跟,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后米碰,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體窝革,經(jīng)...
    沈念sama閱讀 43,466評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,937評(píng)論 2 323
  • 正文 我和宋清朗相戀三年吕座,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了虐译。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,039評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡吴趴,死狀恐怖漆诽,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤厢拭,帶...
    沈念sama閱讀 33,701評(píng)論 4 323
  • 正文 年R本政府宣布兰英,位于F島的核電站,受9級(jí)特大地震影響蚪腐,放射性物質(zhì)發(fā)生泄漏箭昵。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,254評(píng)論 3 307
  • 文/蒙蒙 一回季、第九天 我趴在偏房一處隱蔽的房頂上張望家制。 院中可真熱鬧,春花似錦泡一、人聲如沸颤殴。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,259評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽涵但。三九已至,卻和暖如春帖蔓,著一層夾襖步出監(jiān)牢的瞬間矮瘟,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來泰國(guó)打工塑娇, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留澈侠,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,497評(píng)論 2 354
  • 正文 我出身青樓埋酬,卻偏偏與公主長(zhǎng)得像哨啃,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子写妥,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,786評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容