别再死记硬背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

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

相关文章
|
6月前
|
人工智能 JavaScript API
零基础构建MCP服务器:TypeScript/Python双语言实战指南
作为一名深耕技术领域多年的博主摘星,我深刻感受到了MCP(Model Context Protocol)协议在AI生态系统中的革命性意义。MCP作为Anthropic推出的开放标准,正在重新定义AI应用与外部系统的交互方式,它不仅解决了传统API集成的复杂性问题,更为开发者提供了一个统一、安全、高效的连接框架。在过去几个月的实践中,我发现许多开发者对MCP的概念理解透彻,但在实际动手构建MCP服务器时却遇到了各种技术壁垒。从环境配置的细节问题到SDK API的深度理解,从第一个Hello World程序的调试到生产环境的部署优化,每一个环节都可能成为初学者的绊脚石。因此,我决定撰写这篇全面的实
1540 67
零基础构建MCP服务器:TypeScript/Python双语言实战指南
|
5月前
|
存储 弹性计算 网络协议
阿里云服务器ECS实例规格族是什么?不同规格CPU型号、处理器主频及网络性能参数均不同
阿里云ECS实例规格族是指具有不同性能特点和适用场景的实例类型集合。不同规格族如计算型c9i、通用算力型u1、经济型e等,在CPU型号、主频、网络性能、云盘IOPS等方面存在差异。即使CPU和内存配置相同,性能参数和价格也各不相同,适用于不同业务需求。
466 144
|
3月前
|
弹性计算 人工智能 前端开发
在阿里云ECS上部署n8n自动化工作流:U2实例实战
本文介绍如何在阿里云ECS的u2i/u2a实例上部署开源工作流自动化平台n8n,利用Docker快速搭建并配置定时任务,实现如每日抓取MuleRun新AI Agent并推送通知等自动化流程。内容涵盖环境准备、安全组设置、实战案例与优化建议,助力高效构建低维护成本的自动化系统。
902 5
|
5月前
|
存储 弹性计算 网络协议
阿里云服务器ECS实例规格族详细介绍:计算型c9i、经济型e和通用算力u1实例CPU参数说明
阿里云ECS实例规格族包括计算型c9i、经济型e和通用算力型u1等,各自针对不同场景优化。不同规格族在CPU型号、主频、网络性能、云盘IOPS等方面存在差异,即使CPU内存相同,性能和价格也不同。
780 0
|
6月前
|
JSON 前端开发 Go
Go语言实战:创建一个简单的 HTTP 服务器
本篇是《Go语言101实战》系列之一,讲解如何使用Go构建基础HTTP服务器。涵盖Go语言并发优势、HTTP服务搭建、路由处理、日志记录及测试方法,助你掌握高性能Web服务开发核心技能。
|
8月前
|
人工智能 安全 Shell
Jupyter MCP服务器部署实战:AI模型与Python环境无缝集成教程
Jupyter MCP服务器基于模型上下文协议(MCP),实现大型语言模型与Jupyter环境的无缝集成。它通过标准化接口,让AI模型安全访问和操作Jupyter核心组件,如内核、文件系统和终端。本文深入解析其技术架构、功能特性及部署方法。MCP服务器解决了传统AI模型缺乏实时上下文感知的问题,支持代码执行、变量状态获取、文件管理等功能,提升编程效率。同时,严格的权限控制确保了安全性。作为智能化交互工具,Jupyter MCP为动态计算环境与AI模型之间搭建了高效桥梁。
586 2
Jupyter MCP服务器部署实战:AI模型与Python环境无缝集成教程
|
9月前
|
域名解析 SQL 网络协议
阿里云服务器国际站高防bgp服务器参数怎么看?服务器被攻击了怎么解决?
阿里云服务器国际站高防bgp服务器参数怎么看?服务器被攻击了怎么解决?
378 4
|
9月前
|
Go API 定位技术
MCP 实战:用 Go 语言开发一个查询 IP 信息的 MCP 服务器
随着 MCP 的快速普及和广泛应用,MCP 服务器也层出不穷。大多数开发者使用的 MCP 服务器开发库是官方提供的 typescript-sdk,而作为 Go 开发者,我们也可以借助优秀的第三方库去开发 MCP 服务器,例如 ThinkInAIXYZ/go-mcp。 本文将详细介绍如何在 Go 语言中使用 go-mcp 库来开发一个查询 IP 信息的 MCP 服务器。
563 2
|
9月前
|
弹性计算 资源调度 搜索推荐
阿里云ECS中长期成本节省计划解析:从原理到实战,助力企业降本提效
阿里云ECS节省计划的推出为企业用户提供了一种全新的成本优化方案。通过一次性购买的方式享受长期按量付费的折扣权益,客户不仅可以大幅降低ECS资源的使用成本还可以享受更高的灵活性和便捷性。本文将从多个维度深入剖析阿里云ECS节省计划,包括其核心优势、详尽的购买使用指引、与传统付费模式的全面对比,以及一客户成功案例,以供大家了解和参考。