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

JDK 8.x 微服务启动JVM参数调优实战

微服务启动JVM参数调优实战

    • 1.1 配置JVM启动参数
    • 1.2 解释
    • 1.3 JVM参数优化思路
      • 1.3.1 调整堆内存大小
      • 1.3.2 年轻代大小
      • 1.3.3 Metaspace 大小
      • 1.3.4 栈大小
      • 1.3.5 垃圾回收器选择
      • 1.3.6 垃圾回收参数
      • 1.3.7 预分配内存
    • 1.3.8 禁用 ResizePLAB
    • 2. 常用JVM参数

1.1 配置JVM启动参数

服务器配置

硬件资源
内存6Gi
CPU4核
APP_PARAM="-Xmx2g -Xms2g -Xmn768m -XX:MetaspaceSize=256m -XX:MaxMetaspaceSize=256m -Xss256k -XX:+UseG1GC -XX:+AlwaysPreTouch -XX:-ResizePLAB -XX:+ParallelRefProcEnabled -XX:+ExplicitGCInvokesConcurrent -XX:MaxGCPauseMillis=200  -XX:ParallelGCThreads=4 -XX:ConcGCThreads=2"

1.2 解释

这是一个包含多个 Java 虚拟机(JVM)参数的变量 APP_PARAM,用于在启动 Java 程序时配置 JVM 的各种选项。让我们逐个解释这些参数的含义:

JVM参数解释
-Xmx2g设置 JVM 的最大堆内存为 2GB。这是 Java 堆可使用的最大内存量。
-Xms2g设置 JVM 的初始堆内存为 2GB。这是 Java 堆的初始内存大小,在 JVM 启动时将分配给堆。
-Xmn768m设置 JVM 的年轻代初始大小为 768MB。年轻代是 Java 堆中用于存放新创建的对象的区域。
-XX:MetaspaceSize=256m设置 Metaspace(元空间)的初始大小为 256MB。Metaspace 用于存放类的元数据。
-XX:MaxMetaspaceSize=256m设置 Metaspace(元空间)的最大大小为 256MB。当 Metaspace 达到这个大小时,JVM 将触发垃圾回收来回收不再使用的类元数据。
-Xss256k设置每个线程的栈大小为 256KB。这决定了每个线程可使用的内存大小。
-XX:+UseG1GC指定使用 G1 (Garbage-First) 垃圾回收器。G1 是一种现代的垃圾回收器,适用于大内存和多核处理器的应用。
-XX:+AlwaysPreTouch指定在 JVM 启动时,将堆的所有页面都预先分配和填充,以避免后续使用时的延迟。
-XX:-ResizePLAB禁用自适应的 Parallel Lab(PLAB)大小调整。PLAB 是 G1 回收器中用于优化对象分配的一种技术。
-XX:+ParallelRefProcEnabled启用并行的引用处理。这允许 G1 回收器在处理引用时使用并行处理。
-XX:+ExplicitGCInvokesConcurrent允许显式调用 System.gc() 时与并发标记周期并行执行垃圾回收。
-XX:MaxGCPauseMillis=200设置期望的最大 GC 暂停时间为 200 毫秒。G1 回收器将尽力保持 GC 暂停时间在这个范围内。
-XX:ParallelGCThreads=4设置并行垃圾回收的线程数为 4。这决定了在进行并行垃圾回收时使用的线程数量。
-XX:ConcGCThreads=2设置并发垃圾回收的线程数为 2。这决定了在进行并发垃圾回收时使用的线程数量。
  • 这些 JVM 参数可根据具体应用和硬件环境进行调整,以优化 Java 程序的性能和内存使用。
  • 请注意,某些参数可能在不同的 Java版本中或不同的 JVM 实现中具有不同的效果,因此建议根据具体情况进行测试和调优。

1.3 JVM参数优化思路

优化 JVM 参数是一个复杂的过程,需要根据具体应用和硬件环境进行调整。

以下是一些建议的优化措施:

1.3.1 调整堆内存大小

考虑根据应用的实际内存需求,适度增加堆的最大内存 -Xmx 和初始内存 -Xms。但不要过度分配,避免过大的堆导致频繁的垃圾回收。

1.3.2 年轻代大小

-Xmn 设置年轻代初始大小。根据应用的对象创建频率和堆大小,适度调整年轻代大小。较小的年轻代可能导致更频繁的垃圾回收,较大的年轻代可能会减少垃圾回收的频率。

1.3.3 Metaspace 大小

-XX:MetaspaceSize-XX:MaxMetaspaceSize 设置 Metaspace 的初始和最大大小。根据应用的类加载需求,适度增加 Metaspace 大小。

1.3.4 栈大小

-Xss 设置每个线程的栈大小。根据应用的线程需求,适度调整栈大小。过大的栈大小可能导致线程数受限于可用内存。

1.3.5 垃圾回收器选择

-XX:+UseG1GC 使用 G1 垃圾回收器是一个不错的选择,特别是在大内存和多核处理器环境下。

1.3.6 垃圾回收参数

根据实际情况调整垃圾回收器的参数,例如 -XX:MaxGCPauseMillis-XX:ParallelGCThreads-XX:ConcGCThreads。这些参数的调整需要在实际应用场景中进行性能测试和优化。

1.3.7 预分配内存

-XX:+AlwaysPreTouch 在 JVM 启动时预分配堆内存,避免后续内存分配导致的延迟。

1.3.8 禁用 ResizePLAB

-XX:-ResizePLAB 可以禁用 Parallel Lab(PLAB)大小调整。


  • 优化 JVM 参数需要综合考虑应用的性能需求、硬件环境和可用内存资源。
  • 建议在生产环境中进行测试和性能评估,逐步调整参数以达到最佳性能和内存利用率。
  • 同时,注意不要过度优化,避免因过多的参数调整而引入新的问题。

2. 常用JVM参数

在这里插入图片描述

相关文章:

JDK 8.x 微服务启动JVM参数调优实战

微服务启动JVM参数调优实战 1.1 配置JVM启动参数1.2 解释1.3 JVM参数优化思路1.3.1 调整堆内存大小1.3.2 年轻代大小1.3.3 Metaspace 大小1.3.4 栈大小1.3.5 垃圾回收器选择1.3.6 垃圾回收参数1.3.7 预分配内存 1.3.8 禁用 ResizePLAB2. 常用JVM参数 1.1 配置JVM启动参数 服务…...

Web与HTTP

目录 DNS与域名 DNS解析的方式 过程 注册域名 html 名词解释 html的语法 web web2.0 静态页面特点 动态页面 动态页面特点 http协议 工作流程 http的请求方式 get post 状态码 常用状态码 通信套接字 套接字调用的端口 DNS与域名 网络是基于tcp/ip协议进…...

算法刷题Day 56两个字符串的删除操作+编辑距离

Day 56 动态规划 583. 两个字符串的删除操作 class Solution { public:int minDistance(string word1, string word2) {int m word1.size(), n word2.size();vector<vector<int>> dp(m 1, vector<int>(n 1, 0));for (int i 0; i < m; i){dp[i][0] …...

Flutter中Dart语言常用知识

目录 1. 变量和数据类型2. 函数3. 类4. 异常处理5. 泛型6. 变量声明和类型推断&#xff1a;7. 函数定义&#xff1a;8. 类定义和实例化&#xff1a;9. 接口定义&#xff1a;10. 抽象类定义&#xff1a;11. 混合类型列表&#xff1a;12. Flutter 中的 UI 组件&#xff1a;13.Dar…...

11万多英藏对照词典英藏翻译ACCESS\EXCEL数据库

今天继续发一个藏文藏语相关的翻译数据库&#xff0c;即英藏对照词典&#xff0c;加上《5万6千多藏文词典解释ACCESS数据库》以及昨天发的《近13万汉藏对照词典汉藏翻译ACCESS\EXCEL数据库》藏文类的数据就算较全了。 截图下方有显示“共有记录数”&#xff0c;截图包含了表的所…...

浅谈C语言分支循环语句

为什么需要循环控制&#xff1f; 因为在日常生活中或者在程序所处理的问题中常常遇见需要重复处理的问题&#xff0c;用循环语句可以提高代码的运行效率&#xff0c;更快的解决日常生活中遇到的问题。 循环嵌套 就是传说中的套娃&#xff0c;不同的循环语句都可以互相嵌套。 …...

Spring Boot Starter 剖析与实践 | 京东云技术团队

引言 对于 Java 开发人员来说&#xff0c;Spring 框架几乎是必不可少的。它是一个广泛用于开发企业应用程序的开源轻量级框架。近几年&#xff0c;Spring Boot 在传统 Spring 框架的基础上应运而生&#xff0c;不仅提供了 Spring 的全部功能&#xff0c;还使开发人员更加便捷地…...

技术能力提升-《系统架构设计师教程》

在最近的月度读书会上&#xff0c;国林哥分享了下对《系统架构设计教程》的一点见解&#xff0c;在技术管理摸爬滚打了多年&#xff0c;觉得这个认证还是有一定价值&#xff0c;希望对有兴趣了解这门认证考试的朋友有所帮助&#xff0c;起到抛砖引玉的作用。 国林哥从以下四个方…...

【LeetCode 热题 100】矩阵 专题(大多原地算法,需要一定思维)

解题思路 在 代码注释中&#xff01; 文章目录 73. 矩阵置零54. 螺旋矩阵48. 旋转图像240. 搜索二维矩阵 II 73. 矩阵置零 class Solution { public:void setZeroes(vector<vector<int>>& matrix) {// 难点&#xff1a;原地算法// 直接复用 matrix 第一行 和 …...

Java 中为什么要把一个数模(10^9+7)

在计算机科学和编程中&#xff0c;经常会遇到需要对结果进行取模操作的情况。模运算是指将一个数除以另一个数&#xff0c;并取得余数的运算。 在 Java 中&#xff0c;常见的一个数取模的值是 (10^97)&#xff0c;即 1000000007。这个特定的数值经常在算法和数学计算中被使用&…...

RPC与REST有什么区别?

原文&#xff1a;RPC与REST有什么区别&#xff1f; 背景 好多开发的同学在工作中&#xff0c;经常分不清RPC和REST的区别&#xff0c;导致经常沟通不在一个层次上。甚至有些同学把这两个当成同一个东西。 RPC与REST的区别&#xff1f; 对比名称 rpc rest 备注 架构风格 RP…...

时间复杂度介绍及其计算

时间复杂度 1.算法效率 如何衡量一个算法的好坏呢&#xff1f;看这段代码&#xff1a; long long Fib(int N) {if(N < 3)return 1;return Fib(N-1) Fib(N-2); }这是斐波那契数列的递归代码&#xff0c;非常简洁&#xff0c;那么这就一定说明它好吗&#xff1f;答案显而易…...

etcd实现大规模服务治理应用实战

导读&#xff1a;服务治理目前越来越被企业建设所重视&#xff0c;特别现在云原生&#xff0c;微服务等各种技术被更多的企业所应用&#xff0c;本文内容是百度小程序团队基于大模型服务治理实战经验的一些总结&#xff0c;同时结合当前较火的分布式开源kv产品etcd&#xff0c;…...

目标检测中 anchor base和anchor free

目标检测中两种不同anchor的生成 趋势&#xff1a;anchor free越来越受到实时性检测的青睐&#xff0c;&#xff0c;&#xff0c;...

TypeC拓展设计方案|TypeC转HDMI设计方案|CS5261/CS5265芯片设计参数对比

集睿智远CS5261/CS5265都可以用于设计TypeC转HDMI方案&#xff0c;低成本TypeC扩展坞设计方案&#xff0c;而两者也有些差异&#xff1a;1.CS5261支持DP1.4输入&#xff0c;一个HDMI1.4输出&#xff0c;即HDMI输出为4K30HZ ;CS5265DP1.4到HDMI2.0转换芯片&#xff0c;即HDMI输出…...

SQL Developer中的Active Data Guard

这篇文章 Display Data Guard configuration in SQL Developer 中&#xff0c;用SQL Developer展示了多种ADG的拓扑。 今天自己也试了一下&#xff0c;还蛮简单的&#xff0c;其实最麻烦的部分在于搭建一个ADG环境。 假设我已有一个ADG环境&#xff0c;即最典型的环境&#x…...

谈谈FFT到底有何用

谈谈FFT到底有何用 FFT快速傅里叶变换是数字信号处理的经典算法,学过DSP或者芯片设计的人大多知道这个算法;但是,大家是否想过,为什么数字信号处理会有那么多FFT呢有人会说,为了分析信号的频谱;那么下边的问题就是,分析频谱对我们的日常需求,比如手机打电话,雷达测量速度和方向…...

MATLAB | 如何绘制这样的描边散点图?

part.-1 前前言 最近略忙可能更新的内容会比较简单&#xff0c;见谅哇&#xff0c;今日更新内容&#xff1a; part.0 前言 看到gzhBYtools科研笔记(推荐大家可以去瞅瞅&#xff0c;有很多有意思的图形的R语言复现&#xff01;&#xff01;)做了这样一张图&#xff1a; 感觉很…...

偶数科技与白鲸开源完成兼容性认证

近日&#xff0c;偶数科技自主研发的云原生分布式数据库 OushuDB v5.0 完成了与白鲸开源集成调度工具 WhaleStudio v2.0 的兼容性相互认证测试。 测试结果显示&#xff0c;双方产品相互良好兼容&#xff0c;稳定运行、安全&#xff0c;同时可以满足性能需求&#xff0c;为企业级…...

【机器学习】Feature scaling and Learning Rate (Multi-variable)

Feature scaling and Learning Rate 1、数据集2、学习率2.1 α \alpha α 9.9e-72.2 α \alpha α 9e-72.3 α \alpha α 1e-7 3、特征缩放3.1 特征缩放的原因3.2 Z-score 归一化3.3 预测3.4 损失等值线 导入所需的库 import numpy as np np.set_printoptions(precision…...

FreeMove:Windows系统C盘空间终极清理方案,无需重装释放数十GB

FreeMove&#xff1a;Windows系统C盘空间终极清理方案&#xff0c;无需重装释放数十GB 【免费下载链接】FreeMove Move directories without breaking shortcuts or installations 项目地址: https://gitcode.com/gh_mirrors/fr/FreeMove 还在为C盘空间不足而烦恼吗&…...

AI气象模型统一基准:可复现、多源真值、时空一致的评测标尺

1. 这不是又一个“天气数据集”&#xff0c;而是一把标尺&#xff1a;为什么AI气象建模急需统一基准“AI Weather Models”这个词组最近两年在气象学会议、AI顶会和工业界技术白皮书里出现的频率&#xff0c;已经快赶上“大模型”本身了。但我和团队在去年参与三个不同机构的AI…...

Mos:macOS 鼠标滚轮太生硬?这款免费开源工具让你的滚轮爽如触控板

如果你刚从 Windows 转到 macOS&#xff0c;或者习惯了 MacBook 触控板丝滑的滚动体验&#xff0c;再插上鼠标用滚轮时&#xff0c;大概率会觉得哪里不对劲——网页一顿一顿地跳&#xff0c;代码编辑器里翻行像在打碟&#xff0c;哪怕是在备忘录里上下滑动&#xff0c;那种生涩…...

PTFE材料在多领域的创新应用与发展分析

PTFE材料在生活领域的独特贡献不粘锅技术的演变与PTFE应用不粘锅的问世大大推动了厨房烹饪的便利性&#xff0c;而PTFE材料在其中扮演了关键角色。随着科技的发展&#xff0c;我们见证了PTFE涂层技术的不断创新&#xff0c;早期的传统不粘锅被更为耐磨、不易脱落的新型PTFE涂层…...

KAN网络实战:5分钟看懂如何用它‘可视化’发现物理定律(以安德森定域化为例)

KAN网络&#xff1a;用可视化方法发现物理定律的AI协作者 在科学研究的前沿&#xff0c;物理学家们常常需要从海量数据中识别出隐藏的规律和模式。传统的人工智能方法虽然能够提供预测结果&#xff0c;却往往难以解释其内部机制&#xff0c;这让科学家们难以信任和验证这些&quo…...

5分钟搞定AI 3D建模!TripoSR:图片秒变专业3D模型的终极方案

5分钟搞定AI 3D建模&#xff01;TripoSR&#xff1a;图片秒变专业3D模型的终极方案 【免费下载链接】TripoSR TripoSR: Fast 3D Object Reconstruction from a Single Image 项目地址: https://gitcode.com/GitHub_Trending/tr/TripoSR 还在为复杂的3D建模软件头疼吗&am…...

Unity游戏资源提取实战指南:AssetStudio高阶用法与避坑手册

1. 这不是“又一个AssetStudio教程”&#xff0c;而是我拆了27款Unity手游后总结的资源提取生存手册AssetStudio、Unity游戏资源提取、Unity AssetBundle、Unity3D反编译——这几个词&#xff0c;过去三年里我每天至少在技术群、论坛、工单系统里看到50次。但绝大多数人点开Ass…...

为什么你的ElevenLabs挪威语输出总被用户投诉“像AI朗读”?——基于217小时母语者A/B测试的5个声学参数调优阈值

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;挪威语语音“AI感”感知机制与母语者听觉认知模型 当挪威语母语者听到由现代TTS系统&#xff08;如Coqui TTS或Azure Neural TTS&#xff09;生成的挪威语语音时&#xff0c;常产生一种微妙的“AI感”—…...

终极指南:如何用AhabAssistantLimbusCompany彻底解放《Limbus Company》游戏时间

终极指南&#xff1a;如何用AhabAssistantLimbusCompany彻底解放《Limbus Company》游戏时间 【免费下载链接】AhabAssistantLimbusCompany AALC&#xff0c;PC端Limbus Company小助手。AALC&#xff0c;Limbus Company Assistant on PC 项目地址: https://gitcode.com/gh_mi…...

BetterCodable高级用法:自定义策略和属性包装器的深度解析

BetterCodable高级用法&#xff1a;自定义策略和属性包装器的深度解析 【免费下载链接】BetterCodable Better Codable through Property Wrappers 项目地址: https://gitcode.com/gh_mirrors/be/BetterCodable BetterCodable是一个通过属性包装器(Property Wrapper)增强…...