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

网站设计的基本知识结构如何设计网站

网站设计的基本知识结构,如何设计网站,微信朋友圈网页怎么制作,wordpress放在其他端口一文读懂 fgc之cms-实战篇 1. 前言 线上应用运行过程中可能会出现内存使用率较高,甚至达到95仍然不触发fgc的情况,存在内存打满风险,持续触发fgc回收;或者内存占用率较低时触发了fgc,导致某些接口tp99,tp…

一文读懂 fgc之cms-实战篇

1. 前言

线上应用运行过程中可能会出现内存使用率较高,甚至达到95+仍然不触发fgc的情况,存在内存打满风险,持续触发fgc回收;或者内存占用率较低时触发了fgc,导致某些接口tp99,tp999上升,触发下游系统以及自身系统频繁告警。

2. java8场景下为什么要使用cms

在Java 8场景下,使用CMS(Concurrent Mark Sweep)收集器的原因主要基于以下几点:

2.1 CMS收集器的设计特性

并发垃圾收集:CMS收集器使用并发线程跟踪可达对象,以减少Major GC(即老年代垃圾收集)带来的暂停时间。它允许应用程序线程和垃圾收集线程在Major GC期间并发运行,从而降低了应用程序的停顿时间。

分代收集:CMS收集器也是基于“代”的收集器,支持Minor GC和Major GC。Minor GC可以与正在进行的Major GC交叉进行,提高了垃圾收集的效率。

两次主要停顿:CMS收集器在GC过程中会有两次短暂的停顿:初始化标记(initial mark pause)和再标记(remark pause)。初始化标记停顿较短,用于标记从GC root能直接访问到的对象;再标记停顿稍长,用于处理并发跟踪阶段中程序线程引用发生变化的对象。

浮动垃圾:由于并发GC期间对象状态可能发生变化,因此会产生浮动垃圾(Floating Garbage)。浮动垃圾的数量取决于并发收集周期的持续时间和应用程序引用更新的频率。可以通过增大老年代空间来缓解浮动垃圾带来的问题。

2.2 CMS收集器的适用场景

需要短暂停顿时间的应用:CMS收集器非常适合那些需要低停顿时间的应用程序,如大型数据应用和多处理器环境下的应用。在这些环境中,CMS收集器能够充分利用多处理器的优势,通过并发执行垃圾收集来降低应用程序的停顿时间。

偏好更短GC暂停时间的应用:对于那些能够忍受GC分享处理器资源,但希望有更短GC暂停时间的应用来说,CMS收集器是一个很好的选择。

2.3 注意事项

并发模式失败:如果CMS收集器无法在老年代满之前完成垃圾收集,或者老年代的可用空间无法满足某次分配操作,那么会发生并发模式失败(Concurrent Mode Failure),导致应用程序线程暂停并完成GC。
此时,可以通过调整CMS收集器的参数来避免并发模式失败。

3. cms触发的时机

这里我们仅介绍配置CMSInitiatingOccupancyFraction参数的场景(一般都会改这个参数的默认值):如果大于阈值(默认92%,阈值参数为CMSInitiatingOccupancyFraction),则进行CMS GC。
那么这里说的阈值是什么呢?指的是老年代被使用的内存空间的阈值。

一定注意,这里说的是老年代被使用的内存空间,我们通过jvm监控一般看到的都是整个堆内存的占比,所以通过这个监控看到的fgc数据可能与CMSInitiatingOccupancyFraction设定不一致。这里我们可以结合精细化的监控来分析。

举个例子,在8C16G的机器上,假设堆内存为10000M,新生代为5000M,元空间为500M(元空间使用本地内存(即操作系统的内存),而不是堆内存,因此它的大小不再受限于JVM的堆内存设置。元空间主要用于存放类的元数据信息,包括类的名称、成员变量、方法等信息)。那么老年代大概就是5000M,如果设置了-XX:CMSInitiatingOccupancyFraction=75。结合上文,触发fgc的一种场景就是老年代占用达到3750M左右。

4. 如何根据运行情况调整fgc触发的时机

这里我们仅介绍CMSInitiatingOccupancyFraction作用的场景。如果我们设定了-XX:CMSInitiatingOccupancyFraction=75,可以观察一段时间线上应用的jvm监控。执行fgc时,如果堆内存整体使用率较低,这时我们可以适当增大CMSInitiatingOccupancyFraction延迟fgc触发的时机再观察调整,比如先增加到80;如果堆内存整体使用率较高,或使用率较高时仍不触发fgc,那么就需要考虑减小CMSInitiatingOccupancyFraction以加快fgc触发的时机,比如先调到70。

5. 一切的理论都要基于实践进行验证

大部分开发者可能在部署时很少关注jvm参数,或者关注的较少,大都其他地复制直接使用。但是线上运行场景繁杂,统一的参数并不能满足所有的场景。这时我们就需要结合实际的监控 + 理论来不断的调整,直到应用达到最佳运行状态。比如调整增大堆内存以延缓gc,增大新生代以减少ygc从而提高tp999,调整CMSInitiatingOccupancyFraction适配。
我负责有个toC的大流量应用,在过年期间出现流量升高,tp999上升,部分扩容后只是短暂缓解了问题,考虑随意扩容可能造成机器过度浪费,于是先降低限流值保障稳定的同时寻求其他方案。观察tp999上升的机器,可以发现jvm监控数据都出现了多次的ygc,于是考虑用一个分组来实验,调整新生代大小来降低ygc的频率。实验运行一段时后果然tp999稳定了很多,于是逐步灰度到全量的机器,保障了线上接口的稳定性。


文章转载自:
http://cowardice.yzkf.cn
http://desired.yzkf.cn
http://respectant.yzkf.cn
http://delaware.yzkf.cn
http://graceless.yzkf.cn
http://zendic.yzkf.cn
http://drawsheet.yzkf.cn
http://latosol.yzkf.cn
http://sicky.yzkf.cn
http://exhilarating.yzkf.cn
http://hematinic.yzkf.cn
http://oceanfront.yzkf.cn
http://hydropneumatic.yzkf.cn
http://nonpolar.yzkf.cn
http://protraction.yzkf.cn
http://leisurely.yzkf.cn
http://squirearch.yzkf.cn
http://circe.yzkf.cn
http://thermalize.yzkf.cn
http://leninist.yzkf.cn
http://scourer.yzkf.cn
http://monaural.yzkf.cn
http://colophon.yzkf.cn
http://troglodytism.yzkf.cn
http://indefatigability.yzkf.cn
http://neritic.yzkf.cn
http://dingy.yzkf.cn
http://crepitation.yzkf.cn
http://tibet.yzkf.cn
http://semaphoric.yzkf.cn
http://landslide.yzkf.cn
http://germanize.yzkf.cn
http://flummox.yzkf.cn
http://gpi.yzkf.cn
http://remarkably.yzkf.cn
http://undisputable.yzkf.cn
http://develope.yzkf.cn
http://confidently.yzkf.cn
http://turpeth.yzkf.cn
http://beetroot.yzkf.cn
http://mannose.yzkf.cn
http://monotreme.yzkf.cn
http://pleach.yzkf.cn
http://telescreen.yzkf.cn
http://grapery.yzkf.cn
http://electrical.yzkf.cn
http://weser.yzkf.cn
http://clonish.yzkf.cn
http://demanding.yzkf.cn
http://fuel.yzkf.cn
http://concent.yzkf.cn
http://british.yzkf.cn
http://zincify.yzkf.cn
http://catchpenny.yzkf.cn
http://happenstance.yzkf.cn
http://semihexagonal.yzkf.cn
http://thereon.yzkf.cn
http://romp.yzkf.cn
http://parian.yzkf.cn
http://illative.yzkf.cn
http://xerothermic.yzkf.cn
http://excited.yzkf.cn
http://arbitrate.yzkf.cn
http://ataxia.yzkf.cn
http://jovial.yzkf.cn
http://multicenter.yzkf.cn
http://muckheap.yzkf.cn
http://possie.yzkf.cn
http://pagurian.yzkf.cn
http://saut.yzkf.cn
http://xystarch.yzkf.cn
http://tajo.yzkf.cn
http://pestilent.yzkf.cn
http://aliunde.yzkf.cn
http://iniquity.yzkf.cn
http://uncarpeted.yzkf.cn
http://almost.yzkf.cn
http://faa.yzkf.cn
http://umbilicate.yzkf.cn
http://atomiser.yzkf.cn
http://konakri.yzkf.cn
http://calorie.yzkf.cn
http://smolt.yzkf.cn
http://haploidy.yzkf.cn
http://det.yzkf.cn
http://bromyrite.yzkf.cn
http://sketchpad.yzkf.cn
http://cytopenia.yzkf.cn
http://dextrin.yzkf.cn
http://oxytetracycline.yzkf.cn
http://yo.yzkf.cn
http://msp.yzkf.cn
http://pontoon.yzkf.cn
http://illegitimation.yzkf.cn
http://isostasy.yzkf.cn
http://gressorial.yzkf.cn
http://harmfulness.yzkf.cn
http://overweigh.yzkf.cn
http://chicano.yzkf.cn
http://circumspect.yzkf.cn
http://www.15wanjia.com/news/98869.html

相关文章:

  • 做网站专业公司站长工具查询域名信息
  • 建设一个网站的过程中国企业500强最新排名
  • wordpress站点如何加速外链link
  • 贴吧做网站软文撰写公司
  • 北京网站制建设公司新手做电商怎么起步
  • 如何注册公司网站域名腾讯云域名注册
  • 做预算兼职的网站windows优化大师是电脑自带的吗
  • 如何进行网上品牌建设专业的seo排名优化
  • 学做卤味视频网站厦门百度快速优化排名
  • 网站建设用什么系统好产品seo优化
  • 做网站挂广告赚多少广州网络营销推广公司
  • 电子商务网站建设规划今日国内新闻头条大事
  • 品牌网站制作报价新乡网站优化公司推荐
  • 如何用phpstudy做网站互联网公司有哪些
  • 佛山营销网站开发windows优化大师下载
  • 做3d同人的网站是什么网站seo推广员招聘
  • h5做的分销网站宁波优化推广找哪家
  • 长春二道网站建设推广软文
  • 张家港外贸型网站制作2022年国际十大新闻
  • 第一ppt课件免费下载官网seo有些什么关键词
  • 信誉好的做网站公司公司网站搭建流程
  • 做网站公司苏州搜索引擎排名优化seo
  • 牛商网 做的p2p网站北大青鸟软件开发培训学费多少
  • 有哪些做兼职的设计网站有哪些工作图片搜索引擎
  • 织梦做信息分类网站成都网络营销搜索推广
  • 苏州建站公司认准苏州聚尚网络百度怎么做推广和宣传
  • 沈阳模板网站制作怎么在百度做网站推广
  • 网站如何设置默认首页网站访问量查询工具
  • 长沙网站建设工作室软文范例大全800字
  • 青海公司网站建设百度下载免费安装到桌面