如何以最小的内存运行spring boot fat jar?

时间:2015-10-05 06:12:04

标签: java spring spring-mvc spring-boot apache-camel

这是我们的maven MediSpan 项目。实际上它是REST网络服务。其返回JSON药物药物相互作用对象通过 GPI 代码查询指定患者。以下是休息查询的示例:

http://localhost:8017/mspn/query?pid=1000&
gpis=83-20-00-30-20-03-10&gpis=64-99-10-02-12-03-20

以下是我们项目的结构:

/opt/java/spring/boot/fat/jar/project/chorke─mspn─server/
    ├─ MediSpan.Documents.Monograph.css                   [     1,697 Byte]
    ├─ MediSpan.Documents.Monograph.xslt                  [    35,167 Byte]
    ├─ bitronix-tx-mgr-log-001                            [ 2,097,173 Byte]
    ├─ bitronix-tx-mgr-log-002                            [ 2,097,173 Byte]
    └─ chorke─mspn─server.jar!                            [26,022,610 Byte]
        ├─ medispan/                                      [   443,756 Byte]
        ├─ META-INF/                                      [    33,702 Byte]
        ├─ org/springframework/boot/loader/               [   165,003 Byte]
        ├─ com/chorke/                                    [    27,633 Byte]
        ├─ application.properties                         [       501 Byte]
        ├─ application.yml                                [     2,234 Byte]
        ├─ MediSpan.Foundation.Config.xml                 [    14,939 Byte]
        ├─ MediSpan.Foundation.Text.xml                   [     9,003 Byte]
        ├─ log4j.xml                                      [     2,254 Byte]
        └─ lib/                                           [25,688,056 Byte]
            ├─ aopalliance-1.0.jar
            ├─ btm-2.1.4.jar
            ├─ c3p0-0.9.1.2.jar
            ├─ camel-core-2.15.2.jar
            ├─ camel-jasypt-2.15.2.jar
            ├─ camel-quartz2-2.15.2.jar
            ├─ camel-spring-2.15.2.jar
            ├─ camel-spring-javaconfig-2.15.2.jar
            ├─ chorke-comn-spring-2.0.00-SNAPSHOT.jar     [    11,698 Byte]
            ├─ chorke-mspn-entity-2.0.00-SNAPSHOT.jar     [    13,486 Byte]
            ├─ chorke-mspn-parser-2.0.00-SNAPSHOT.jar     [    15,921 Byte]
            ├─ chorke-mspn-persis-2.0.00-SNAPSHOT.jar     [    23,328 Byte]
            ├─ chorke-mspn-utlity-2.0.00-SNAPSHOT.jar     [    25,684 Byte]
            ├─ commons-lang3-3.3.2.jar
            ├─ commons-logging-1.1.1.jar
            ├─ ehcache-core-2.6.11.jar
            ├─ jackson-annotations-2.4.6.jar
            ├─ jackson-core-2.4.6.jar
            ├─ jackson-databind-2.4.6.jar
            ├─ jasypt-1.9.2.jar
            ├─ javax.transaction-api-1.2.jar
            ├─ jaxb-core-2.2.11.jar
            ├─ jaxb-impl-2.2.11.jar
            ├─ log4j-1.2.17.jar
            ├─ medispan-business-5.1.10.jar
            ├─ medispan-concepts-5.1.10.jar
            ├─ medispan-conditions-5.1.10.jar
            ├─ medispan-documents-5.1.10.jar
            ├─ medispan-interactions-5.1.10.jar
            ├─ medispan-screening-5.1.10.jar
            ├─ medispan-utility-5.1.10.jar
            ├─ mybatis-3.2.8.jar
            ├─ mybatis-ehcache-1.0.2.jar
            ├─ mybatis-spring-1.2.2.jar
            ├─ ojdbc6-11.2.0.3.jar
            ├─ org.apache.servicemix.bundles.cglib-2.1_3_7.jar
            ├─ quartz-2.2.1.jar
            ├─ slf4j-api-1.7.12.jar
            ├─ slf4j-log4j12-1.7.12.jar
            ├─ snakeyaml-1.14.jar
            ├─ spring-aop-4.1.6.RELEASE.jar
            ├─ spring-beans-4.1.6.RELEASE.jar
            ├─ spring-boot-1.2.4.RELEASE.jar
            ├─ spring-boot-actuator-1.2.4.RELEASE.jar
            ├─ spring-boot-autoconfigure-1.2.4.RELEASE.jar
            ├─ spring-boot-starter-1.2.4.RELEASE.jar
            ├─ spring-boot-starter-actuator-1.2.4.RELEASE.jar
            ├─ spring-boot-starter-tomcat-1.2.4.RELEASE.jar
            ├─ spring-context-4.1.6.RELEASE.jar
            ├─ spring-context-support-4.1.6.RELEASE.jar
            ├─ spring-core-4.1.6.RELEASE.jar
            ├─ spring-expression-4.1.6.RELEASE.jar
            ├─ spring-jdbc-4.1.6.RELEASE.jar
            ├─ spring-jms-4.1.6.RELEASE.jar
            ├─ spring-messaging-4.1.6.RELEASE.jar
            ├─ spring-tx-4.1.6.RELEASE.jar
            ├─ spring-web-4.1.6.RELEASE.jar
            ├─ spring-webmvc-4.1.6.RELEASE.jar
            ├─ tomcat-embed-core-8.0.23.jar
            ├─ tomcat-embed-el-8.0.23.jar
            ├─ tomcat-embed-logging-juli-8.0.23.jar
            └─ tomcat-embed-websocket-8.0.23.jar

这是运行这个胖jar项目及其矩阵的命令:

# without setting java option
java -jar chorke-mspn-server.jar

在41.824秒内启动BootstrapApplication(JVM运行42.807)

  • 使用的内存: 532,858千字节
  • 承诺: 751,616千字节
  • 最高: 1,847,808千字节
  • 已加载9502个课程

工作正常。

# setting java option for 1024 MB
java -Xmx1024M -XX:MaxPermSize=768M -XX:+CMSClassUnloadingEnabled \
-jar chorke-mspn-server.jar

在42.134秒内启动BootstrapApplication(JVM运行43.084)

  • 使用的内存: 160,016千字节
  • 承诺: 422,912千字节
  • 最大: 932,352千字节
  • 已加载9505个课程

工作正常。

# setting java option for 512 MB
java -Xmx512M -XX:MaxPermSize=384M -XX:+CMSClassUnloadingEnabled \
-jar chorke-mspn-server.jar

在42.385秒内启动BootstrapApplication(JVM运行43.358)

  • 使用的内存: 244,280千字节
  • 承诺: 463,360千字节
  • 最大: 465,920千字节
  • 已加载9503个课程

工作正常。

# setting java option for 256 MB
java -Xmx256M -XX:MaxPermSize=192M -XX:+CMSClassUnloadingEnabled \
-jar chorke-mspn-server.jar

在42.202秒内启动BootstrapApplication(JVM运行43.174)

  • 使用的内存: 244,280千字节
  • 承诺: 463,360千字节
  • 最大: 465,920千字节
  • 已加载9503个课程

抛出异常[处理程序处理失败;嵌套异常是java.lang.OutOfMemoryError:超出GC开销限制],具有根本原因

java.lang.OutOfMemoryError: GC overhead limit exceeded
        at java.lang.Integer.valueOf(Integer.java:642)
        at medispan.foundation.convert.ValueType.asValue(Unknown Source)
        at medispan.foundation.dataaccess.providers.sql.SQLProvider.executeForResults(Unknown Source)
        at medispan.foundation.dataaccess.providers.sql.SQLDataAccessProvider.innerExecuteForCollection(Unknown Source)
        at medispan.foundation.dataaccess.DataAccessProvider.executeForCollection(Unknown Source)
        at medispan.business.dataaccess.BusinessDataAccessManager.load(Unknown Source)
        at medispan.business.dataaccess.QueryPropertyValues.getPropertyValue(Unknown Source)
        at medispan.business.dataaccess.QueryPropertyValues.getInnerValue(Unknown Source)
        more..

此应用程序包含嵌入式tomcat服务器 spring boot spring mvc myBatis apache-camel bitronix事务管理器 medispan 。我们希望在 32~128 MB内存上运行它。你能不能建议我们以最佳/最少的内存使用量来运行这个应用程序?

1 个答案:

答案 0 :(得分:1)

你需要运行像JProfile或VisualVM这样的Profiler才能看到什么是cosuming memory。

我可以直接告诉你,你永远不会得到32MB的所有那些额外的库。单独的Apache Camel可能需要至少256MB才能可靠地运行。并且Apache Camel不应该嵌入微服务中。这是您的服务应该在外部调用的服务。使用JPA或几乎任何缓存都会使内存使用率很低。

我确实在Spring Boot中有一些高容量的微服务,运行时只有32MB - 64MB,但它们基本上只是放置和计算。所有这些额外的库和服务将大大扩展您的内存使用。