我的问题对我来说很复杂。我正在为一个游戏运行一个服务器,我在正确设置内存的java设置时遇到了一些问题。
我运行的Ubuntu12.10 64位,32 gb的内存。
java任务应该占用20 gb的实际内存。它没有这样做,而是一直使用虚拟内存。
top - 19:51:44 up 15 min, 1 user, load average: 0.29, 0.30, 0.19
Tasks: 120 total, 2 running, 118 sleeping, 0 stopped, 0 zombie
Cpu(s): 0.9%us, 0.3%sy, 0.0%ni, 98.5%id, 0.2%wa, 0.0%hi, 0.0%si, 0.0%st
Mem: 32809368k total, 2237888k used, 30571480k free, 28092k buffers
Swap: 16776116k total, 0k used, 16776116k free, 411660k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
1876 test 20 0 46.1g 1.2g 15m S 8 3.7 1:37.17 java目前,我使用以下命令运行它: MAVEN_OPTS="-Xnoagent -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=8000 -Xmx20480M“屏幕-S Test -d -m mvn -o tomcat7 7:run
我还尝试将其添加到pom.xml (构建选择):
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>exec-maven-plugin</artifactId>
<version>1.2.1</version>
<executions>
<execution>
<goals>
<goal>exec</goal>
</goals>
</execution>
</executions>
<configuration>
<argLine>-Xmx20480m</argLine>
<mainClass>org.server.Server</mainClass>
<arguments>
</arguments>
</configuration>
</plugin>如果有人知道解决这个问题的办法,那就太好了。
非常感谢。
编辑: /proc/{pid}/ ls -l我不能直接回答你的评论,但我不明白这个mmap到底在哪里。当我切换到您所写的文件夹时,这就是我所得到的:
root@testserver /proc/1876 # ls -l
total 0
dr-xr-xr-x 2 root root 0 Nov 10 20:15 attr
-rw-r--r-- 1 root root 0 Nov 10 20:15 autogroup
-r-------- 1 root root 0 Nov 10 20:15 auxv
-r--r--r-- 1 root root 0 Nov 10 20:15 cgroup
--w------- 1 root root 0 Nov 10 20:15 clear_refs
-r--r--r-- 1 root root 0 Nov 10 20:15 cmdline
-rw-r--r-- 1 root root 0 Nov 10 20:15 comm
-rw-r--r-- 1 root root 0 Nov 10 19:37 coredump_filter
-r--r--r-- 1 root root 0 Nov 10 20:15 cpuset
lrwxrwxrwx 1 root root 0 Nov 10 19:39 cwd -> /srv/main
-r-------- 1 root root 0 Nov 10 20:15 environ
lrwxrwxrwx 1 root root 0 Nov 10 19:37 exe -> /usr/lib/jvm/java-7-oracle/bin/java
dr-x------ 2 root root 0 Nov 10 19:39 fd
dr-x------ 2 root root 0 Nov 10 20:15 fdinfo
-r-------- 1 root root 0 Nov 10 20:15 io
-r--r--r-- 1 root root 0 Nov 10 20:15 latency
-r--r--r-- 1 root root 0 Nov 10 20:15 limits
-rw-r--r-- 1 root root 0 Nov 10 20:15 loginuid
dr-x------ 2 root root 0 Nov 10 20:15 map_files
-r--r--r-- 1 root root 0 Nov 10 19:37 maps
-rw------- 1 root root 0 Nov 10 20:15 mem
-r--r--r-- 1 root root 0 Nov 10 20:15 mountinfo
-r--r--r-- 1 root root 0 Nov 10 20:15 mounts
-r-------- 1 root root 0 Nov 10 20:15 mountstats
dr-xr-xr-x 5 root root 0 Nov 10 19:37 net
dr-x--x--x 2 root root 0 Nov 10 20:15 ns
-r--r--r-- 1 root root 0 Nov 10 20:15 numa_maps
-rw-r--r-- 1 root root 0 Nov 10 20:15 oom_adj
-r--r--r-- 1 root root 0 Nov 10 20:15 oom_score
-rw-r--r-- 1 root root 0 Nov 10 20:15 oom_score_adj
-r--r--r-- 1 root root 0 Nov 10 20:15 pagemap
-r--r--r-- 1 root root 0 Nov 10 20:15 personality
lrwxrwxrwx 1 root root 0 Nov 10 19:39 root -> /
-rw-r--r-- 1 root root 0 Nov 10 20:15 sched
-r--r--r-- 1 root root 0 Nov 10 20:15 schedstat
-r--r--r-- 1 root root 0 Nov 10 20:15 sessionid
-r--r--r-- 1 root root 0 Nov 10 20:15 smaps
-r--r--r-- 1 root root 0 Nov 10 20:15 stack
-r--r--r-- 1 root root 0 Nov 10 19:37 stat
-r--r--r-- 1 root root 0 Nov 10 19:37 statm
-r--r--r-- 1 root root 0 Nov 10 20:15 status
-r--r--r-- 1 root root 0 Nov 10 20:15 syscall
dr-xr-xr-x 627 root root 0 Nov 10 20:15 task
-r--r--r-- 1 root root 0 Nov 10 20:15 wchan编辑2:地图文件:https://drive.google.com/file/d/0BxN3fm0mPOMUMVF1X0VEc2NSWVU/edit?usp=sharing
发布于 2013-11-10 19:09:17
您需要确定额外的虚拟内存来自何处。堆不是唯一使用的内存,而是JVM或应用程序。
我建议您查看/proc/{pid}/maps,看看虚拟内存是来自内存映射文件、线程堆栈还是本机内存。
您有多少线程,因为这些线程可以贡献很多(如果您有数千)
如果您有内存映射文件,这可能很容易是数百GB的虚拟内存。考虑到整个系统实际上使用的是2GB内存,我怀疑大内存映射,因为这些映射通常使用大量的虚拟内存而不使用读内存。您应该能够在maps中轻松地看到这一点,因为它包含到每个内存映射文件的路径。
下面是一个可以用来解码映射的程序。用这个运行
java -cp . Main /proc/{pid}/mapsimport java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.math.BigInteger;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new FileReader(args[0]));
List<Mapping> mappings = new ArrayList<>();
for (String line; (line = br.readLine()) != null; ) {
mappings.add(new Mapping(line));
}
Collections.sort(mappings);
for (Mapping mapping : mappings) {
System.out.println(mapping);
}
}
static class Mapping implements Comparable<Mapping> {
final String details;
final long size;
Mapping(String details) {
this.details = details;
String[] words = details.split("[- ]");
long size = 0;
try {
if (words.length > 2)
size = new BigInteger(words[1], 16).longValue() - new BigInteger(words[0], 16).longValue();
} catch (NumberFormatException e) {
// ignored.
}
this.size = size;
}
@Override
public int compareTo(Mapping o) {
// reverse order.
return -Long.compare(size, o.size);
}
@Override
public String toString() {
return String.format("%.3f %s", size / 1024.0 / 1024, details);
}
}
}https://stackoverflow.com/questions/19893814
复制相似问题