首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

每天百万交易的支付系统,生产环境该怎么设置JVM内存大小

java的时候很少去思考这个JVM的相关参数到底怎么去设置,更很少去预估我们程序所需的内存以及并发量等等,或者是直接参考公司资深工程师写的配置。...好,那我们今天就结合实际案例来每日百万交易的支付系统,生产环境该怎么去设置JVM内存大小。...03 支付系统每秒钟需要处理多少笔支付订单 要想合理设置我们JVM内存大小,我们就得去计算出我们系统每秒会处理多少笔支付单。...09 JVM堆内存该如何设置 这里建议,生产环境服务器至少最普通是4CPU 8G 来部署我们的支付系统,那么我们的JVM进程至少可以给4G以上内存,新生代在里面至少可以分配到2G内存空间,这样子就可以做到可能新生代每秒钟...总结,今天我带着大家来分析了一个系统开发完,我们该怎么去再生产环境配置我们的JVM内存大小,主要需要考虑我们应该部署多少台机器?每台机器要多少内存?每台机器每秒钟能有多少的请求过来并且生成对象?

1.4K10

java虚拟机内存大小_jvm内存分布

看着就是一个16字节的文件,看着像乱码,其实每个都是有对应的含义的,oracle官方是有专门的jvm字节码指令手册来查询每组指令对应的含义的。那我们研究的,当然不是这个。...那么一样的,这个jvm指令官方也是有手册可以查阅的,网上也有很多翻译版本,大家如果想了解可自行百度。 这里我只讲解本博文设计代码中的部分指令含义: 0....那么jvm虚拟机为什么要设置程序计数器这个结构呢?...我们这里使用jdk自带的一个jvm调优工具jvisualvm来观察一下这个代码执行的的内存结构。...到这里jvm内存模型简单介绍就结束了,看到这里还不点个赞嘛! 欢迎访问我的个人小站哦:我爱吃土豆 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。

1.1K30

JVM - 应用JVM核心参数推荐设置

Pre JVM-08垃圾收集Garbage Collection【GC常用参数】 ? ---- JDK版本 = 1.8 ---- 核心参数 ?...---- 线程栈 默认1M , 不足的话 StackOverflowError -Xss设置越小 ,说明一个线程栈里能分配的栈帧就越少,但是对JVM整体来说能开启的线程数会更多 ,当然了,线程多了并不一定性能就高...对于64位JVM来说,元空间的默认初始大小是21MB,若不足,GC后自动扩容,无上限,取决于操作系统的内存大小。...---- 【经验之谈】 一般建议在JVM参数中将MetaspaceSize和MaxMetaspaceSize设置成一样的值 ,8G物理内存的机器来说,可以将这两个参数设置为256M 如果应用启动比较慢,...可以看下是不是因为方法区的JVM参数没有设置(默认值21 ,频繁GC,自动扩容)导致的。

1.4K40

JVM系列——JVM参数及如何设置

本次主要内容: 如何查看参数标准参数-X参数-XX参数Boolean类型非Boolean类型其他参数如何设置参数单位换算JVM常见参数和含义 如何查看参数 java -XX:+PrintFlagsFinal...-server:设置jvm使server模式,特点是启动速度比较慢,但运行时性能和内存管理效率很高,适用于生产环境。在具有64位能力的jdk环境下将默认启用该模式,而忽略-client参数。...开发工具中设置比如IDEA(前面已经演示过了),eclipse也和IDEA类似 运行jar包的时候:java -XX:+UseG1GC xxx.jar web容器比如tomcat,可以在脚本中的进行设置...manageable的flags可以被实时修改) 单位换算 1Byte(字节)=8bit(位) 1KB=1024Byte(字节) 1MB=1024KB 1GB=1024MB 1TB=1024GB 示例: 设置内存大小和参数打印...查询堆内存大小MaxHeapSize:= 104857600 值得注意的是"="表示默认值,":="表示被用户或JVM修改后的值 ?

4.4K20

jvm linux 时区设置

那么问题变成了jvm从哪里去获取时区的呢?...经过查询大致如下: 1)如有环境变量 TZ设置,则用TZ中设置的时区 2) 在 /etc/sysconfig/clock文件中找 "ZONE"的值 3)如2)都没,就用/etc/localtime...于是开始设置了,TZ不管了,加了/etc/sysconfig/clock,如下操作: 新建一个/etc/sysconfig/clock,内容如下: ZONE="Asia/Shanghai" UTC=false...但是在实际工作中,发现这种方式是不能够使得服务器上的时间设置马上生效的,而且使用ntpdate去同步时间服务器也不能够更改时间。...即使你使用了 date命令手工设置了时间的话,如果使用ntpdate去进行时间同步的话,时间又会被改动到原来的错误时区的时间。而生产的机器往往是非常重要的,不能够进行重启等操作。

8.2K30

JVM系列三:JVM参数设置、分析

本文将注重介绍JVM、GC的一些重要参数的设置来提高系统的性能。...设置持久代最大值 物理内存的1/4 -Xss 每个线程的堆栈大小 JDK5.0以后每个线程堆栈大小为1M,以前每个线程堆栈大小为256K.更具应用的线程所需内存大小进行 调整.在相同物理内存下,减小这个值能生成更多的线程...(此项待验证) -XX:+UseParNewGC 设置年轻代为并行收集 可与CMS收集同时使用JDK5.0以上,JVM会根据系统配置自行设置,所以无需再设置此值 -XX:ParallelGCThreads...采用并发回收时,年轻代小一点,年老代要大,因为年老大用的是并发回收,即使时间长点也不会影响其他程序继续运行,网站不会停顿 JVM参数的设置(特别是 –Xmx –Xms –Xmn -XX:SurvivorRatio...,而且更重要的是,年老代和永久代上升非常慢(因为好多对象到不了年老代就被回收了),所以CMS执行频率非常低,好几个小时才执行一次,这样,服务器都不用重启了。

1.6K60

JVM参数汇总:JVM内存设置多大合适?Xmx和Xmn如何设置

年轻代Xmn的设置为老年代存活对象的1-1.5倍。 老年代的内存大小设置为老年代存活对象的2-3倍。...方式1(推荐/比较稳妥): JVM参数中添加GC日志,GC日志中会记录每次FullGC之后各代的内存大小,观察老年代GC之后的空间大小。...例如: 常用的参数介绍: -Xms512m 设置JVM促使内存为512m。此值可以设置与-Xmx相同,以避免每次垃圾回收完成后JVM重新分配内存。...-Xmx512m ,设置JVM最大可用内存为512M。 -Xmn200m:设置年轻代大小为200M。...,而且更重要的是,年老代和永久代上升非常慢(因为好多对象到不了年老代就被回收了),所以CMS执行频率非常低,好几个小时才执行一次,这样,服务器都不用重启了。

14K100

JVM参数设置、分析

本文将注重介绍JVM、GC的一些重要参数的设置来提高系统的性能。 JVM内存组成及GC相关内容请见之前的文章:JVM内存组成 GC策略&内存申请。...JDK5.0以后每个线程堆栈大小为1M,以前每个线程堆栈大小为256K.更具应用的线程所需内存大小进行 调整.在相同物理内存下,减小这个值能生成更多的线程.但是操作系统对一个进程内的线程数还是有限制的...(此项待验证) -XX:+UseParNewGC 设置年轻代为并行收集 可与CMS收集同时使用 JDK5.0以上,JVM会根据系统配置自行设置,所以无需再设置此值 -XX:ParallelGCThreads...采用并发回收时,年轻代小一点,年老代要大,因为年老大用的是并发回收,即使时间长点也不会影响其他程序继续运行,网站不会停顿 JVM参数的设置(特别是 –Xmx –Xms –Xmn -XX:SurvivorRatio...,而且更重要的是,年老代和永久代上升非常慢(因为好多对象到不了年老代就被回收了),所以CMS执行频率非常低,好几个小时才执行一次,这样,服务器都不用重启了。

10410

全网最硬核 JVM 内存解析 - 4.Java 堆内存大小的确认

Java 堆内存相关设计(全网最硬核 JVM 内存解析 - 4.Java 堆内存大小的确认开始) 通用初始化与扩展流程 直接指定三个指标的方式(涉及 JVM 参数:MaxHeapSize,MinHeapSize...内存解析 - 11.元空间分配与回收流程举例开始) CommitLimiter 的限制元空间可以 commit 的内存大小以及限制元空间占用达到多少就开始尝试 GC 每次 GC 之后,也会尝试重新计算...,但是,我们经常看到的可能是 Xmx 以及 Xms 这两个参数设置这三个指标,这两个参数分别对应: Xmx:对应 最大堆大小 等价于 MaxHeapSize Xms:相当于同时设置最小堆大小 MinHeapSize...由此引入第一个 JVM 参数,MaxRAM,这个参数是用来明确指定 JVM 进程可用内存大小的,如果没有指定,JVM 会自己读取系统可用内存。这个可用内存用来指导 JVM 限制最大堆内存。...:注意不要被名字迷惑,这个参数是在可用内存比较大的时候生效,即最大堆内存占用为可用内存的这个参数指定的百分比,默认为 25,即 25% ErgoHeapSizeLimit:通过自动计算,计算出的最大堆内存大小不超过这个参数指定的大小

77020

jvm 参数设置与分析

概述 之前的文章中介绍了 jvm 内存管理和垃圾收集的相关内容,结合这些理论知识,通过合理设置参数才能将系统的性能得以提升。 2. JVM 主要参数 2.1....基本的设置参数 JVM 设置参数的主要含义 参数名称 含义 默认值 说明 -Xms 最小堆大小 物理内存的 1/64(<1GB) 空闲堆内存小于40%(通过 MinHeapFreeRatio 参数可调整该阈值...并行收集相关的参数 JVM 并行GC的设置参数 参数名称 含义 默认值 说明 -XX:+UseParGC 使用 ParNew 收集器进行新生代收集 false 与 -XX:+UseConcMarkSweepGC...CMS 相关参数 JVM CMS GC 的设置参数 参数名称 含义 默认值 说明 -XX:+UseConcMarkSweepGC 启用 CMS GC false - -XX:CMSFullGCsBeforeCompaction...进行并发收集,所以老年代不能设计过小,否则会因为内存过多造成频繁 full GC;如果设计过大,则需要较长的收集,因此需要结合并发收集信息、持久化并发收集次数、传统GC信息、年轻代和老年代的时间比例考虑具体的内存大小

85820
领券