Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Windows 10 super slow I/O #373

Open
ehsankhodayar opened this issue Nov 29, 2022 · 3 comments
Open

Windows 10 super slow I/O #373

ehsankhodayar opened this issue Nov 29, 2022 · 3 comments

Comments

@ehsankhodayar
Copy link

I have created a Windows 10 Pro using windows-imaging-tools. After running a new VM based on this image, the Disk activation time is always 100%, while the VM is not running any special service. I am using OpenStack Yoga on a baremetal server with a KVM hypervisor. It works fine when I run a VM using the same image file and VirtualBox.

I also allocated more resources to the OpenStack VM, but nothing changed.

image
image

@ader1990
Copy link
Member

ader1990 commented Dec 5, 2022

Hello,

From the task manager, I can see that Windows Update might be the process hogging the IO resources.

@ehsankhodayar
Copy link
Author

Hi @ader1990,
When I check processes, I don't find a particular I/O-intensive process that causes this problem. However, a few days ago, I noticed one issue. The server I am working on has around 230 GB of storage for the root partition and 9 TB of storage for the opt partition where the OpenStack is located. I noticed when I ran the VM using VirtualBox in the root partition it worked fine. But when I ran the same VM on the opt partition, it was as slow as OpenStack. I think the problem is from opt partition. This partition has a raid six configuration. Do you know what can cause this issue? I have this problem with running even one VM in the opt directory.

@ader1990
Copy link
Member

ader1990 commented Dec 5, 2022

I usually test the storage IO with a simple command: dd. On Windows, it comes with the git environment.

NOTE: dd command is very distructive if not used correctly, as it wipes the file as value for the argument "of", use it at your own risk.

The code bellow is an incomplete example, as you need to change the path "C:\tmp" according to your environment.

For sequential IO, from PowerShell:

mkdir C:\tmp
& "C:\Program Files\Git\usr\bin\dd.exe" if=/dev/zero of=C:\tmp\output-8MB.img bs=8MB count=500 oflag=dsync

I get around 650MB/s on a good NVME SSD.

For random IO, from PowerShell:

mkdir C:\tmp
& "C:\Program Files\Git\usr\bin\dd.exe" if=/dev/zero of=C:\tmp\output-4KB.img bs=4KB count=500 oflag=dsync

I get around 25MB/s on a good NVME SSD.

You can compare the two disks easily this way.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants