O2OA(翱途)服务器配置与管理-如何修改服务器内存占用率?

2024-08-21 07:28

本文主要是介绍O2OA(翱途)服务器配置与管理-如何修改服务器内存占用率?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

o2server 启动后一般占用大约4G~6G内存空间,在启动脚本中默认设置 -Xms2g 限定heap(堆)的大小最小2G,可以通过设置-Xmx来设置堆的上限.

Xms

-Xms2g:设置JVM初始堆内存为2g.此值可以设置与-Xmx相同,以避免每次垃圾回收完成后JVM重新分配内存.

Xmx

-Xmx5g:设置JVM最大堆内存为5g.如果不设置默认情况下为物理内存的1/4.

内存占用

下面我们看一下o2server实际内存占用.通过 top 命令可以看到运行中o2server的pid号为:15167

top内存.png

实际占用内存4.014g.但是这4g内存中有很大一部分处于空闲状态.

通过命令:

/data/o2server/jvm/linux_java11/bin/jhsdb jmap --heap --pid 15167

我们可以查看到内存占用情况如图:

jhsdb.png

实际堆占用内存2458M,使用1486M,空闲971M

实际占用内存至少有40%是处于free状态预留的.

MinHeapFreeRatio = 40
MaxHeapFreeRatio = 70

其中MinHeapFreeRatio = 40表示如果free的内存比上现在占用的内存,也就是空闲比例小于40,那么jvm将向系统申请一些内存以至少达到40%的比例---扩容.

其中MaxHeapFreeRatio = 70表示如果free的内存比上现在占用的内存,也就是空闲比例大于70,那么jvm将减少占用的内存,并将减少占用的内存释放操作系统--缩容.

设置
-XX:MaxHeapFreeRatio,-XX:MinHeapFreeRatio

如果内存比较紧张,比如在docker环境中,我们可以通过设置-XX:MaxHeapFreeRatio和-XX:MinHeapFreeRatio,减少jvm预留的空间:

````shell
-XX:MinHeapFreeRatio=10 -XX:MaxHeapFreeRatio=25
````

当空闲内存大于25%时进行缩容,当空闲内存小于10时进行扩容.减少预留的free空间.

设置GC

再次运行jhsdb查看

jhsdb_2g.png

虽然设置已经生效但是实际内存并没有释放回操作系统,还是占用在预留空间中,java11默认使用G1GC,jvm并不一定会立即归还系统内存.我们将GC改为serialGC(-XX:+UseSerialGC).

jhsdb_serialGC.png

可以看到jvm立即归还了内存,在不同的GC下表现并不一致,G1GC也会逐渐归还内存给操作系统.

在Java12中可以使用ShenandoahGC(-XX:+UseShenandoahGC),可以更快的将可释放的内存归还给操作系统.

总结

各种常用的GC中只有ParallelGC不具备内存伸缩能力.而其他的GC.例如:Serial.CMS,G1,ShenandoahGC都具备内存伸缩能力.需要说明的是,具备伸缩能力的前提是Xms小于Xmx,其伸缩能力上限由Xmx限制,伸缩能力下限由Xms限制.伸缩的比例由MaxHeapFreeRatio和MinHeapFreeRatio控制,其中Serial和CMS的效果一般,G1需要借助FGC才能将不再使用的内存归还给操作系统.至于JDK12带来的ShenandoahGC,效果非常好,而且不需要依赖FGC,异步就能完成完成内存伸缩.

这篇关于O2OA(翱途)服务器配置与管理-如何修改服务器内存占用率?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1092501

相关文章

SpringBoot改造MCP服务器的详细说明(StreamableHTTP 类型)

《SpringBoot改造MCP服务器的详细说明(StreamableHTTP类型)》本文介绍了SpringBoot如何实现MCPStreamableHTTP服务器,并且使用CherryStudio... 目录SpringBoot改造MCP服务器(StreamableHTTP)1 项目说明2 使用说明2.1

Spring Boot Maven 插件如何构建可执行 JAR 的核心配置

《SpringBootMaven插件如何构建可执行JAR的核心配置》SpringBoot核心Maven插件,用于生成可执行JAR/WAR,内置服务器简化部署,支持热部署、多环境配置及依赖管理... 目录前言一、插件的核心功能与目标1.1 插件的定位1.2 插件的 Goals(目标)1.3 插件定位1.4 核

RabbitMQ消息总线方式刷新配置服务全过程

《RabbitMQ消息总线方式刷新配置服务全过程》SpringCloudBus通过消息总线与MQ实现微服务配置统一刷新,结合GitWebhooks自动触发更新,避免手动重启,提升效率与可靠性,适用于配... 目录前言介绍环境准备代码示例测试验证总结前言介绍在微服务架构中,为了更方便的向微服务实例广播消息,

nginx 负载均衡配置及如何解决重复登录问题

《nginx负载均衡配置及如何解决重复登录问题》文章详解Nginx源码安装与Docker部署,介绍四层/七层代理区别及负载均衡策略,通过ip_hash解决重复登录问题,对nginx负载均衡配置及如何... 目录一:源码安装:1.配置编译参数2.编译3.编译安装 二,四层代理和七层代理区别1.二者混合使用举例

Java JDK1.8 安装和环境配置教程详解

《JavaJDK1.8安装和环境配置教程详解》文章简要介绍了JDK1.8的安装流程,包括官网下载对应系统版本、安装时选择非系统盘路径、配置JAVA_HOME、CLASSPATH和Path环境变量,... 目录1.下载JDK2.安装JDK3.配置环境变量4.检验JDK官网下载地址:Java Downloads

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

Jenkins分布式集群配置方式

《Jenkins分布式集群配置方式》:本文主要介绍Jenkins分布式集群配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装jenkins2.配置集群总结Jenkins是一个开源项目,它提供了一个容易使用的持续集成系统,并且提供了大量的plugin满