-
Notifications
You must be signed in to change notification settings - Fork 414
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
[QUESTION] URing weird CPU utilization with write requests #1260
Comments
Application does not use neither IORING_SETUP_IOPOLL nor IORING_SETUP_SQPOLL. For each write operation it sets IOSQE_ASYNC flag. Submits are done using io_uring_submit(). Here is an strace sample of the application: $ sudo perf trace --tid 1321722 -e 'io_uring_enter' -- sleep 1
0.000 ( 0.010 ms): io_uring_enter(fd: 4, to_submit: 1, argsz: 8) = 1
0.182 ( 0.003 ms): io_uring_enter(fd: 4, to_submit: 1, argsz: 8) = 1
0.362 ( 0.006 ms): io_uring_enter(fd: 4, to_submit: 1, argsz: 8) = 1
1.328 ( 0.005 ms): io_uring_enter(fd: 4, to_submit: 2, argsz: 8) = 2
3.264 ( 0.016 ms): io_uring_enter(fd: 4, to_submit: 1, argsz: 8) = 1
7.107 ( 0.004 ms): io_uring_enter(fd: 4, to_submit: 1, argsz: 8) = 1 |
Don't set IOSQE_ASYNC, it'll generally just slow things down. On anything more recent (eg 6.x kernels), it'll just do more harm than good. Anything that needs to punt to a worker thread will do so internally anyway, forcing it is usually not a good idea. |
Okay, I will try this and send measured results here, thanks. Maybe there are other general advises to make my URing faster on new kernels? What I am for is low latency and balanced load across many CPUs |
Hello @axboe , I tested your idea with removing IOSQE_ASYNC and it sadly didn't work, that is not the reason of performance degradation. Unfortunately I still observe uneven load distribution for write requests after removing IOSQE_ASYNC flag |
I've been measuring performance of my Uring across the application and found out unexpected results:
Can you please explain the reasons of such weird behaviour?
The text was updated successfully, but these errors were encountered: