Ubuntu 18.04。2Gb RAM + 512mb 交换。
运行 clamav 时,它会消耗 800+mb 的内存,因为它会将所有签名加载到内存中。因此,我将其设置为每天凌晨 3 点运行,而不是持续运行。
到目前为止,tomcat 和 clamav 相处得很好。昨晚凌晨 3 点,当 clamav 开始工作时,tomcat 服务被关闭。
[4643256.375812] OOM killed process 8145 (clamscan) total-vm:1149268kB, anon-rss:969476kB, file-rss:4kB
[7667218.452649] OOM killed process 8865 (java) total-vm:4568248kB, anon-rss:1067312kB, file-rss:0kB
Mar 26 03:00:31 user systemd[1]: tomcat.service: Main process exited, code=killed, status=9/KILL
Mar 26 03:00:31 user systemd[1]: tomcat.service: Failed with result 'signal'.
Mar 26 03:17:08 user systemd[1]: Reloading The Apache HTTP Server.
Mar 26 03:17:08 user systemd[1]: Reloaded The Apache HTTP Server.
我知道升级是一个直接的答案,但在那之前,我的问题是:
有没有办法在不消耗 800+mb 的情况下运行 clamav?
如果类似的事情再次发生,有没有办法自动重启tomcat?
Java 真的占用了 4,568,248kB = 4.5gb 还是我遗漏了什么?
在 tomcat.service 文件中编辑 我有以下内容:
Environment="CATALINA_OPTS=-Xms512M -Xmx1024M -server -XX:+UseParallelGC"
Environment="JAVA_OPTS=-Djava.security.egd=file:///dev/urandom -Djava.awt.headless=true"