JAVA服务器搭建之问题总结

摘要:
负责维护公司产品的web服务器搭建与维护,最近遇到一下状况,今天在这里简单总结一下,希望对于刚刚一些刚入行的小伙伴有所帮助,避免再走弯路。对于以上两个问题,我的处理是:在catalina.bat的第一行增加:Java代码:setJAVA_OPTS=-Xms64m-Xmx256m-XX:PermSize=128M-XX:MaxNewSize=256m-XX:MaxPermSize=256m在catalina.sh的第一行增加:Java代码:JAVA_OPTS=-Xms64m-Xmx256m-XX:PermSize=128M-XX:MaxNewSize=256m-XX:MaxPermSize=256m第二点:服务器内存使用率经常达到90%以上这是我感觉最可怕的,因为在程序上找不到问题,这种问题的出现多半是因为服务器的配置过低,并且Tomcat下的服务过多,最终导致服务器压力过大罢工。

负责维护公司产品的web服务器搭建与维护,最近遇到一下状况,今天在这里简单总结一下,希望对于刚刚一些刚入行的小伙伴有所帮助,避免再走弯路。

第一点:Tomcat内存设置:

一、常见的Java内存溢出有以下三种:

1.java.lang.OutOfMemoryError: Java heap space----JVM Heap(堆)溢出
JVM在启动的时候会自动设置JVM Heap的值,其初始空间(即-Xms)是物理内存的1/64,最大空间(-Xmx)不可超过物理内存。

可以利用JVM提供的-Xmn -Xms -Xmx等选项可进行设置。Heap的大小是Young Generation 和Tenured Generaion 之和。

在JVM中如果98%的时间是用于GC,且可用的Heap size 不足2%的时候将抛出此异常信息。

解决方法:手动设置JVM Heap(堆)的大小。

2.java.lang.OutOfMemoryError: PermGen space----PermGen space溢出。
PermGen space的全称是Permanent Generation space,是指内存的永久保存区域。

为什么会内存溢出,这是由于这块内存主要是被JVM存放Class和Meta信息的,Class在被Load的时候被放入PermGen space区域,它和存放Instance的Heap区域不同,sun的 GC不会在主程序运行期对PermGen space进行清理,所以如果你的APP会载入很多CLASS的话,就很可能出现PermGen space溢出。

解决方法: 手动设置MaxPermSize大小

3.java.lang.StackOverflowError---- 栈溢出
栈溢出了,JVM依然是采用栈式的虚拟机,这个和C和Pascal都是一样的。函数的调用过程都体现在堆栈和退栈上了。
调用构造函数的 “层”太多了,以致于把栈区溢出了。
通常来讲,一般栈区远远小于堆区的,因为函数调用过程往往不会多于上千层,而即便每个函数调用需要 1K的空间(这个大约相当于在一个C函数内声明了256个int类型的变量),那么栈区也不过是需要1MB的空间。通常栈的大小是1-2MB的。
通常递归也不要递归的层次过多,很容易溢出。

解决方法:修改程序。

设置Tomcat启动的初始内存其初始空间(即-Xms)是物理内存的1/64,最大空间(-Xmx)是物理内存的1/4。

可以利用JVM提供的-Xmn -Xms -Xmx等选项可进行设置

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 omcat.exe.他读取注册表中的值,而不是catalina.bat的设置.

解决办法:

修改注册表HKEY_LOCAL_MACHINESOFTWAREApache Software FoundationTomcat Service ManagerTomcat5ParametersJavaOptions

原值为-Dcatalina.home="C:ApacheGroupTomcat 5.0"-Djava.endorsed.dirs="C:ApacheGroupTomcat 5.0commonendorsed"-Xrs加入 -Xms300m -Xmx350m

重起tomcat服务,设置生效

分析java.lang.OutOfMemoryError: PermGen space 发现很多人把问题归因于: spring,hibernate,tomcat,因为他们动态产生类,导致JVM中的permanent heap溢出 。然后解决方法众说纷纭,有人说升级 tomcat版本到最新甚至干脆不用tomcat。还有人怀疑spring的问题,在spring论坛上讨论很激烈,因为spring在AOP时使用CBLIB会动态产生很多类。 但问题是为什么这些王牌的开源会出现同一个问题呢,那么是不是更基础的原因呢?tomcat在Q&A很隐晦的回答了这一点,我们知道这个问题,但这个问题是由一个更基础的问题产生。 于是有人对更基础的JVM做了检查,发现了问题的关键。原来SUN 的JVM把内存分了不同的区,其中一个就是permenter区用来存放用得非常多的类和类描述。本来SUN设计的时候认为这个区域在JVM启动的时候就固定了,但他没有想到现在动态会用得这么广泛。而且这个区域有特殊的垃圾收回机制,现在的问题是动态加载类到这个区域后,gc根本没办法回收!

对于以上两个问题,我的处理是:

在catalina.bat的第一行增加:

Java代码 :set JAVA_OPTS=-Xms64m -Xmx256m -XX:PermSize=128M -XX:MaxNewSize=256m -XX:MaxPermSize=256m  

在catalina.sh的第一行增加:

Java代码 :JAVA_OPTS=-Xms64m -Xmx256m -XX:PermSize=128M -XX:MaxNewSize=256m -XX:MaxPermSize=256m

第二点:服务器内存使用率经常达到90%以上

这是我感觉最可怕的,因为在程序上找不到问题,这种问题的出现多半是因为服务器的配置过低,并且Tomcat下的服务过多,最终导致服务器压力过大罢工。

对于这种问题我的解决方案是:1、申请提高服务器配置;2、将Tomcat下的服务分开放置于不同的服务器上;3、增加服务器的虚拟内存大小

对于前两种方案,我想大家一听就会,我们重点说一下,如何手动增加服务器的虚拟内存大小:

我的电脑-->右键点击选择属性-->高级系统设置-->性能选项-->高级-->虚拟内存-->更改(具体流程见下图)

JAVA服务器搭建之问题总结第1张

JAVA服务器搭建之问题总结第2张

JAVA服务器搭建之问题总结第3张

需要注意的是,当我们第一次设置虚拟内存大小时,点击确定按钮就可以设置成功,当我们第二次设置时,如果设置的比之前的小,点击确定,系统会提示我们重启计算机,如果我们设置的比之前的大,那就和第一次设置时一致,当我们点击确定即可完成设置。

第三点:服务器内存使用率不间断的突然达到99%

对于这个问题,我也是刚遇到的,发现暂用内存较大的是一个名为sychost.exe的服务,经过在度娘上的搜索,这个应该是windows的升级服务,但是我们不能盲目的将其关闭,因为我们如果直接将其关闭,可能会引起蓝屏。这里我给大家讲解一种方式:开始-->所有程序-->管理工具-->服务

JAVA服务器搭建之问题总结第4张  

将这个Windows Update的服务设置为手动即可。

好了,到这里关于服务搭建的总结,就简单叙述完了,如有不当的地方还望指点一二。谢谢

免责声明:文章转载自《JAVA服务器搭建之问题总结》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇如何反馈问题issue?Java准确地获取本地IP地址下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Linux、Windows如何进行性能监控与调优

【本文版权归微信公众号"代码艺术"(ID:onblog)所有,若是转载请务必保留本段原创声明,违者必究。若是文章有不足之处,欢迎关注微信公众号私信与我进行交流!】 1.Linux命令行工具 推荐:CentOS 7 1.1 top命令 top命令的输出如下: top命令的输出可以分为两部分:前半部分是系统统计信息,后半部分是进程信息。在统计信息中, 第1行...

XP 任务管理器——性能 中 各项的意思

XP  任务管理器——性能 中 各项的意思     1、物理内存——系统缓存 是指什么?是硬盘上的 虚拟内存 么?2、内存使用——总数、限制、峰值 都是指什么?3、核心内存 是指什么呢?   一个高手给我的回复:   物理内存:计算机上安装的总物理内存,也称RAM,“可用数”物理内存中可被程序使用的空余量。但实际的空余量要比这个数值略大一点,因为物理内存...

centos6 free 和 centos 7的free 的差异与对比

以下内容大多数是转载 在centos6中: 查看内存是这样的: [root@ ~]# free -h  #人性化输出显示total used free shared buffers cachedMem: 996M 521M 474M 56K 35M 118M-/+ buffers/cache: 368M 628MSwap: 1.5G 234M 1.2G t...

java.lang.OutOfMemoryError: unable to create new native thread问题排查以及当前系统最大进程数量

1. 问题描述 线上某应用出问题,查看日志 这一组服务器是2台,每台都有。配置为64G,使用7G,空余内存非常多 2. 问题排查 环境变化:程序迁移到新机器,新机器是CentOS 7,程序运行账号由原来的root改为work。硬件配置由32G升级为64G。首先切换到work账号,然后运行一个测试程序就是建立线程,发现只能跑2900多个,我的笔记本还能跑2...

深入了解Windows句柄到底是什么(句柄是逻辑指针,或者是指向结构体的指针,图文并茂,非常清楚)good

总是有新入门的Windows程序员问我Windows的句柄到底是什么,我说你把它看做一种类似指针的标识就行了,但是显然这一答案不能让他们满意,然后我说去问问度娘吧,他们说不行网上的说法太多还难以理解。今天比较闲,我上网查了查,光是百度百科词条“句柄”中就有好几种说法,很多叙述还是错误的,天知道这些误人子弟的人是想干什么。 这里我列举词条中的关于句柄的叙述不...

tomcat优化

tomcat的内存使用配置,最大连接数配置。 如何修改配置呢,在/tomcat的/bin/下面有个脚本文件catailna.sh。 如果 windows 是bat设置tomcat的使用内存,其实就是设置jvm的使用参数。 一.Tomcat内存优化 Tomcat内存优化主要是对 tomcat 启动参数优化,我们可以在 tomcat 的启动脚本 catalin...