weblogic 性能调优,提升程序响应效率

Posted supingemail

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了weblogic 性能调优,提升程序响应效率相关的知识,希望对你有一定的参考价值。

好记忆不如烂笔头,能记下点东西,就记下点,有时间拿出来看看,也会发觉不一样的感受.

目录

一、前奏

二、优化一、weblogic启动配置文件

三、优化二、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 性能调优,提升程序响应效率的主要内容,如果未能解决你的问题,请参考以下文章

weblogic 性能调优,提升程序响应效率

网络性能总不好?专家帮你来“看看”——昇腾AI黑科技 | 网络调优专家AOE,性能效率双提升

BI用户福利 | 免费性能调优,提升企业数据分析效率!

Spark 性能调优零散知识

网络性能总不好?网络调优专家AOE帮你来“看看”

网络性能总不好?网络调优专家AOE帮你来“看看”