jvm调优从哪几个方面 一般的Java项目需要JVM调优吗?注意哪些?
一般的Java项目需要JVM调优吗?注意哪些?
Java以其开源、高效、跨平台和良好的生态环境成为主流编程语言。即使是以前使用其他技术栈的公司,现在也在慢慢地向Java平台迁移。我相信很多Java学生在面试时都会被问到关于JVM调优的问题,但是他们似乎很少在日常工作中进行JVM调优。您想为一般Java项目进行JVM调优吗?
在我们讨论JVM调优之前,让我们先讨论一下JVM。什么是JVM?实际上,JVM是Java虚拟机的缩写。Java能够跨平台的原因实际上是基于JVM。
尽管JVM本身是一个计算机程序,但它也有自己的一套软件和硬件环境。
就像你买了一台新电脑。系统安装后,您可以正常使用计算机。但是很多用户需要自定义电脑,比如桌面背景。同样,JVM安装后,即使没有任何额外的设置,也可以正常工作,但在某些情况下,还需要对JVM进行调优,而调优的手段就是更改JVM参数。
JVM调优的目的是使用尽可能少的内存和CPU,使Java程序获得更高的吞吐量和更低的延迟。
2. JVM常用调优项
JVM最常用的调优是更改JVM的默认参数,例如:
最大堆大小:-Xmx
新生成大小:-XMN
不朽生成的最小值:-XX:permsize
不朽生成的最大值:-XX:maxpermsize
事实上,JVM的默认设置可以满足一般项目的需要。似乎只要您更改参数,JVM的调优就非常简单,但不是我,而是您认为的那么简单。
如果JVM调优不好,会影响整个项目的稳定性。在正常情况下,不建议调优JVM,除非Java项目内存太高,服务器内存太低。
为什么需要jvm调优?
JVM调优目标:使用较小的内存占用来实现更高的吞吐量或更低的延迟。
在上线前测试或运行程序的过程中,有时会出现一些JVM问题,比如CPU,负载过高,请求延迟,TPS降低,甚至内存泄漏(每次垃圾收集时间越来越长,垃圾收集频率越来越高,每次垃圾回收清理的垃圾数据越来越少),内存溢出导致系统崩溃,因此有必要对JVM进行调优,使程序在正常运行效率的前提下获得更高的用户体验和效率。
Net Core已经开源好几年了, 为什么不像JVM那样很多人研究和调优其GC算法?
我们已经推出了几个。Net核心项目,基本上是docker。净核心2/3。说实话。netcore的GC非常好。基本上,你不需要像Java那样做很多优化。所以没有多少研究是正常的。换句话说,如果一个GC需要做很多优化,那么它肯定不是一个好的GC。当然,平时编程、常用的非托管对象处理等都必须掌握。
jvm调优和tomcat调优的区别?
JVM调优的主要目的是在程序执行过程中合理分配内存资源,并在程序执行后设置内存恢复机制。
Tomcat调优主要是设置最大并发线程数、初始化期间创建的线程数以及超过最大并发线程数后可以等待连接的请求数。
jvm性能调优都做了什么?
JVM性能调优有很多设置,只需参考JVM参数即可。调优的主要目的是控制GC的行为。GC是后台处理,但它也消耗系统性能,因此它经常根据系统运行程序的特点改变GC的行为,控制JVM堆栈的大小。一般来说,您不需要修改JVM的内存分配。但是,当程序中的新一代对象在一段时间内增多时,需要控制新一代堆的大小。同时,需要控制JVM的总大小以避免内存溢出控制JVM线程的内存分配。如果是多线程程序,那么生成线程和运行线程所消耗的内存也可以控制。经过一段时间的观察,配置最佳结果
~]-XMS初始堆大小
-Xmx最大堆大小
-XMN年轻一代大小(1.4或播放器)
-XX:newsize设置年轻一代大小(对于1.3/1.4)
-XX:maxnewsize年轻一代的最大值(对于1.3/1.4)
-XX:permsize设置perm Gen的初始值
-XX:maxpermsize设置持续生成的最大值
-XSS每个线程的堆栈大小
-XX:threadstack size thread stack size
-XX:newratio年轻一代(包括Eden和两个幸存者)与老一代(不包括持续生成)的比率
-XX:surviorratio Eden区域与幸存者的比率area
-XX:不能将largepagesizeinbytes内存页的大小设置得太大,这将影响perm的大小
-XX:usefastaccessormethods基元类型的快速优化
-XX:disableexplicit GC closed系统.gc()
-XX:最大保留时间
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。