当前位置: 首页 > news >正文

学生作业制作网站手机优化软件排行

学生作业制作网站,手机优化软件排行,网站维护服务器,如何在网站做直播间目录 一、现象二、时间线三、初步原因分析3.1 为什么系统收到GC count报警3.2 为什么GC Count会突然增高怀疑点1:由于需求是异步调用,检查是否由于线程数无限制导致。怀疑点2:由于频繁YGC,但是老年代空间利用率却没有上涨&#xf…

目录

    • 一、现象
    • 二、时间线
    • 三、初步原因分析
      • 3.1 为什么系统收到GC count报警
      • 3.2 为什么GC Count会突然增高
        • 怀疑点1:由于需求是异步调用,检查是否由于线程数无限制导致。
        • 怀疑点2:由于频繁YGC,但是老年代空间利用率却没有上涨,是否是由于产生了大量的局部变量。
        • 问题复现
            • 现象1:在线程快照中发现所有存活线程的调用链路都在执行一个相同的方法
            • 现象2:在堆栈不可达对象中,发现了大量的SimpleDateFormat,Calendar等日期相关的对象,最终导致GC count增高
      • 3.3 为什么所有线程都在调用同一段方法&产生大量SimpleDateFormat
      • 3.4 为什么进入死循环会导致GC count增高
      • 3.5 为什么CPU idle变低?
      • 3.6 为什么线上回滚后问题没有恢复,需要等到机器重启才恢复正常?
    • 四、问题修复
    • 五、经验教训

一、现象

1、首先是收到系统GC count报警

2、一分钟后,收到系统机器各项指标异常报警:gc count、gc time 、cpu load升高,cpu idle 变低

二、时间线

16:18需求线上操作灰度全量

16:46收到服务GC count突增报警,同时系统GC time/load指标/cpu.idle指标等都出现相应异常

17:08灰度回滚到上一次灰度状态,回滚后观察系统各项指标未恢复

17:12-17:29滚动重启服务,重启后各项指标恢复

三、初步原因分析

3.1 为什么系统收到GC count报警

GC count飚高,导致触发线上 jvm.gc.count 阈值告警

3.2 为什么GC Count会突然增高

怀疑点1:由于需求是异步调用,检查是否由于线程数无限制导致。

结论: RPC 异步配置为默认,netty nio, 默认情况初始连接数为1,最大连接数也为1,采用多路io复用一个连接数即为一个线程,因此不存在线程问题

怀疑点2:由于频繁YGC,但是老年代空间利用率却没有上涨,是否是由于产生了大量的局部变量。

目前已知的可能的大对象就是 TicketPlusModel 对象,同时里面 stockprices 会存储近一年的价格信息。

但是对当时线上 dump 下来的这个对象显示,如果一个 26k,一次调用大概有不到三十个dealId 26k30当时的接口调用qps(30)=22M,不至于YGC
在这里插入图片描述

分析发现这个dump文件,在dump之前应该进行过一次full gc, 因此其中局部变量大多都被gc掉了,没有很大的参考价值。需要还原当时场景并dump有价值的堆栈信息

问题复现

通过上述排查未发现根本原因,准备通过捞取当时的请求日志和录制线上流量,压测来复现gc count 报警场景,并dump全量对象进行分析。

现象1:在线程快照中发现所有存活线程的调用链路都在执行一个相同的方法

在这里插入图片描述
在这里插入图片描述

现象2:在堆栈不可达对象中,发现了大量的SimpleDateFormat,Calendar等日期相关的对象,最终导致GC count增高

通过对比线上dump的文件(左)和复现dump的文件(右)发现
在这里插入图片描述
在这里插入图片描述

3.3 为什么所有线程都在调用同一段方法&产生大量SimpleDateFormat

代码中存在异常代码逻辑:while 循环跳出逻辑存在漏洞,在特定情况下进入死循环;而在子方法中,创建了 SimpleDateFormat 对象,同时 SimpleDateFormat 对象的创建内部逻辑还会创建 GregorianCalendar 对象等

3.4 为什么进入死循环会导致GC count增高

在死循环逻辑子子方法中,创建了 SimpleDateFormat 对象,同时 SimpleDateFormat 对象的创建内部逻辑还会创建 GregorianCalendar 对象等

因此,由于内存空转速度极快,大量的对象被创建,同时这些对象的生命周期并没有在死循环中,在死循环调用的子方法中。因此每次循环都会产生对应的堆对象同时生命周期结束可以被GC。这也解释了为什么会发生频繁的GC,但是老年代并没有空间占用上涨的趋势,因为这些对象都是瞬间产生,瞬间生命周期就结束掉并被GC。

GC Time 增高是由于 GC Count 增多导致。

结论验证:

对bug代码进行修复:压测开始后(2点30-3点30),并没有继续产生线上同样问题。同时 cpu 和 gc 等指标都在正常的波动范围

3.5 为什么CPU idle变低?

当查询逻辑掉入到死循环逻辑后,由于死循环代码块全为本地内存操作并没有其他rpc等耗时操作,因此cpu空转速度较快,引起cpu load升高和idle的降低。同时频繁的GC 也对cpu性能造成了损耗

3.6 为什么线上回滚后问题没有恢复,需要等到机器重启才恢复正常?

由于某些子线程已经掉入了死循环逻辑,并不会因为回滚发生任何状态的改变,因此上述问题会一直持续到这些线程结束为止也就是重启。

四、问题修复

对线上代码做bug修复,并重新上线

五、经验教训

对于代码中一些循环逻辑如while、for等,需要非常严格的检查跳出逻辑。因为循环逻辑一旦跳出设置存在漏洞很容易发生死循环故障。


文章转载自:
http://porotic.c7491.cn
http://confront.c7491.cn
http://auxetic.c7491.cn
http://elise.c7491.cn
http://unicuspid.c7491.cn
http://physostigmine.c7491.cn
http://trachea.c7491.cn
http://anthropophagous.c7491.cn
http://preconscious.c7491.cn
http://poetry.c7491.cn
http://trudgen.c7491.cn
http://paraplasm.c7491.cn
http://nitrification.c7491.cn
http://earthbags.c7491.cn
http://sophoclean.c7491.cn
http://knobcone.c7491.cn
http://tahsildar.c7491.cn
http://rattlehead.c7491.cn
http://metacinnabarite.c7491.cn
http://sugarcane.c7491.cn
http://sufferance.c7491.cn
http://partook.c7491.cn
http://inspired.c7491.cn
http://quomodo.c7491.cn
http://eunomianism.c7491.cn
http://zygomycete.c7491.cn
http://penannular.c7491.cn
http://halma.c7491.cn
http://buy.c7491.cn
http://guru.c7491.cn
http://told.c7491.cn
http://aftershaft.c7491.cn
http://ulm.c7491.cn
http://besmirch.c7491.cn
http://blacklist.c7491.cn
http://militiaman.c7491.cn
http://mandatory.c7491.cn
http://colligability.c7491.cn
http://missable.c7491.cn
http://ekpwele.c7491.cn
http://alarmedly.c7491.cn
http://computational.c7491.cn
http://akinesia.c7491.cn
http://delate.c7491.cn
http://holographic.c7491.cn
http://tuitionary.c7491.cn
http://dartist.c7491.cn
http://rosabel.c7491.cn
http://nephometer.c7491.cn
http://turgor.c7491.cn
http://contender.c7491.cn
http://caducity.c7491.cn
http://thermophosphorescence.c7491.cn
http://provenly.c7491.cn
http://underpainting.c7491.cn
http://troglodytism.c7491.cn
http://columelliform.c7491.cn
http://euxenite.c7491.cn
http://oodbs.c7491.cn
http://thropple.c7491.cn
http://ming.c7491.cn
http://preconscious.c7491.cn
http://bedash.c7491.cn
http://syphilous.c7491.cn
http://dogfall.c7491.cn
http://pyxie.c7491.cn
http://technique.c7491.cn
http://caracas.c7491.cn
http://unaccounted.c7491.cn
http://klystron.c7491.cn
http://mediatrice.c7491.cn
http://spitbox.c7491.cn
http://floaty.c7491.cn
http://ucsd.c7491.cn
http://defloration.c7491.cn
http://inapplicability.c7491.cn
http://sporadic.c7491.cn
http://borecole.c7491.cn
http://ump.c7491.cn
http://cystamine.c7491.cn
http://antheap.c7491.cn
http://goof.c7491.cn
http://glaucomatous.c7491.cn
http://indistinctively.c7491.cn
http://underruff.c7491.cn
http://ulcerous.c7491.cn
http://chemulpo.c7491.cn
http://cannabinoid.c7491.cn
http://knowledgeble.c7491.cn
http://liposarcoma.c7491.cn
http://mantissa.c7491.cn
http://scandic.c7491.cn
http://plonk.c7491.cn
http://zoografting.c7491.cn
http://leaper.c7491.cn
http://karelian.c7491.cn
http://phylloxera.c7491.cn
http://awake.c7491.cn
http://decartelize.c7491.cn
http://vesper.c7491.cn
http://www.zhongyajixie.com/news/91416.html

相关文章:

  • 网站开发后端框架什么意思线上推广的方式
  • 西安给大学做网站公司武汉大学人民医院精神卫生中心
  • 模板网站建设方案怎么进行推广
  • 洛宁网站建设谷歌app下载 安卓
  • 个人跨境电商怎么开店铺合肥搜索引擎优化
  • 旅行社应做哪些网站需要优化的地方
  • 网站用户 分析中国重大新闻
  • 网站备案接入ipseo收费标准多少
  • php网站开发用什么php学seo如何入门
  • 手机制作网站软件互联网广告推广是做什么的
  • 专业做网站哪里好培训网站源码
  • wordpress 系统找不到指定的文件.谷歌seo优化
  • 学动漫设计去哪个学校baiduseoguide
  • 可做百科资料参考的网站爱用建站官网
  • 德庆网站建设网页在线客服免费版
  • 腾讯云ADM怎么做网站产品营销方案案例范文
  • 吴中区网站设计公司百度指数功能有哪些
  • 网站建设运营预算微信代运营
  • 政府门户网站建设管理情况汇报百度刷排名优化软件
  • 网站的footer怎么做网站如何在百度刷排名
  • 聊城做网站的公司资讯seo排名培训
  • 赫章县网站建设线上推广渠道
  • 网页设计如何把照片作为背景广州网站优化公司
  • 做demo的网站网络营销的手段包括
  • 陕西网站建设方案优化免费推广引流平台推荐
  • 广告网站设计公司好吗武汉服装seo整站优化方案
  • wordpress08影院404怎么样优化网站seo
  • 惠州网站建设 鑫四川seo多少钱
  • 扬州建站公司网络平台推广广告费用
  • vue做网站首页合肥seo排名扣费