• 请不要在回答技术问题时复制粘贴 AI 生成的内容
aiqier
V2EX  ›  程序员

Java 的 web 服务会在什么情况下读磁盘?

  •  
  •   aiqier · Nov 17, 2020 · 2657 views
    This topic created in 2030 days ago, the information mentioned may be changed or developed.

    web 服务是用 spring 写的,部署在 jetty 上,使用网络请求 mysql 和 redis,有接入消息队列,有上报日志。但是看监控读磁盘 io 操作的时间和 size 都升高了(其实写也升高了)。

    但自己项目没什么要加载静态文件的地方。

    自己能想到的就在虚拟内存页交换和加载 java 类了,除了这些还有什么会读磁盘?

    14 replies    2020-11-19 15:47:21 +08:00
    xuanbg
        1
    xuanbg  
       Nov 17, 2020
    读写 MySQL 的时候,MySQL 就会有磁盘 IO 。写 Redis 的时候,Redis 如果配置了数据持久化的话,也会写磁盘。消息队列同样也会有数据持久化,也需要写磁盘的。
    aiqier
        2
    aiqier  
    OP
       Nov 17, 2020
    @xuanbg mysql 和 redis 都不在本机。
    misaka19000
        3
    misaka19000  
       Nov 17, 2020
    swap
    rulework
        4
    rulework  
       Nov 17, 2020
    所有数据持久化操作不都得跟磁盘打交道
    rulework
        5
    rulework  
       Nov 17, 2020
    所有数据持久化操作不都得跟磁盘打交道
    @aiqier 确定只是磁盘 io 而不包含网络 io 吗
    aiqier
        6
    aiqier  
    OP
       Nov 17, 2020
    @rulework 是的,disk.io 的利用率和量都涨了。
    luckyrayyy
        7
    luckyrayyy  
       Nov 17, 2020
    你没有日志吗?框架没有默认日志吗?
    aiqier
        8
    aiqier  
    OP
       Nov 17, 2020
    @luckyrayyy 类似 logagent 打本地上报到服务器。
    billccn
        9
    billccn  
       Nov 18, 2020
    strace 一下 JVM 看它写什么了呗。感觉最可能是 swap
    onice
        11
    onice  
       Nov 18, 2020
    是不是内存满了,用了 swap 。
    aiqier
        12
    aiqier  
    OP
       Nov 18, 2020
    @onice swap 看了,用了很少一部分。
    azygote
        13
    azygote  
       Nov 19, 2020
    如果日志框架是 log4j/log4j2, 然后启用了 rolling file appender 的话,是会向硬盘写日志的
    aiqier
        14
    aiqier  
    OP
       Nov 19, 2020
    @azygote 我主要是说读磁盘,我理解系统会读取磁盘的日志上报到服务器。但是那个是 logagent 不算是 java 服务本身。
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2537 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 56ms · UTC 16:10 · PVG 00:10 · LAX 09:10 · JFK 12:10
    ♥ Do have faith in what you're doing.