weblogic 性能调优,提升程序响应效率
Posted supingemail
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了weblogic 性能调优,提升程序响应效率相关的知识,希望对你有一定的参考价值。
好记忆不如烂笔头,能记下点东西,就记下点,有时间拿出来看看,也会发觉不一样的感受.
目录
一、前奏
weblogic 是oracle的一款很nice的web容器;能够将打包好的war文件管理并运行起来,而且作为一个web容器,本身也具有很强大的管理能力,在使用的时候,还是需要在默认值的基础之上进行修改和调整的,以便达到最优的使用原则。
虽说oracle已经退出了中国市场,并且现在已经是以springcloud为天下的微服务时代,单仍然有很多应用更加适合使用像weblogic这样的容器来启动、运行、管理。
二、优化一、weblogic启动配置文件
weblogic的启动配置文件,主要是指setDomainEnv.sh
在这个文件中,需要指定jvm的地址,堆栈内存大小;也可以手动分配年轻代,老年代的占用比例等等,需要在文件中查找到 WLS_MEM_ARGS_64BIT ,并给这个值设置相应的参数即可。例如:
-Xms12288m -Xmx12288m -Xmn4608m -XX:NewRatio=4 -XX:SurvivorRatio=8 -XX:MaxPermSize=1024M -XX:PermSize=512M -XX:+UseG1GC -XX:MaxGCPauseMillis=100 -XX:+ParallelRefProcEnabled -XX:HeapDumpPath=logs -XX:+PrintGCDetails -XX:+PrintGCDateStamps -verbose:class -XX:+HeapDumpOnOutOfMemoryError -XX:+PrintClassHistogramBeforeFullGC -XX:+PrintClassHistogramAfterFullGC -XX:+PrintCommandLineFlags -XX:+PrintGCApplicationConcurrentTime -XX:+PrintGCApplicationStoppedTime -XX:+PrintTenuringDistribution -XX:+PrintHeapAtGC
参数解析:
-Xmx12288m:堆内存最大值为12GB。
-Xms12288m:初始化堆内存大小为12GB 。
-Xmn4608m:设置年轻代大小为4608MB。增大年轻代后,将会减小年老代大小。此值对系统性能影响较大,Sun官方推荐配置为整个堆的3/8。
-Xss2048k:设置每个线程的堆栈大小。JDK5.0以后每个线程堆栈大小为1MB,以前每个线程堆栈大小为256K。应根据应用线程所需内存大小进行调整。在相同物理内存下,减小这个值能生成更多的线程。但是操作系统对一个进程内的线程数还是有限制的,不能无限生成,经验值在3000~5000左右。
-XX:NewRatio=4:设置年轻代(包括Eden和两个Survivor区)与年老代的比值(除去持久代)。设置为4,则年轻代与年老代所占比值为1:4,年轻代占整个堆栈的1/5
-XX:SurvivorRatio=8:设置年轻代中Eden区与Survivor区的大小比值。设置为8,则两个Survivor区与一个Eden区的比值为2:8,一个Survivor区占整个年轻代的1/10
-XX:PermSize=512m:初始化永久代大小为100MB。
-XX:MaxPermSize=1024m:设置持久代大小为256MB。
-XX:MaxTenuringThreshold=15:设置垃圾最大年龄。如果设置为0的话,则年轻代对象不经过Survivor区,直接进入年老代。对于年老代比较多的应用,可以提高效率。如果将此值设置为一个较大值,则年轻代对象会在Survivor区进行多次复制,这样可以增加对象再年轻代的存活时间,增加在年轻代即被回收的概论。
以上参数,都需要根据实际情况进行删减和修改。
WLS_MEM_ARGS_64BIT 的赋值,也需要根据实际情况,判断是hotspot还是其他,是32位还是64位的,都需要根据实际情况来赋值。
三、优化二、weblogic管理界面修改
weblogic管理界面的修改,主要是在weblogic的 环境——>服务器——> 来到adminServer的管理页面——>点击“优化” ,修改几个参数的值:最大线程等待时间,最大线程数和最小线程数,接收请求积压数等。具体如下图:
四、其他修改
其他修改一般都是指程序方面的优化,比如文件下载:可以采用nio管道的方式,实现文件的下载 ,例如:
public static void downloadFile(File file, HttpServletResponse response)
OutputStream os = null;
try
// 取得输出流
os = response.getOutputStream();
String contentType = Files.probeContentType(Paths.get(file.getAbsolutePath()));
response.setHeader("Content-Type", contentType);
response.setHeader("Content-Disposition", "attachment;filename="+ new String(file.getName().getBytes("utf-8"),"ISO8859-1"));
FileInputStream fileInputStream = new FileInputStream(file);
WritableByteChannel writableByteChannel = Channels.newChannel(os);
FileChannel fileChannel = fileInputStream.getChannel();
fileChannel.transferTo(0,fileChannel.size(),writableByteChannel);
fileChannel.close();
os.flush();
writableByteChannel.close();
catch (IOException e)
logger.error("文件下载出错,错误信息是:",e.getMessage());
//文件的关闭放在finally中
finally
try
if (os != null)
os.close();
catch (IOException e)
logger.error("关闭流信息出错,错误信息是:",e.getMessage());
当然还有其他方面的优化,比如设计,存储,访问方式,linux 的最大文件个数,日志文件输出等等。
以上是关于weblogic 性能调优,提升程序响应效率的主要内容,如果未能解决你的问题,请参考以下文章