我在Linux服务器上运行solr在tomcat服务器上,当我使用顶级命令时,我看到“VIRT”非常高
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 4786 root 20 0 19.6g 3.8g 10m S 200 15.9 8:26.13 java 1808 root 20 0 6437m 162m 4740 S 2 0.7 101:08.75 java 4889 root 20 0 19352 1580 1064 R 1 0.0 0:00.08 top 31700 mysql 20 0 6677m 5.2g 4468 S 0 22.0 470:51.49 mysqld 1 root 20 0 23708 1464 972 S 0 0.0 0:23.06 init
这可能是什么原因,或者我该如何描述这个?
您看到如此高的虚拟内存使用率的原因是Solr使用MMapFSDirectory作为操作Lucene索引的默认类。 这个类将试图将Solr控制下的所有索引映射到虚拟内存 – 越多核心/索引越糟糕。 有趣的是,这不在JVM的知识/控制范围之内。 JVM只会报告您为servlet容器指定的(-Xms:128m -Xmx:1024m作为示例)最小/最大内存。 他们会很高兴地警告人们,或者使用更为保守的directoryFactory作为默认值。
更改solrconfig.xml中的行:
directoryFactory name="DirectoryFactory" class="${solr.directoryFactory:solr.StandardDirectoryFactory}"
指向类似NIOFSDirectoryFactory的东西。