Use iostat to check %util and await for disk saturation; 2. Run iotop to identify high-I/O processes; 3. Check %wa in top or vmstat for CPU I/O wait; 4. Review mount options like noatime and discard, and verify filesystem health; 5. Identify disk type via lsblk -d -o name,rota to optimize accordingly; 6. Tune I/O scheduler: deadline for HDDs, none/mq-deadline for SSDs; 7. Assess RAID, LVM, or virtualization overhead such as thin provisioning or non-virtio disks; 8. Benchmark with dd or fio to test raw performance; 9. Ensure sufficient RAM and adjust vm.dirty_ratio and vm.dirty_background_ratio to manage writeback pressure; addressing these areas systematically resolves most slow disk I/O issues without requiring hardware upgrades.
Slow disk I/O on Linux systems can severely impact application performance, system responsiveness, and overall user experience. Diagnosing and resolving these issues requires a methodical approach to identify bottlenecks in storage, configuration, or system load. Below are key steps and tools to help troubleshoot and improve disk I/O performance.

1. Check Current I/O Utilization with iostat
The first step is to assess whether the disk is actually the bottleneck.
-
Install
sysstat
if not already available:sudo apt install sysstat # Debian/Ubuntu sudo yum install sysstat # RHEL/CentOS
Run
iostat
to monitor disk activity:iostat -x 2 5
This gives extended statistics every 2 seconds, 5 times.
Key metrics to watch:
%util
– Percentage of time the device is busy. Sustained values near 100% indicate saturation.await
– Average wait time (in ms) for I/O requests. High values suggest congestion.svctm
– Average service time (deprecated in newer kernels, use cautiously).r/s
,w/s
– Read/write operations per second.
If %util
is high and await
is increasing, the disk is likely overloaded.
2. Identify Processes Causing High I/O with iotop
Just like top
for CPU, iotop
shows which processes are generating the most I/O.
- Install and run:
sudo apt install iotop sudo iotop -o
The
-o
flag shows only processes currently doing I/O.
Look for:
- Processes with high DISK WRITE or DISK READ.
- Unexpected or runaway processes (e.g., loggers, backups, databases).
Tip: Press
r
to sort by read,w
by write, andp
to toggle processes only.
3. Check for I/O Wait in CPU Usage
High %wa
(I/O wait) in CPU usage indicates the CPU is idle waiting for disk responses.
- Use
top
orhtop
:- In
top
, look at the CPU line:%us, %sy, %ni, %id, %wa
- If
%wa
is consistently high (e.g., >20%), I/O is a bottleneck.
- In
Alternatively, use:
vmstat 2 5
Check the wa
column under CPU.
4. Evaluate Filesystem and Mount Options
Misconfigured filesystems can severely limit performance.
- Check current mount options:
mount | grep " / "
or
cat /proc/mounts
Common performance-related options:
noatime
orrelatime
– Prevents updating access time on every read (reduces writes).data=ordered
(ext4 default) – Good balance; avoiddata=journal
unless required.- For SSDs: ensure
discard
is set (or use periodicfstrim
) if using TRIM.
If
atime
is enabled, consider switching torelatime
in/etc/fstab
:/dev/sda1 / ext4 defaults,relatime 0 1
Also, check for filesystem errors or full disks:
df -h # Check free space dmesg | grep -i "I/O error" # Look for hardware errors
5. Assess Disk Type and Hardware Limitations
Not all disks perform the same:
- HDDs are slow for random I/O; optimize for sequential access.
- SSDs/NVMe offer high IOPS but can degrade if over-provisioned or worn.
Check your disk type:
lsblk -d -o name,rota
rota=1
= rotational (HDD)rota=0
= non-rotational (SSD/NVMe)
HDDs benefit from:
- Larger I/O queues
- Sequential access patterns
- Reducing random I/O via caching or batching
6. Tune I/O Scheduler
Linux uses different I/O schedulers (e.g., cfq
, deadline
, noop
, mq-deadline
, kyber
).
- Check current scheduler:
cat /sys/block/sda/queue/scheduler
(Replace
sda
with your disk)
Recommended:
- For SSD/NVMe:
none
(viamq-deadline
orkyber
on modern kernels) - For HDD:
mq-deadline
ordeadline
Change temporarily:
echo deadline | sudo tee /sys/block/sda/queue/scheduler
Make permanent via kernel boot parameter (e.g., in GRUB):
elevator=deadline
7. Check for RAID, LVM, or Virtualization Overhead
- LVM: Thin provisioning or snapshots can slow I/O.
- RAID arrays: Rebuilds or degraded arrays cause slowness.
- Virtual machines: Host storage contention or using emulated disks (e.g., IDE instead of virtio).
In VMs:
- Use
virtio
block devices. - Ensure the host isn’t overcommitted on storage.
8. Test Raw Disk Performance
Use tools to benchmark actual disk speed.
Sequential write test:
dd if=/dev/zero of=/tmp/testfile bs=1G count=1 oflag=direct
(
oflag=direct
bypasses cache)Read test:
dd if=/tmp/testfile of=/dev/null bs=1G iflag=direct
Better tool: fio
(Flexible I/O Tester)
fio --name=randwrite --ioengine=libaio --direct=1 \ --size=1G --bs=4k --rw=randwrite --runtime=60
Compare results with expected disk specs.
9. Consider Memory and Cache Pressure
Low available memory forces more frequent disk writes (dirty pages) and fewer read caches.
- Check memory usage:
free -h
- Monitor dirty memory:
cat /proc/vmstat | grep -E "dirty|writeback"
Tune kernel dirty page settings in /etc/sysctl.conf
:
vm.dirty_background_ratio = 5 # Start writing at 5% dirty memory vm.dirty_ratio = 10 # Throttle at 10%
Avoid overly aggressive flushing that causes I/O bursts.
Summary Checklist
- ? Use
iostat
andiotop
to confirm I/O bottleneck - ? Check for high
%wa
in CPU usage - ? Review mount options (
noatime
,discard
) - ? Verify disk type and health
- ? Tune I/O scheduler based on storage
- ? Rule out LVM, RAID, or virtualization overhead
- ? Benchmark with
fio
ordd
- ? Ensure sufficient RAM and tune dirty page settings
Slow disk I/O is rarely a single-point failure — it’s often a mix of workload, configuration, and hardware. Start with monitoring, isolate the cause, and apply targeted fixes. Most issues can be resolved without hardware upgrades if caught early.
The above is the detailed content of Troubleshooting Slow Disk I/O on Linux Systems. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Linux's cost of ownership is usually lower than Windows. 1) Linux does not require license fees, saving a lot of costs, while Windows requires purchasing a license. 2) Linux has low hardware requirements and can extend the service life of the device. 3) The Linux community provides free support to reduce maintenance costs. 4) Linux is highly secure and reduces productivity losses. 5) The Linux learning curve is steep, but Windows is easier to use. The choice should be based on specific needs and budget.

LinuxoftenoutperformsWindowsinI/Operformanceduetoitscustomizablekernelandfilesystems,whileWindowsoffersmoreuniformperformanceacrosshardware.1)LinuxexcelswithcustomizableI/OschedulerslikeCFQandDeadline,enhancingperformanceinhigh-throughputapplications

The key to installing dual systems in Linux and Windows is partitioning and boot settings. 1. Preparation includes backing up data and compressing existing partitions to make space; 2. Use Ventoy or Rufus to make Linux boot USB disk, recommend Ubuntu; 3. Select "Coexist with other systems" or manually partition during installation (/at least 20GB, /home remaining space, swap optional); 4. Check the installation of third-party drivers to avoid hardware problems; 5. If you do not enter the Grub boot menu after installation, you can use boot-repair to repair the boot or adjust the BIOS startup sequence. As long as the steps are clear and the operation is done properly, the whole process is not complicated.

The key to enabling EPEL repository is to select the correct installation method according to the system version. First, confirm the system type and version, and use the command cat/etc/os-release to obtain information; second, enable EPEL through dnfinstallepel-release on CentOS/RockyLinux, and the 8 and 9 version commands are the same; third, you need to manually download the corresponding version of the .repo file and install it on RHEL; fourth, you can re-import the GPG key when encountering problems. Note that the old version may not be supported, and you can also consider enabling epel-next to obtain the test package. After completing the above steps, use dnfrepolist to verify that the EPEL repository is successfully added.

Linux usually performs better in web server performance, mainly due to its advantages in kernel optimization, resource management and open source ecosystem. 1) After years of optimization of the Linux kernel, mechanisms such as epoll and kqueue make it more efficient in handling high concurrent requests. 2) Linux provides fine-grained resource management tools such as cgroups. 3) The open source community continuously optimizes Linux performance, and many high-performance web servers such as Nginx are developed on Linux. By contrast, Windows performs well when handling ASP.NET applications and provides better development tools and commercial support.

Newbie users should first clarify their usage requirements when choosing a Linux distribution. 1. Choose Ubuntu or LinuxMint for daily use; programming and development are suitable for Manjaro or Fedora; use Lubuntu and other lightweight systems for old devices; recommend CentOSStream or Debian to learn the underlying principles. 2. Stability is preferred for UbuntuLTS or Debian; you can choose Arch or Manjaro to pursue new features. 3. In terms of community support, Ubuntu and LinuxMint are rich in resources, and Arch documents are technically oriented. 4. In terms of installation difficulty, Ubuntu and LinuxMint are relatively simple, and Arch is suitable for those with basic needs. It is recommended to try it first and then decide.

The steps to add a new hard disk to the Linux system are as follows: 1. Confirm that the hard disk is recognized and use lsblk or fdisk-l to check; 2. Use fdisk or parted partitions, such as fdisk/dev/sdb and create and save; 3. Format the partition to a file system, such as mkfs.ext4/dev/sdb1; 4. Use the mount command for temporary mounts, such as mount/dev/sdb1/mnt/data; 5. Modify /etc/fstab to achieve automatic mount on the computer, and test the mount first to ensure correctness. Be sure to confirm data security before operation to avoid hardware connection problems.

Have problems uploading files in Google Chrome? This may be annoying, right? Whether you are attaching documents to emails, sharing images on social media, or submitting important files for work or school, a smooth file upload process is crucial. So, it can be frustrating if your file uploads continue to fail in Chrome on Windows PC. If you're not ready to give up your favorite browser, here are some tips for fixes that can't upload files on Windows Google Chrome 1. Start with Universal Repair Before we learn about any advanced troubleshooting tips, it's best to try some of the basic solutions mentioned below. Troubleshooting Internet connection issues: Internet connection
