别再死记硬背JVM参数了!实战“双十一”大促,亲手调教服务器

简介: 别再死记硬背JVM参数了!实战“双十一”大促,亲手调教服务器

别再死记硬背JVM参数了!实战“双十一”大促,亲手调教服务器


先看耳熟能详的一道面试题:请问一下JAVA中JRE和JDK之间有啥联系和区别呢?,妥妥的八股文,稳稳的安排。在这个问题的引导下,就会出现请说一下虚拟机中的堆和垃圾回收方面的内容,再到后面就是请问你对于JVM调优有啥心得或者经验吗?


  • 掌握JVM做到心中有图!
  • JVM内存参数介绍以及如何使用!
  • 以电商场景,实战JVM调优!


1 🍏结构及内存模型

为了更深刻的理解JVM,把握JVM在整个JDK的位置及功能是十分重要的。45911bffb04ee78942e6fb8ddbcd9f2d.png


从图中可以清晰的看到jdkjre以及jvm,三者之间的结构关系,将图记下,对于面试和工作可以丝毫不慌。在这基础之上我们再深入剖析JVM的结构以及开发和面试重中之重的内存模型,就可以更加心中有数了。

573392b7c898b7e37384159ca1ee1a3e.png


2 🍎的内存参数设置及使用

对于JVM中的内存模型有哪些构成呢?以及在日常的开发过程和准备面试要掌握到啥程度呢?

  • 首先:做到心中有图442bc23159a008256ab525e28c9ec8fc.png


  • 对于其中的核心参数,我门要如何配置呢?

在实际的应用中我们有以下几种方式对内存进行配置:

  • IDEA编辑器:

b3b7b0de87c264bd2155daa3495e73a0.png

  • 命令行脚本:
java ‐Xms2048M ‐Xmx2048M ‐Xmn1024M ‐Xss512K ‐XX:MetaspaceSiz>>e=256M ‐XX:MaxMetaspaceSize=256M ‐jar "你的应用名".jar
  • Tomcat环境下 :Tomcat启动直接加在bin目录下catalina.sh文件里


  • 然后搞懂每个参数的意义

-Xms: 堆内存的初始大小,默认为物理内存的1/64

-Xmx: 堆内存的最大大小,默认为物理内存的1/4

-Xmn: 堆内新生代的大小。通过这个值也可以得到老生代的大小:-Xmx减去-Xmn

-XX:PermSize:代表永久代的初始容量。

由于调整元空间的大小需要Full GC,这是非常昂贵的操作,如果应用在启动的时候发生大量Full GC,通常都是由于永久代或元空间发生了大小调整,基于这种情况,一般建议在JVM参数中将MetaspaceSize和MaxMetaspaceSize设置成一样的值,并设置得比初始值要大,对于8G物理内存的机器来说,一般将这两个值都设置为256M。

-XX:MetaspaceSize: 指定元空间触发Fullgc的初始阈值(元空间无固定初始大小), 以字节为单位,默认是21M,达到该值就会触发

full gc进行类型卸载, 同时收集器会对该值进行调整: 如果释放了大量的空间, 就适当降低该值; 如果释放了很少的空间, 那么在不超过-XX:MaxMetaspaceSize(如果设置了的话) 的情况下, 适当提高该值。

-XX:MaxMetaspaceSize: 设置元空间最大值, 默认是-1, 即不限制, 或者说只受限于本地内存大小。


3 🍐JVM调优

**项目背景:**在一个日均百万级的订单交易系统中,假设有500万日活用户,每个用户的每秒平均点击次数在20-30次左右.

根据该用户访问量场景,对JVM进行参数设计:

针对500W的用户,除开正常的点击浏览之外,按照10%的购买率进行计算。这些用户的会直接对订单服务器集群进行访问。

对于这50w的订单量,抛开平时没有抢购或者秒杀活动的场景,对于类似于“双十一”和“618”这类瞬间高并发的场景而言

这些订单均发生在活动开始的前几分钟,算下来平均每秒1000多单.

假设订单服务总共有三台服务器提供服务,按照主流的4核8G的单节点配置服务器,对着1000单进行负载均衡,平均每台分担300单/秒.

除此之外,在用户的购买流程中仍然会涉及到如优惠券服务、积分服务、商品库存服务等,于是,用户订单数据将会进一步膨胀,我们假定其膨胀20倍.

而且,不排除用户在整个下单购买的链路中,仍然会进行一些如查询、搜索等一系列非核心业务的请求操作,为进一步优化系统性能,我们再将该请求数据再放大10倍。

3f6621924aabc0d6a299d4e0941cb665.gif

套路实在是太多,要考虑的信息量简直可怕。基于以上的分析,我们再看看具体的数据规模流向:

e55914c8ec8e1615620571f57d42c5fb.png


  • 基于以上的分析: 我们可以对JVM参数进行如下设置
java -Xms3072M -Xmx3072M -Xmn2048M -Xss1M -XX:MetaspaceSize=256M -XX:MaxMetaspaceSiz


  • JVM调优效果图

2d93226d420542b9489546bdd8eb4c39.png

综合以上的调优案例,后面再遇到类似的面试题或者实际场景便可轻松拿捏!

相关文章
|
17天前
|
网络协议
keepalived对后端服务器的监测方式实战案例
关于使用keepalived进行后端服务器TCP监测的实战案例,包括配置文件的编辑和keepalived服务的重启,以确保配置生效。
29 1
keepalived对后端服务器的监测方式实战案例
|
28天前
|
SQL 缓存 自然语言处理
实战案例1:基于C语言的Web服务器实现。
实战案例1:基于C语言的Web服务器实现。
96 15
|
23天前
|
运维 数据安全/隐私保护 数据库管理
企业实战项目之服务器用户权限集中管理
企业实战项目之服务器用户权限集中管理
|
29天前
|
弹性计算 监控 网络安全
解锁云端力量:ECS全攻略,从新手到专家的实战之旅!轻松掌握云计算核心技能,驾驭数字浪潮之巅!
【8月更文挑战第22天】云计算中的弹性计算服务(ECS)让企业和开发者能按需获取虚拟服务器,灵活配置CPU、内存等资源。本文从零开始指导ECS的基础操作与高级技巧,包括实例创建、SSH连接、Web应用部署及利用ELB和自动伸缩优化性能。同时介绍监控工具和数据备份方法,帮助您全方位掌握ECS的高效运用,满足业务需求并保障数据安全。
51 3
|
26天前
|
Java
【Azure 应用服务】如何查看App Service Java堆栈JVM相关的参数默认配置值?
【Azure 应用服务】如何查看App Service Java堆栈JVM相关的参数默认配置值?
【Azure 应用服务】如何查看App Service Java堆栈JVM相关的参数默认配置值?
|
19天前
|
C# 开发者 Windows
震撼发布:全面解析WPF中的打印功能——从基础设置到高级定制,带你一步步实现直接打印文档的完整流程,让你的WPF应用程序瞬间升级,掌握这一技能,轻松应对各种打印需求,彻底告别打印难题!
【8月更文挑战第31天】打印功能在许多WPF应用中不可或缺,尤其在需要生成纸质文档时。WPF提供了强大的打印支持,通过`PrintDialog`等类简化了打印集成。本文将详细介绍如何在WPF应用中实现直接打印文档的功能,并通过具体示例代码展示其实现过程。
79 0
|
27天前
|
运维 监控 Java
【JVM 调优秘籍】实战指南:JVM 调优参数全解析,让 Java 应用程序性能飙升!
【8月更文挑战第24天】本文通过一个大型在线零售平台的例子,深入探讨了Java虚拟机(JVM)性能调优的关键技术。面对应用响应延迟的问题,文章详细介绍了几种常用的JVM参数调整策略,包括堆内存大小、年轻代配置、垃圾回收器的选择及日志记录等。通过具体实践(如设置`-Xms`, `-Xmx`, `-XX:NewRatio`, `-XX:+UseParallelGC`等),成功降低了高峰期的响应时间,提高了系统的整体性能与稳定性。案例展示了合理配置JVM参数的重要性及其对解决实际问题的有效性。
47 0
|
27天前
|
移动开发 网络协议 编译器
实战案例3:C语言实现的HTTP服务器
实战案例3:C语言实现的HTTP服务器
39 0
|
1月前
|
存储 监控 算法
深入解析JVM内部结构及GC机制的实战应用
深入解析JVM内部结构及GC机制的实战应用
|
1月前
|
缓存 PHP 数据库
PHP性能优化实战:从代码到服务器的全方位攻略
在数字化时代,Web应用的性能直接影响用户体验和业务成果。作为流行的后端开发语言,PHP的性能优化是提升网站响应速度的关键。本文将通过实际案例分析,探讨PHP代码级别的优化策略、数据库交互效率提升以及服务器配置调优,旨在帮助开发者全面提升PHP应用性能。
35 0