侧边栏壁纸
博主头像
会飞的大象博主等级

爱运动的程序猿

  • 累计撰写 126 篇文章
  • 累计创建 158 个标签
  • 累计收到 0 条评论
标签搜索

目 录CONTENT

文章目录

java -jar 设置内存大小

会飞的大象
2021-12-29 / 0 评论 / 0 点赞 / 765 阅读 / 0 字
nohup java -jar -Xms128M -Xmx256M -XX:PermSize=64M -XX:MaxPermSize=128M  xxxx.jar

Xms — 堆内存初始大小
Xmx — 堆内存最大值
PermSize — 永久内存初始大小
MaxPermSize — 永久内存最大值

nohup java -Xms堆内存初始值m -Xmx堆内存最大值m -jar xx.jar >log.out & 

JDK8的JVM知识点:

JDK8之后把-XX:PermSize 和 -XX:MaxPermGen移除了,取而代之的是

-XX:MetaspaceSize=128m (元空间默认大小)

-XX:MaxMetaspaceSize=128m (元空间最大大小)

JDK 8开始把类的元数据放到本地化的堆内存(native heap)中,这一块区域就叫Metaspace,中文名叫元空间。

使用本地化的内存有什么好处呢?最直接的表现就是java.lang.OutOfMemoryError: PermGen 空间问题将不复存在,因为默认的类的元数据分配只受本地内存大小的限制,也就是说本地内存剩余多少,理论上Metaspace就可以有多大(貌似容量还与操作系统的虚拟内存有关?这里不太清楚),这解决了空间不足的问题。不过,让Metaspace变得无限大显然是不现实的,因此我们也要限制Metaspace的大小:使用-XX:MaxMetaspaceSize参数来指定Metaspace区域的大小。JVM默认在运行时根据需要动态地设置MaxMetaspaceSize的大小。

什么是jdk1.8默认堆大小? (MaxHeapSize)

就是使用java -jar 并且没有手动指定-Xmx参数的启动的进程使用的堆的大小,就是用的默认jdk堆的大小。

 

这个默认的堆大小是取决你服务器的物理内存,假如服务器内存大于1GB,则使用1/4的服务器物理内存作为jvm的堆内存大小。

例如:服务器内存4GB 则默认堆大小为1GB

           服务器内存32GB 则默认堆大小为8GB

 

可以用命令jmap -heap <pid> 验证一下

0

评论区