Spring启动内存利用率

时间:2014-06-09 21:34:14

标签: java spring spring-boot

我们有一个基于Spring Boot的应用程序。我们使用大约20Meg的可执行jar来部署它。当我们启动这个应用程序时,它会立即使用18Gigs的“Virutual”内存。据我所知,其中大部分存储在硬盘等二级存储中,但我们的系统管理员质疑为什么我们需要这么多的虚拟内存。

Jar文件很小。在启动时我正在使用BoneCPDataSource,但我已将连接数减少到5.一旦应用程序启动,它就会使用18g的虚拟内存。

有人可以告诉我为什么吗?我应该在命令行上使用java内存设置来减少这个数字吗?我们使用的命令是:

java -jar filename.jar

根据要求,这里有更多信息:

1)这是'top'命令中的一行:

24511 xyz 20 0 17.6g 531m 9.8m S 0.0 0.8 0:16.57 java

2)没有Neo4J。这是我的pom.xml

http://maven.apache.org/xsd/maven-4.0.0.xsd">     4.0.0

<groupId>com.xyz.myapp</groupId>
<artifactId>myapp-rest-service</artifactId>
<version>0.1.0</version>

<properties>
    <start-class>com.xyz.myapp.rest.Application</start-class>
</properties>

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.0.1.RELEASE</version>
</parent>

<dependencies>
    <dependency>
        <groupId>com.jolbox</groupId>
        <artifactId>bonecp</artifactId>
        <version>0.8.0.RELEASE</version>
        <exclusions>
            <exclusion>
                <groupId>com.jolbox</groupId>
                <artifactId>com.jolbox.logging</artifactId>
            </exclusion>
        </exclusions>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-databind</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-jdbc</artifactId>
        <version>4.0.3.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-tx</artifactId>
        <version>4.0.3.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-api</artifactId>
        <version>2.0-rc1</version>
    </dependency>
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-core</artifactId>
        <version>2.0-rc1</version>
    </dependency>
    <dependency>
        <groupId>oracle</groupId>
        <artifactId>jdbc</artifactId>
        <version>6.0</version>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-security</artifactId>
    </dependency>
    <dependency>
        <groupId>com.sun.jersey</groupId>
        <artifactId>jersey-bundle</artifactId>
        <version>1.18.1</version>
    </dependency>
</dependencies>

<build>
    <plugins>
        <plugin> 
            <artifactId>maven-compiler-plugin</artifactId> 
            <version>2.3.2</version> 
        </plugin>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
    </plugins>
</build>

<repositories>
    <repository>
        <id>spring-snapshots</id>
        <url>http://repo.spring.io/libs-snapshot</url>
        <snapshots><enabled>true</enabled></snapshots>
    </repository>
</repositories>

<pluginRepositories>
    <pluginRepository>
        <id>spring-snapshots</id>
        <url>http://repo.spring.io/libs-snapshot</url>
        <snapshots><enabled>true</enabled></snapshots>
    </pluginRepository>
</pluginRepositories>

3)我使用以下命令构建此应用程序:

mvn clean package

这就是它在./target目录中创建的内容:

-rwxr-xr-x 1 myuserid Domain Users 20259555 Jun 9 15:36 myapp-rest-service-0.1.0.jar

4)为我的应用输出lsof:

http://pastebin.com/V00BrD67

5)mvn依赖的输出:树

http://pastebin.com/cFnR0NMX

2 个答案:

答案 0 :(得分:6)

指定-Xmx选项后,虚拟内存消耗量下降。目前,我正在启动我的Spring Boot应用程序:

java -Xmx4096m -jar myapp-rest-service-0.1.0.jar

如果有更好的方法在application.properties文件(或其他地方)设置此值,请告诉我。

答案 1 :(得分:4)

JVM根据可用的物理内存(通常是可用系统内存的百分比)使用默认堆大小。该值还取决于JVM版本和客户端/服务器模式。

您可以使用以下关键字找到有关此主题的更多信息:“默认Java堆配置”

这个SO答案解决了同一主题(Jabir的回答): What is the default maximum heap size for Sun's JVM from Java SE 6?

HTH