• SpringBoot项目配置Tomcat和JVM参数


    设置Tomcat端口号和连接数等

    使用application.properties配置文件有一些参数无法设置,所以推荐创建一个类文件来配置,如下:

    package com.qipai.springbean;
    
    import org.apache.catalina.connector.Connector;
    import org.apache.coyote.http11.Http11NioProtocol;
    import org.springframework.boot.context.embedded.EmbeddedServletContainer;
    import org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedServletContainerFactory;
    import org.springframework.boot.web.servlet.ServletContextInitializer;
    import org.springframework.stereotype.Component;
    
    /**
     * Created by weiqingming on 2017/12/7.
     */
    @Component
    public class TomcatConfig extends TomcatEmbeddedServletContainerFactory
    {
        public EmbeddedServletContainer getEmbeddedServletContainer(ServletContextInitializer... initializers)
        {
            //设置端口
            this.setPort(8081);
            return super.getEmbeddedServletContainer(initializers);
        }
    
        protected void customizeConnector(Connector connector)
        {
            super.customizeConnector(connector);
            Http11NioProtocol protocol = (Http11NioProtocol)connector.getProtocolHandler();
            //设置最大连接数
            protocol.setMaxConnections(200);
            //设置最大线程数
            protocol.setMaxThreads(300);
            //连接超时时间
            protocol.setConnectionTimeout(10000);
        }
    }

     

    也可以使用application.properties配置文件来配置,如下,但是没有连接超时时间的配置。

    #端口号
    server.port=8081
    #最大连接数
    server.tomcat.max-connections=200
    #最大线程数
    server.tomcat.max-threads=300
    #编码方式
    server.tomcat.uri-encoding=UTF-8
    #post提交数据最大大小,设置为0不限制
    server.tomcat.max-http-post-size=0

     

     

    运行时设置JVM参数

    先使用Maven打包成jar文件

    cd /项目路径
    
    mvn clean package

     

    使用默认JVM配置运行

    #前台运行,关闭窗口后退出
    java -jar /jar包路径
    
    #后台运行
    nohup java -jar /jar包路径
    
    #后台运行,指定启动日志记录文件
    nohub java -jar /jar包路径 > /指定日志文件路径

     

    配置JVM参数运行

    #前台运行
    java -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=128m -Xms1024m -Xmx1024m -Xmn256m -Xss256k -XX:SurvivorRatio=8 -XX:+UseConcMarkSweepGC -jar /jar包路径 
    
    nohup java -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=128m -Xms1024m -Xmx1024m -Xmn256m -Xss256k -XX:SurvivorRatio=8 -XX:+UseConcMarkSweepGC -jar /jar包路径 

    参数说明:

    -XX:MetaspaceSize=128m (元空间默认大小)

    -XX:MaxMetaspaceSize=128m (元空间最大大小)

    -Xms1024m (堆最大大小)

    -Xmx1024m (堆默认大小)

    -Xmn256m (新生代大小)

    -Xss256k (棧最大深度大小)

    -XX:SurvivorRatio=8 (新生代分区比例 8:2)

    -XX:+UseConcMarkSweepGC (指定使用的垃圾收集器,这里使用CMS收集器)

     

    知识点:JDK8之后把-XX:PermSize 和 -XX:MaxPermGen移除了,取而代之的是

    -XX:MetaspaceSize=128m (元空间默认大小)

    -XX:MaxMetaspaceSize=128m (元空间最大大小)

    JDK 8开始把类的元数据放到本地化的堆内存(native heap)中,这一块区域就叫Metaspace,中文名叫元空间。

    使用本地化的内存有什么好处呢?最直接的表现就是java.lang.OutOfMemoryError: PermGen 空间问题将不复存在,因为默认的类的元数据分配只受本地内存大小的限制,也就是说本地内存剩余多少,理论上Metaspace就可以有多大(貌似容量还与操作系统的虚拟内存有关?这里不太清楚),这解决了空间不足的问题。不过,让Metaspace变得无限大显然是不现实的,因此我们也要限制Metaspace的大小:使用-XX:MaxMetaspaceSize参数来指定Metaspace区域的大小。JVM默认在运行时根据需要动态地设置MaxMetaspaceSize的大小。

  • 相关阅读:
    微信用户授权,获取code
    关于swiper在vue中不生效的问题
    ES6-Set 和 Map 数据结构
    Js中caller和callee的区别
    类与对象基础总结--继承,多态
    java 类与对象基础整理
    java 的数据库操作--JDBC
    Socket的长连接和短连接
    java 的底层通信--Socket
    算法--树与递归
  • 原文地址:https://www.cnblogs.com/telwanggs/p/15099195.html
Copyright © 2020-2023  润新知