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 |
CPU | 4核 |
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. 变量声明和类型推断:7. 函数定义:8. 类定义和实例化:9. 接口定义:10. 抽象类定义:11. 混合类型列表:12. Flutter 中的 UI 组件:13.Dar…...

11万多英藏对照词典英藏翻译ACCESS\EXCEL数据库
今天继续发一个藏文藏语相关的翻译数据库,即英藏对照词典,加上《5万6千多藏文词典解释ACCESS数据库》以及昨天发的《近13万汉藏对照词典汉藏翻译ACCESS\EXCEL数据库》藏文类的数据就算较全了。 截图下方有显示“共有记录数”,截图包含了表的所…...
浅谈C语言分支循环语句
为什么需要循环控制? 因为在日常生活中或者在程序所处理的问题中常常遇见需要重复处理的问题,用循环语句可以提高代码的运行效率,更快的解决日常生活中遇到的问题。 循环嵌套 就是传说中的套娃,不同的循环语句都可以互相嵌套。 …...

Spring Boot Starter 剖析与实践 | 京东云技术团队
引言 对于 Java 开发人员来说,Spring 框架几乎是必不可少的。它是一个广泛用于开发企业应用程序的开源轻量级框架。近几年,Spring Boot 在传统 Spring 框架的基础上应运而生,不仅提供了 Spring 的全部功能,还使开发人员更加便捷地…...
技术能力提升-《系统架构设计师教程》
在最近的月度读书会上,国林哥分享了下对《系统架构设计教程》的一点见解,在技术管理摸爬滚打了多年,觉得这个认证还是有一定价值,希望对有兴趣了解这门认证考试的朋友有所帮助,起到抛砖引玉的作用。 国林哥从以下四个方…...
【LeetCode 热题 100】矩阵 专题(大多原地算法,需要一定思维)
解题思路 在 代码注释中! 文章目录 73. 矩阵置零54. 螺旋矩阵48. 旋转图像240. 搜索二维矩阵 II 73. 矩阵置零 class Solution { public:void setZeroes(vector<vector<int>>& matrix) {// 难点:原地算法// 直接复用 matrix 第一行 和 …...
Java 中为什么要把一个数模(10^9+7)
在计算机科学和编程中,经常会遇到需要对结果进行取模操作的情况。模运算是指将一个数除以另一个数,并取得余数的运算。 在 Java 中,常见的一个数取模的值是 (10^97),即 1000000007。这个特定的数值经常在算法和数学计算中被使用&…...

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

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

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

目标检测中 anchor base和anchor free
目标检测中两种不同anchor的生成 趋势:anchor free越来越受到实时性检测的青睐,,,...

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

SQL Developer中的Active Data Guard
这篇文章 Display Data Guard configuration in SQL Developer 中,用SQL Developer展示了多种ADG的拓扑。 今天自己也试了一下,还蛮简单的,其实最麻烦的部分在于搭建一个ADG环境。 假设我已有一个ADG环境,即最典型的环境&#x…...
谈谈FFT到底有何用
谈谈FFT到底有何用 FFT快速傅里叶变换是数字信号处理的经典算法,学过DSP或者芯片设计的人大多知道这个算法;但是,大家是否想过,为什么数字信号处理会有那么多FFT呢有人会说,为了分析信号的频谱;那么下边的问题就是,分析频谱对我们的日常需求,比如手机打电话,雷达测量速度和方向…...

MATLAB | 如何绘制这样的描边散点图?
part.-1 前前言 最近略忙可能更新的内容会比较简单,见谅哇,今日更新内容: part.0 前言 看到gzhBYtools科研笔记(推荐大家可以去瞅瞅,有很多有意思的图形的R语言复现!!)做了这样一张图: 感觉很…...

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

【机器学习】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…...
浏览器访问 AWS ECS 上部署的 Docker 容器(监听 80 端口)
✅ 一、ECS 服务配置 Dockerfile 确保监听 80 端口 EXPOSE 80 CMD ["nginx", "-g", "daemon off;"]或 EXPOSE 80 CMD ["python3", "-m", "http.server", "80"]任务定义(Task Definition&…...

【Python】 -- 趣味代码 - 小恐龙游戏
文章目录 文章目录 00 小恐龙游戏程序设计框架代码结构和功能游戏流程总结01 小恐龙游戏程序设计02 百度网盘地址00 小恐龙游戏程序设计框架 这段代码是一个基于 Pygame 的简易跑酷游戏的完整实现,玩家控制一个角色(龙)躲避障碍物(仙人掌和乌鸦)。以下是代码的详细介绍:…...

Python:操作 Excel 折叠
💖亲爱的技术爱好者们,热烈欢迎来到 Kant2048 的博客!我是 Thomas Kant,很开心能在CSDN上与你们相遇~💖 本博客的精华专栏: 【自动化测试】 【测试经验】 【人工智能】 【Python】 Python 操作 Excel 系列 读取单元格数据按行写入设置行高和列宽自动调整行高和列宽水平…...

安宝特方案丨XRSOP人员作业标准化管理平台:AR智慧点检验收套件
在选煤厂、化工厂、钢铁厂等过程生产型企业,其生产设备的运行效率和非计划停机对工业制造效益有较大影响。 随着企业自动化和智能化建设的推进,需提前预防假检、错检、漏检,推动智慧生产运维系统数据的流动和现场赋能应用。同时,…...

visual studio 2022更改主题为深色
visual studio 2022更改主题为深色 点击visual studio 上方的 工具-> 选项 在选项窗口中,选择 环境 -> 常规 ,将其中的颜色主题改成深色 点击确定,更改完成...

新能源汽车智慧充电桩管理方案:新能源充电桩散热问题及消防安全监管方案
随着新能源汽车的快速普及,充电桩作为核心配套设施,其安全性与可靠性备受关注。然而,在高温、高负荷运行环境下,充电桩的散热问题与消防安全隐患日益凸显,成为制约行业发展的关键瓶颈。 如何通过智慧化管理手段优化散…...

使用 Streamlit 构建支持主流大模型与 Ollama 的轻量级统一平台
🎯 使用 Streamlit 构建支持主流大模型与 Ollama 的轻量级统一平台 📌 项目背景 随着大语言模型(LLM)的广泛应用,开发者常面临多个挑战: 各大模型(OpenAI、Claude、Gemini、Ollama)接口风格不统一;缺乏一个统一平台进行模型调用与测试;本地模型 Ollama 的集成与前…...

零基础在实践中学习网络安全-皮卡丘靶场(第九期-Unsafe Fileupload模块)(yakit方式)
本期内容并不是很难,相信大家会学的很愉快,当然对于有后端基础的朋友来说,本期内容更加容易了解,当然没有基础的也别担心,本期内容会详细解释有关内容 本期用到的软件:yakit(因为经过之前好多期…...
rnn判断string中第一次出现a的下标
# coding:utf8 import torch import torch.nn as nn import numpy as np import random import json""" 基于pytorch的网络编写 实现一个RNN网络完成多分类任务 判断字符 a 第一次出现在字符串中的位置 """class TorchModel(nn.Module):def __in…...

DingDing机器人群消息推送
文章目录 1 新建机器人2 API文档说明3 代码编写 1 新建机器人 点击群设置 下滑到群管理的机器人,点击进入 添加机器人 选择自定义Webhook服务 点击添加 设置安全设置,详见说明文档 成功后,记录Webhook 2 API文档说明 点击设置说明 查看自…...