⑴ Linux里面JVM内存怎么设置
一、堆内存相关配置
设置堆初始值
指令1:-Xms2g
指令2:-XX:InitialHeapSize=2048m
设置堆区最大值
指令1:`-Xmx2g`
指令2: -XX:MaxHeapSize=2048m
缩小堆内存的时机
-XX:MaxHeapFreeRatio=70//堆内存使用率大于70时扩张堆内存,xms=xmx时该参数无效,默认值70
扩张堆内存的时机
-XX:MinHeapFreeRatio=40//堆内存使用率小于40时缩减堆内存,xms=xmx时该参数无效,默认值40
新生代内存配置
指令1:-Xmn512m
指令2:-XX:MaxNewSize=512m
2个survivor区和Eden区大小比率
指令:-XX:SurvivorRatio=6 //S区和Eden区占新生代比率为1:6,两个S区2:6
新生代和老年代的占比
-XX:NewRatio=4 //表示新生代:老年代 = 1:4 即老年代占整个堆的4/5;默认值=2
二、方法区内存配置常用参数
初始化的Metaspace大小,
-XX:MetaspaceSize :
Metaspace最大值
-XX:MaxMetaspaceSize
三、线程栈内存配置常用参数
每个线程栈最大值
指令1:-Xss256k
指令2:-XX:ThreadStackSize=256k
注意:
栈设置太大,会导致线程创建减少。
栈设置小,会导致深入不够,深度的递归会导致栈溢出。
建议栈深度设置在3000-5000
四、配置垃圾收集器
Serial垃圾收集器(新生代)
开启:-XX:+UseSerialGC
关闭:-XX:-UseSerialGC
//新生代使用Serial 老年代则使用SerialOld
ParNew垃圾收集器(新生代)
开启 -XX:+UseParNewGC
关闭 -XX:-UseParNewGC
//新生代使用功能ParNew 老年代则使用功能CMS
Parallel Scavenge收集器(新生代)
开启 -XX:+UseParallelOldGC
关闭 -XX:-UseParallelOldGC
//新生代使用功能Parallel Scavenge 老年代将会使用Parallel Old收集器
ParallelOl垃圾收集器(老年代)
开启 -XX:+UseParallelGC
关闭 -XX:-UseParallelGC
//新生代使用功能Parallel Scavenge 老年代将会使用Parallel Old收集器
CMS垃圾收集器(老年代)
开启 -XX:+UseConcMarkSweepGC
关闭 -XX:-UseConcMarkSweepGC
G1垃圾收集器
开启 -XX:+UseG1GC
关闭 -XX:-UseG1GC
五、GC策略配置
GC并行执行线程数
-XX:ParallelGCThreads=16
新生代可容纳的最大对象
-XX:PretenureSizeThreshold=1000000 //大于此值的对象直接会分配到老年代,设置为0则没有限制。 //避免在Eden区和Survivor区发生大量的内存复制,该参数只对Serial和ParNew收集器有效,Parallel Scavenge并不认识该参数
进入老年代的GC年龄
进入老年代最小的GC年龄
-XX:InitialTenuringThreshol=7 //年轻代对象转换为老年代对象最小年龄值,默认值7,对象在坚持过一次Minor GC之后,年龄就加1,每个对象在坚持过一次Minor GC之后,年龄就增加1
进入老年代最大的GC年龄
-XX:MaxTenuringThreshold=15 //年轻代对象转换为老年代对象最大年龄值,默认值15
六、GC日志信息配置
配置GC文件路径
-Xloggc:/data/gclog/gc.log//固定路径名称生成 -Xloggc:/home/GCEASY/gc-%t.log //根据时间生成
滚动生成日志
日志文件达到一定大小后,生成另一个文件。须配置Xloggc
开启 -XX:+UseGCLogFileRotation
关闭 -XX:-UseGCLogFileRotation
-XX:NumberOfGCLogFiles=4 //滚动GC日志文件数,默认0,不滚动 -XX:GCLogFileSize=100k //GC文件滚动大小,需配置UseGCLogFileRotation,设置为0表示仅通过jcmd命令触发
⑵ java xms 怎么设置大小
在一些规模稍大的应用中,Java虚拟机(JVM)的内存设置尤为重要,想在项目中取得好的效率,GC(垃圾回收)的设置是第一步。
PermGen space:全称是Permanent Generation space.就是说是永久保存的区域,用于存放Class和Meta信息,Class在被Load的时候被放入该区域Heap space:存放Instance。
GC(Garbage Collection)应该不会对PermGen space进行清理,所以如果你的APP会LOAD很多CLASS的话,就很可能出现PermGen space错误
Java Heap分为3个区
1.Young
2.Old
3.Permanent
Young保存刚实例化的对象。当该区被填满时,GC会将对象移到Old区。Permanent区则负责保存反射对象,本文不讨论该区。
JVM的Heap分配可以使用-X参数设定,
-Xms
初始Heap大小
-Xmx
java heap最大值
-Xmn
young generation的heap大小
JVM有2个GC线程
第一个线程负责回收Heap的Young区
第二个线程在Heap不足时,遍历Heap,将Young 区升级为Older区
Older区的大小等于-Xmx减去-Xmn,不能将-Xms的值设的过大,因为第二个线程被迫运行会降低JVM的性能。
为什么一些程序频繁发生GC?
有如下原因:
1.程序内调用了System.gc()或Runtime.gc()。
2.一些中间件软件调用自己的GC方法,此时需要设置参数禁止这些GC。
3.Java的Heap太小,一般默认的Heap值都很小。
4.频繁实例化对象,Release对象 此时尽量保存并重用对象,例如使用StringBuffer()和String()。
如果你发现每次GC后,Heap的剩余空间会是总空间的50%,这表示你的Heap处于健康状态,许多Server端的Java程序每次GC后最好能有65%的剩余空间
经验之谈:
1.Server端JVM最好将-Xms和-Xmx设为相同值。为了优化GC,最好让-Xmn值约等于-Xmx的1/3。
2.一个GUI程序最好是每10到20秒间运行一次GC,每次在半秒之内完成。
注意:
1.增加Heap的大小虽然会降低GC的频率,但也增加了每次GC的时间。并且GC运行时,所有的用户线程将暂停,也就是GC期间,Java应用程序不做任何工作。
2.Heap大小并不决定进程的内存使用量。进程的内存使用量要大于-Xmx定义的值,因为Java为其他任务分配内存,例如每个线程的Stack等。
Stack的设定
每个线程都有他自己的Stack。
-Xss
每个线程的Stack大小
Stack的大小限制着线程的数量。如果Stack过大就好导致内存溢漏。-Xss参数决定Stack大小,例如-Xss1024K。如果Stack太小,也会导致Stack溢漏。
硬件环境
硬件环境也影响GC的效率,例如机器的种类,内存,swap空间,和CPU的数量。
如果你的程序需要频繁创建很多transient对象,会导致JVM频繁GC。这种情况你可以增加机器的内存,来减少Swap空间的使用。
4种GC
1、第一种为单线程GC,也是默认的GC,该GC适用于单CPU机器。
2、第二种为Throughput GC,是多线程的GC,适用于多CPU,使用大量线程的程序。第二种GC与第一种GC相似,不同在于GC在收集Young区是多线程的,但在Old区和第一种一样,仍然采用单线程。-XX:+UseParallelGC参数启动该GC。
3、第三种为Concurrent Low Pause GC,类似于第一种,适用于多CPU,并要求缩短因GC造成程序停滞的时间。这种GC可以在Old区的回收同时,运行应用程序。-XX:+UseConcMarkSweepGC参数启动该GC。
4、第四种为Incremental Low Pause GC,适用于要求缩短因GC造成程序停滞的时间。这种GC可以在Young区回收的同时,回收一部分Old区对象。-Xincgc参数启动该GC。
单文件的JVM内存进行设置
默认的java虚拟机的大小比较小,在对大数据进行处理时java就会报错:java.lang.OutOfMemoryError。
设置jvm内存的方法,对于单独的.class,可以用下面的方法对Test运行时的jvm内存进行设置。
java -Xms64m -Xmx256m Test
-Xms是设置内存初始化的大小
-Xmx是设置最大能够使用内存的大小(最好不要超过物理内存大小)
tomcat启动jvm内存设置
Linux:
在/usr/local/apache-tomcat-5.5.23/bin目录下的catalina.sh添加:JAVA_OPTS='-Xms512m -Xmx1024m'要加“m”说明是MB,否则就是KB了,在启动tomcat时会报内存不足。
-Xms:初始值
-Xmx:最大值
-Xmn:最小值Windows
在catalina.bat最前面加入
set JAVA_OPTS=-Xms128m -Xmx350m 如果用startup.bat启动tomcat,OK设置生效.够成功的分配200M内存.但是如果不是执行startup.bat启动tomcat而是利用windows的系统服务启动tomcat服务,上面的设置就不生效了,就是说set JAVA_OPTS=-Xms128m -Xmx350m 没起作用.上面分配200M内存就OOM了..windows服务执行的是bin\tomcat.exe.他读取注册表中的值,而不是catalina.bat的设置.解决办法:
修改注册表HKEY_LOCAL_MACHINE\SOFTWARE\Apache Software Foundation\Tomcat Service Manager\Tomcat5\Parameters\JavaOptions
⑶ 如何设置电脑超频
前言:其实超频也可以这样简单
超频,说白了就是通过各种手段提高电脑各部件的运行频率,使其在高于额定的频率下运行,以此来
获得更高的性能。虽然对于高手来说,超频可能就是碟子里的一盘小菜,但是对于广大的普通用户,这似
乎还是显得有些神秘。今天我们要做的就是,揭开这层神秘的面纱,让超频不再是少数人的专利!
每次超频成功后的启动画面让人非常兴奋
我们为什么要超频?
首先我们来算一笔帐,一颗Athlon 64 3000+ Socket 939目前报价是1260元,而一块INTEL顶极
Pentium4 670(默认频率3.8GHz)处理器的售价需要6900元,你只需要通过稍微超频稳定运行2400 MHz,
那么你将获得的性能却要比将近7千元的处理器的性能强悍,而这个时候你只花费了不到五分之一的价钱。
很简单,少花钱,多办事!
世界最高超频频率7361.2MHz,SuperPI 1M=17.047秒
从认知的角度上来讲,超频可以让一个使用电脑的用户,熟悉超频后更为了解电脑硬件知识以及获得
故障排除的基本能力!通常你为了获得更好的性能,达到超频的目的,你会不断的自然而然想充实自己,
于是时常盯着看电脑刊物,留意着新硬件的功能如何!并且时常上网查询有关超频的资讯!玩超频在一定
程度上提高了使用电脑的用户的硬件水品。
《Half Life 2》
我们也希望用这篇入门手册来回击那些超频无用的论调。它可以证明,超频能够获得性能的提升,并且
不会损坏硬件。你很快会发现,超频是值得的...请看我们小编为您强力打造的超频入门手册。
软超频:让我们在桌面上狂奔4GHz
一、运用软件来实现超频
现在早已经不是以前必须打开机箱在主板上硬跳线来实现超频的时代,我们甚至在Windows下通过各种
软件就可以轻松的实现超频,这样的软件真是不胜枚举,ClockGen就是一个,它是由CPUID开发的免费工具
,这个软件不光可以从Windows中对Intel平台的处理器电压进行修改,还适用于Athlon64平台:
较为老式的硬跳线超频,通过不同的组合达到不同的频率
ClockGen
下载它之前,要选好对应于你的芯片组的版本:Nforce 3,Nforce 4或VIA。这个软件可以在Windows
下修改FSB和倍频。使用ClockGen的方法也非常简单,进入软件之后我们先点击“Get Values”按钮来获得
目前系统的CPU速度等情况,然后就可以通过拖动滑动条就能对处理器的外频和PCI-E总线的速度进行调整
。
另外,各主板厂商也日益对超频重视起来,纷纷在自己的主板产品中捆绑专门的超频软件,比如:
ASUS的AI Booster,Gigabyte的EasyTune、MSI的CoreCenter等等。
ASUS的AI Booster
Gigabyte的EasyTune
“超频”——永恒的话题,一个让众多DIYer、发烧友热血沸腾了多年的字眼。超频技术经过多年的演
化,已经从设置跳线(jumper)超频的方式进化为BIOS内调节超频甚至是动态的智能超频技术。
硬超频:进入BIOS,想超就超!
二、通过调整BIOS来实现超频
一般的主板在开机自检的时候,会在电脑屏幕的下方显示一行字“press delete to enter setup”,
此时只要按下键盘上的del键就可以进入主板的BIOS(基本输入输出系统)了。当然,不同主板进入BIOS的
方式不尽相同,例如技嘉主板,可能需要按进入BIOS,用户可以在屏幕初现的时候看屏幕上的提示,或者
是查阅主板用户指南。
首先要给大家介绍一下关于频率的知识,处理器的主频可以有以下公式计算得到:
外频(以MHz为单位)×倍频 = 主频(以MHz为单位)
外频(对AMD处理器来说是HTT)就是整个系统与CPU通信的通道。所以,外频能运行得越快,显然整个
系统就能运行得越快。速度等式的倍频部分也就是一个数字,乘上外频就给出了处理器的总速度。
比如:Intel Celeron D 310的主频为2.13GHz,其倍频为16x,FSB为133MHz,由公式计算出133.3 x
16 = 2133MHz,可见和CPU的标称频率还是符合的。由公式可以看出,理论上,提高CPU的频率可以有3种方
法:
一、提高CPU的FSB
二、提高CPU的倍频
三、CPU的FSB和倍频同时提高
不过在某些CPU上,例如Intel自1998年以来的处理器,倍频是锁定不能改变的。在有些上,例如AMD
Athlon 64处理器,倍频是“封顶锁定”的,也就是可以改变倍频到更低的数字,但不能提高到比默认的更
高。也有一些CPU,倍频是完全放开的,意味着能够把它改成任何想要的数字,不过这种类型的CPU现在非
常罕见了,在AMD K7平台上我们见得较多。
仅就超频而言,在CPU上提高或降低倍频比FSB容易得多了。这是因为倍频和FSB不同,它只影响
CPU速度。改变FSB时,实际上是在改变每个单独的电脑部件与CPU通信的速度,这实际上是在超频系统的所
有其它部件了,这很有可能带来各种各样的问题。不过可惜的是,提高FSB的频率几乎成了目前超频的唯一
途径。
华硕独有的AI Overclock(智能超频)
● 外频与前端总线(FSB)频率的区别
外频与前端总线(FSB)频率很容易被混为一谈。前端总线的速度指的是CPU和北桥芯片间总线的速度
,更实质性的表示了CPU和外界数据传输的速度。而外频的概念是建立在数字脉冲信号震荡速度基础之上的
,也就是说,100MHz外频特指数字脉冲信号在每秒钟震荡一万万次,它更多的影响了PCI及其他总线的频率
。
之所以前端总线与外频这两个概念容易混淆,主要的原因是在以前的很长一段时间里(主要是在
Pentium 4出现之前和刚出现Pentium 4时),前端总线频率与外频是相同的,因此往往直接称前端总线为
外频,最终造成这样的误会。随着计算机技术的发展,人们发现前端总线频率需要高于外频,因此采用了
QDR(Quad Date Rate)技术,或者其他类似的技术实现这个目的。这些技术的原理类似于AGP的2X或者4X
,它们使得前端总线的频率成为外频的2倍、4倍甚至更高,从此之后前端总线和外频的区别才开始被人们
重视起来。
三、内存频率的调节
为什么一开始超频便是调整内存设置呢?
正如之前所说的,FSB是系统与CPU通信的路径。所以提高FSB也有效地超频了系统的其余部件。因此,
CPU超频可不仅仅是调节FSB那么简单,内存也是CPU超频成功与否的关键所在。当CPU的FSB调高以后,内存
的频率也会自然跟着升高,此时过高的内存频率往往成为超频的瓶颈所在,因此在这个时候就需要首先适
当的降低内存频率以保证超频的成功率。
各主板BIOS中内存调节选项的标注方法不尽相同。比如:ASUS的内存调节选项就在Advanced Chipset
Features (或者Advanced或JumperFree Configuration)中的Memclock index value或者DRAM
Configuration一项。
EPoX的是在POWER BIOS Features里的System Memory Frequency(或者Memory Frequency)一项,并
且其内存参数以DDR400、DDR333 或者DDR266的形式表示。
选中内存的调节选项以后,一般可以按下回车键,然后进入下一级菜单再通过上下箭头具体调节;如
果不行的话可以试试PageUp、PageDown按键,有的主板则是通过“+”、“-”来调节,大多数主板都采用
的是这三种之一。适当的调节内存频率是超频的关键。开始,我们将内存频率尽可能设为最小值。
● 为什么要先将内存频率设为最小值呢?
在CPU超频的时候,我们会提升FSB频率,同时,内存的频率也会提升,如果将内存频率设为最小,它
将存在更多的提升空间。也就是说,我们要先尽可能地消除内存对CPU超频的影响。另外,我们还可以稍稍
将内存时序设高一点,或者为内存加少少电压,当然必须在允许的范围内进行。
接下来,我们保存所有设置,进入【Save & Exit Setup】选项,然后按退出,或许直接按住F10,然
后选择YES确定,系统将重新启动。
四、其他总线频率的调节
电脑是一个有机的整体,牵一脉而动全身,在调高FSB的同时,不仅仅只有内存的频率上去了,其他诸
如PCI、Serial ATA、PCI-E和 AGP总线的频率也都上去了,这些总线频率长期运行于高于标准频率的水平
很有可能导致设备的损坏。
一般来说,PCI总线的频率是33.3MHz,AGP总线频率66.6MHz,SATA和PCIE总线频率100MHz。我们来看
看下面的页面,确定你BIOS里面的AGP/PCI频率为66/33MHz。因此,我们在提高FSB的同时,需要把这些总
线的频率锁定在其额定值,不过这对于老式主板需要多多注意了,而现在的主板基本上不存在这些问题,
一般最多需要锁定PCI总线频率,而其他都是自动的,现在基本上所有的主流主板BIOS均支持总线频率调节
。
● 注意:HyperTransport总线的设置
针对AMD Socket 754/939平台中的NVIDIA芯片组,还有一个重要的参数那就是HTT总线频率,如果
HyperTransport频率为1000MHz,那它的默认系数关系为5x,800MHz默认系数关系为4x。HTT总线能运行在
从200到1000 MHz的频率下。实际上,根据主板,或者可以说是市面上芯片组的不同,它的额定HTT总线频
率介于600 MHz(Nforce 3 150)和1000MHz(某些VIA芯片组,Nforce 3 250或Nforce 4)之间。它的频率
是FSB与LDT相乘的结果超频的时候可以适当的降低其频率(还可设置为400MHz、600MHz、800MHz)来达到
更高的超频成绩。
HTT的频率对性能影响不是很大,所以无需担心它运行在低于主板原先设定的频率下。因此为了不超
过芯片组支持的频率,可以调整这个系数。在估计处理器的超频潜力时,降低它以获得巨大的可操作空间
。
OK!内存、HTT总线的频率降低了,PCI、AGP的频率也锁定了,内存频率也降低了,我们已经不受有可
能限制处理器超频的因素妨碍了。一旦你找到了一个稳定的超频频率,那可以根据超频的最终FSB重新调节
这些参数,下面就让我们进入那急速体验的超频之旅吧。
五、FSB频率的调节
经过刚才多步的扫进障碍,我们已经不受有可能限制处理器超频的因素妨碍,我们将开始我们提升CPU
频率关键的一节,FSB频率的调节。
首先我们需要进入到BIOS的Advanced Chipset Features菜单中:
有些主板BIOS标注为Frequency/Voltage Control:
EPoX的主板中这一菜单的名称叫POWER BIOS Features:
ASUS的主板中这一菜单的名称叫JumperFree Configuration:
ABIT的主板中这一菜单的名称叫μGuru Utility:
虽然各品牌主板这一项调节的名称不一定相同,但是原理和功能上还是大同小异的。从而在对FSB调
整了一段时间以后,就会到达处理器的界限,这时系统会变得不稳定。至少在这个时候,处理器确实不能
再释放任何潜能了,这个时候我们改怎么处理呢?
六、电压调节
来自PCPOP的干冰水冷
● CPU电压调节
当CPU的频率到达一定的程度不能再提高时,适当的调高CPU的电压可能会使CPU能达到一个更高的频率
。
电压不需要一开始就修改,它需要根据你超频后的实际情况来设定,你要做的第一件事是看初始电压
是否限制了CPU的超频,然后再决定是否增加电压,接下来测试增加的电压它是否便于超频了。重复这些步
骤,你就能够摸索到CPU超频的极限。注意电压一下猛增加得太高,而我们可以一步一步的增加而得到稳定
的电压值。
根据现在主板与CPU的设计,现在我们去超频是完全安全的,并不再象过去那样很轻易产生烧毁的危险
,现在完全没有,我们还可以在BIOS中设定温度保护来保护系统的安全,一般设置BIOS报警温度为65度,
自动关机温度为70度。
一些经验,处理器的内部温度越低于处理器在保持稳定的同时能够达到的最高温度,它的超频潜力就
越高,这就是为什么我们看到许多超级玩家需要使用液氮与干冰保持在零下摄氏度的情况了,这就是为了
得到更高的频率。
● 内存电压调节
海盗船XMS Xpert内存上LED屏幕能显示内存电压信息
当内存不能稳定在某一个频率下或者达到某个延迟参数时,我们也可以对内存进行适当的加压。
华硕主板上的内存电压调节
磐正主板上的内存电压调节
昂达主板上的内存电压调节
一般情况下我们建议内存电压长时间运行不要超过2.8V,但是也有特殊的内存可以运行在3.2V或者更
高的电压下,这要看具体情况而定。
超频是一个细致而漫长的过程,不可能一蹴而就,CPU的极限频率需要在不停的调试和慢慢的摸索中才能得
到。因此我们在超频的时候需要一点一点的提高FSB,保存以后进入Windows系统,用CPU-Z这样的软件来查
看是否频率现在已经真的提高了。
正在认真的进行着3Dmark2005的稳定性测试
然后还要运行运行几个程序,如 Super PI、Prime95、S&M或游戏等等,之类的测试软件来测试超频以
后系统的稳定性。为了确认获得的最大频率,我们建议使用三个免费软件。它们可以量化性能上的得益,
并且可以测试获得的频率是否稳定。
SuperPI 1M:Super π是一款计算圆周率的软件,但它更适合用来测试CPU的稳定性。即使你的系统运
行一天的 Word、Photoshop 都没有问题,而运行Super PI 也不一定能通过。可以说,Super π可以作为
判断CPU稳定性的依据。它是一个非常快的测试,计算PI值的小数点后一百万位数字。它可以迅速检测到由
内存或处理器引起的不稳定问题。但是请注意,超频的处理器成功通过这个SuperPI 1M测试并不表示它就
很稳定了。在这里,它是超频确认的第一个步骤。如果处理器没有通过这个测试,那就要重新向下设定它
的频率了。
SuperPI 32M:同样的软件,但这次pi值的计算结果拥有3千2百万位小数。它是对内存和处理器十分彻
底的测试。如果这个测试成功地完成,那就代表了非常好的稳定性...
StressPrime2004:
StressPrime2004(SP2004)是一位国外电脑高手JohnnyLee做的测试计算机CPU稳定性的软件.软件基于
Prime95(版本:23.8.1)制作而成,测试的理论。效果和Prime95一样,但操作界面比Prime95方便且人性化
。
在测试模式中,这个软件“野蛮”地使用处理器,导致了大量的发热。由于这个原因,它成为一个非
常好的稳定性测试。为了确认超频,要让它运行几个小时。通常3个小时已经足够了,但如果想要百分之百
地确定处理器的稳定性,那就运行24个小时。遇到稳定性问题会弹出出错信息,但也可能发生死机或重启
。
3DMark2001:
3DMark2001比2003和2005能更多的占用处理器资源。理想的情况是循环运行它,持续数小时。为此应
该在模式中设定:在选项中点击Change,并在Benchmark中勾上Loop。它也是检查显卡和处理器完全超频的
系统稳定性的理想测试,同时包括内存。如果3DMark 2001通过,你还可以测试3DMark03和3DMark05,以确
保万无一失。如果这些测试全都通过的话,就可以肯定已经获得了稳定的超频。但SuperPI,Premium 95和
3DMark 2001的组合已经足够了。
如果系统没有出现任何异常,就证明超频成功。还有一个要注意的是CPU的散热问题,一定要保持良好
的散热,防止CPU过热而烧毁别忘了看看CPU温度,一般最好不要让CPU长时间超过60度,虽然没有烧毁的危
险,但是为了保证你系统的稳定运行和数据的保护,我们建议CPU应该工作于60度下。以上的三个条件都达
到以后,我们重启再次进入BIOS,继续调高FSB,如此往复,直到找到能保持系统稳定的极限频率。
在这里我们在推荐一个监控温度的软件,温度的重要性对于超频不言而喻,这是一个非常棒的软件,
通用现在的主流平台:EVEREST Home Edition v2.00
EVEREST 软件下载地址:http://www.ttdown.com/SoftDown_55278.html
如果你使用的是Intel Pentium 4或者是Celeron处理器,可以用ThrottleWatch或RightMark CPU
Clock Utility等工具来检测CPU温度。
RightMark软件下载地址:http://www.ttdown.com/SoftDown_69451.html
超频不一定会提升系统整体性能,当CPU温度超过一定临界值后,系统性能会迅速下降。所以在超频过
程中,掌握好温度是相当重要的。当系统超频出现性能不升反降的时候,ThrottleWatch或RightMark CPU
Clock Utility会向用户反馈相关的信息。
超频不稳定怎么办?
出现这种情况,我们有两种解决方法:
1、增加电压后,改善系统散热。
2、别超那么高。
[email protected]
⑷ JVM内存设置多大合适Xmx和Xmn如何设置
问题:
新上线一个java服务,或者是RPC或者是WEB站点, 内存的设置该怎么设置呢?设置成多大比较合适,既不浪费内存,又不影响性能呢?
分析:
依据的原则是根据Java Performance里面的推荐公式来进行设置。
具体来讲:
Java整个堆大小设置,Xmx 和 Xms设置为老年代存活对象的3-4倍,即FullGC之后的老年代内存占用的3-4倍
永久代 PermSize和MaxPermSize设置为老年代存活对象的1.2-1.5倍。
年轻代Xmn的设置为老年代存活对象的1-1.5倍。
老年代的内存大小设置为老年代存活对象的2-3倍。
BTW:
1、Sun官方建议年轻代的大小为整个堆的3/8左右, 所以按照上述设置的方式,基本符合Sun的建议。
2、堆大小=年轻代大小+年老代大小, 即xmx=xmn+老年代大小 。 Permsize不影响堆大小。
3、为什么要按照上面的来进行设置呢? 没有具体的说明,但应该是根据多种调优之后得出的一个结论。
如何确认老年代存活对象大小?
方式1(推荐/比较稳妥):
JVM参数中添加GC日志,GC日志中会记录每次FullGC之后各代的内存大小,观察老年代GC之后的空间大小。可观察一段时间内(比如2天)的FullGC之后的内存情况,根据多次的FullGC之后的老年代的空间大小数据来预估FullGC之后老年代的存活对象大小(可根据多次FullGC之后的内存大小取平均值)
方式2:(强制触发FullGC, 会影响线上服务,慎用)
方式1的方式比较可行,但需要更改JVM参数,并分析日志。同时,在使用CMS回收器的时候,有可能不能触发FullGC(只发生CMS GC),所以日志中并没有记录FullGC的日志。在分析的时候就比较难处理。
BTW:使用jstat -gcutil工具来看FullGC的时候, CMS GC是会造成2次的FullGC次数增加。 具体可参见之前写的一篇关于jstat使用的文章
所以,有时候需要强制触发一次FullGC,来观察FullGC之后的老年代存活对象大小。
注:强制触发FullGC,会造成线上服务停顿(STW),要谨慎,建议的操作方式为,在强制FullGC前先把服务节点摘除,FullGC之后再将服务挂回可用节点,对外提供服务
在不同时间段触发FullGC,根据多次FullGC之后的老年代内存情况来预估FullGC之后的老年代存活对象大小
如何触发FullGC ?
使用jmap工具可触发FullGC
jmap -mp:live,format=b,file=heap.bin <pid> 将当前的存活对象mp到文件,此时会触发FullGC
jmap -histo:live <pid> 打印每个class的实例数目,内存占用,类全名信息.live子参数加上后,只统计活的对象数量. 此时会触发FullGC
具体操作实例:
以我司的一个RPC服务为例。
BTW:刚上线的新服务,不知道该设置多大的内存的时候,可以先多设置一点内存,然后根据GC之后的情况来进行分析。
初始JVM内存参数设置为: Xmx=2G Xms=2G xmn=1G
使用jstat 查看当前的GC情况。如下图:
YGC平均耗时: 173.825s/15799=11ms
FGC平均耗时:0.817s/41=19.9ms
平均大约10-20s会产生一次YGC
看起来似乎不错,YGC触发的频率不高,FGC的耗时也不高,但这样的内存设置是不是有些浪费呢?
为了快速看数据,我们使用了方式2,产生了几次FullGC,FullGC之后,使用的jmap -heap 来看的当前的堆内存情况(也可以根据GC日志来看)
heap情况如下图:(命令 : jmap -heap <pid>)
上图中的concurrent mark-sweep generation即为老年代的内存描述。
老年代的内存占用为100M左右。 按照整个堆大小是老年代(FullGC)之后的3-4倍计算的话,设置各代的内存情况如下:
Xmx=512m Xms=512m Xmn=128m PermSize=128m 老年代的大小为 (512-128=384m)为老年代存活对象大小的3倍左右
调整之后的,heap情况
GC情况如下:
YGC 差不多在10s左右触发一次。每次YGC平均耗时大约9.41ms。可接受。
FGC平均耗时:0.016s/2=8ms
整体的GC耗时减少。但GC频率比之前的2G时的要多了一些。
注: 看上述GC的时候,发现YGC的次数突然会增多很多个,比如 从1359次到了1364次。具体原因是?
总结:
在内存相对紧张的情况下,可以按照上述的方式来进行内存的调优, 找到一个在GC频率和GC耗时上都可接受的一个内存设置,可以用较小的内存满足当前的服务需要
但当内存相对宽裕的时候,可以相对给服务多增加一点内存,可以减少GC的频率,GC的耗时相应会增加一些。 一般要求低延时的可以考虑多设置一点内存, 对延时要求不高的,可以按照上述方式设置较小内存。
补充:
永久代(方法区)并不在堆内,所以之前有看过一篇文章中描述的 整个堆大小=年轻代+年老代+永久代的描述是不正确的。
转自:
https://blog.csdn.net/losetowin/article/details/78569001
-verbose:gc 现实垃圾收集信息
-Xloggc:gc.log 指定垃圾收集日志文件
-Xmn:young generation的heap大小,一般设置为Xmx的3、4分之一
-XX:SurvivorRatio=2 :生还者池的大小,默认是2,如果垃圾回收变成了瓶颈,您可以尝试定制生成池设置
-XX:NewSize: 新生成的池的初始大小。 缺省值为2M。
-XX:MaxNewSize: 新生成的池的最大大小。 缺省值为32M。
+XX:AggressiveHeap 会使得 Xms没有意义。这个参数让jvm忽略Xmx参数,疯狂地吃完一个G物理内存,再吃尽一个G的swap。
-Xss:每个线程的Stack大小,“-Xss 15120” 这使得JBoss每增加一个线程(thread)就会立即消耗15M内存,而最佳值应该是128K,默认值好像是512k.
⑸ 在电脑主板上打开XMS,XMS是什么意思
XMS是扩展内存 寻址在1MB之后的内存称“扩展内存”,一般程序不能直接使用扩展内存。扩展内存的使用要用XMS(Extended Memory Specification)规范提供支持,所以,扩展内存有时也简称XMS。Microsoft的HIMEM.SYS是一个符合XMS规范的扩展内存管理程序,因而,在使用扩展内存前应首先在CONFIG.SYS中加入安装HIMEM.SYS的命令。
⑹ 启动JAVA程序时,参数-Xms及Xmx有什么用
-Xms是用来设置你的应用程序能够使用的最大内存数,如果程序要花很大内存的话,那就需要修改增加此数的值。
Xms是用它来设置程序初始化的时候内存栈的大小,增加这个值的话你的程序的启动性能会得到提高。
所以根据程序的大小,还有电脑的实际配置,来进行这两个的参数配置即可,参数的单位都是m(兆)。
Java简介
Java是一种可以撰写跨平台应用软件的面向对象的程序设计语言。Java 技术具有卓越的通用性、高效性、平台移植性和安全性,广泛应用于PC、数据中心、游戏控制台、科学超级计算机、移动电话和互联网,同时拥有全球最大的开发者专业社群。
主要组成
Java由四方面组成:
●Java编程语言,即语法。
●Java文件格式,即各种文件夹、文件的后缀。
●Java虚拟机(JVM),即处理*.class文件的解释器。
●Java应用程序接口(Java API)。
体系
Java分为三个体系,分别为:
Java SE(J2SE,Java2 Platform Standard Edition,标准版),
JavaEE(J2EE,Java 2 Platform, Enterprise Edition,企业版),
Java ME(J2ME,Java 2 Platform Micro Edition,微型版)。