AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1008523
Accepted
Amos
Amos
Asked: 2020-03-27 06:02:16 +0800 CST2020-03-27 06:02:16 +0800 CST 2020-03-27 06:02:16 +0800 CST

ubuntu 18.04:clamav 运行,tomcat 死机

  • 772

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.

我知道升级是一个直接的答案,但在那之前,我的问题是:

  1. 有没有办法在不消耗 800+mb 的情况下运行 clamav?

  2. 如果类似的事情再次发生,有没有办法自动重启tomcat?

  3. 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"
service clamav ubuntu-18.04 tomcat9
  • 1 1 个回答
  • 342 Views

1 个回答

  • Voted
  1. Best Answer
    Piotr P. Karwasz
    2020-03-27T12:59:18+08:002020-03-27T12:59:18+08:00

    Java 没有使用 4.5 GiB 的物理内存,这个数字是指虚拟内存。您有大约 128 TiB 的虚拟内存地址空间(参见此答案),它用于访问物理内存,也用于访问文件,就好像它们在内存中一样。大多数分配的虚拟空间不使用任何物理内存,并且仅包含0s 或指向存在于硬盘驱动器上的数据。

    您感兴趣的是anon-rss编号:它是进程使用的物理内存,主要用于私人用途,而不仅仅是文件的缓存/副本(与file-rss不同)。内核不能只是删除这个内存,你会得到一个 OOM。

    Janne对您之前的问题的回答指出了您的问题的解决方案:

    1. 您应该调整 Tomcat 的内存设置,这可以通过将选项添加JAVA_OPTS到/etc/default/tomcat9. 最常用的是-Xms(最小堆大小)和-Xmx(最大堆大小)。例如,您可以使用:

      JAVA_OPTS="-Djava.awt.headless=true -Xms256m -Xmx1024m"
      

      JVM 将使用 256 MiB 到 1024 MiB 的堆空间(加上其他类型的 Java 内存),并且可能会在不使用时将其中的一部分归还。

    2. 您的交换量非常小,尤其是在您没有大量 RAM 的情况下。将其扩展到大约 4 GiB(参见本文),以便内核可以交换一些内存而不是杀死 Tomcat。

    3. 要配置失败后自动重启 Tomcat,请编辑该tomcat.service文件:

      systemctl edit --full tomcat.service
      

      并添加到该[Service]部分,例如:

      RestartSec=5s
      Restart=on-failure
      

      Restart您可以在SystemD 文档中找到可能的值。

    • 1

相关问题

  • 计划终止端口连接

  • 如何提供可搜索的 IRC 日志?

  • GlassFish 服务在控制台注销时停止

  • “工作站”和“服务器”服务不断停止

  • 如何删除或卸载孤立服务?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve