I recently upgraded to the Kubuntu Natty Beta 1 and I've been having a lot of issues with the process kworker. At moments it uses almost half my CPU. Also, strangely enough it seems to affect my USB ports; whenever I plug in an USB drive, the process kworker goes into hyperdrive, leaving me unable to work.
I have thought about filing a bug but since I haven't even found any reasonable explanation on what kworker is I figured I should find out first.
"kworker" is a placeholder process for kernel worker threads, which perform most of the actual processing for the kernel, especially in cases where there are interrupts, timers, I/O, etc. These typically correspond to the vast majority of any allocated "system" time to running processes. It is not something that can be safely removed from the system in any way, and is completely unrelated to nepomuk or KDE (except in that these programs may make system calls, which may require the kernel to do something).
There were some reports of excessive kworker activity for relatively idle systems starting during 2.6.36 development (example discussion), and wide reports of confusion and problems with 2.6.38 (although many of these reports include the word "Natty", so I presume these people not to have used any kernel between 2.6.35 (distributed in Ubuntu 10.10) and 2.6.38 (distributed in Ubuntu 11.04).
I've found many reports of something that "fixed" this for one or another user. Most "fixes" seem to be related to updates of the kernel of various sorts. Where the update can be tracked to a specific issue, it seems to often be some driver or kernel service that has been patched to not misbehave: I have the impression that there are a very large number of things in the kernel that can cause a behaviour which is observed as excessive kworker usage.
If you find the system unusable due to excessive kworker activity, I would recommend trying to do fewer things. If you think you're not doing anything, try shutting down long-running services or timers (RSS readers, mail readers, file indexers, activity trackers, etc.). If this doesn't work, try restarting. If your system allows you to enable or disable hardware in a pre-boot environment, try turning off hardware you aren't using. If it happens on every restart before you do anything, you could try uninstalling things, but at this point you'll want to be running syscall profiling tools to track down specific applications that seem to be causing this overload.
It is to be hoped that your specific system will stop expressing this behaviour with a future kernel upgrade (and many of the most common causes of this have been solved).
What is kworker?
kworker
means a Linux kernel process doing "work" (processing system calls). You can have several of them in your process list:kworker/0:1
is the one on your first CPU core,kworker/1:1
the one on your second etc..Why does kworker hog your CPU? To find out why a kworker is wasting your CPU, you can create CPU backtraces: watch your processor load (with
top
or something) and in moments of high load throughkworker
, executeecho l > /proc/sysrq-trigger
to create a backtrace. (On Ubuntu, this needs you to login withsudo -s
). Do this several times, then watch the backtraces at the end ofdmesg
output. See what happens frequently in the CPU backtraces, it hopefully points you to the source of your problem.Example: e1000e. In my case, I found a backtrace like this nearly every time:
It hinted me to a problem in the
e1000e
Ethernet card module, and indeed asudo rmmod e1000e
made the high CPU load go away immediately [e1000e bug #26].Why does kworker hog your CPU (cont.)? As an alternative to my other answer here, Perf is a more professional way to analyse what kernel tasks are hogging your CPU:
Install
perf
:(The second package must match your kernel version. You can first install just
linux-tools-common
and callperf
to let it tell you which package it needs.)Record some 10 seconds of backtraces on all your CPUs:
Analyse your recording:
(Navigate the call graph with ←, →, ↑, ↓ and Enter.)
Just to let everyone know. I ran into this issue, installed perf (which is a great tool), it pointed to spin locking and XFS. That pointed to NFS. Then I realized one of my mounts was out of space. Freeing up space caused kworker CPU to drop to 0.
So apparently this can be a symptom of running out of drive space on a busy NFS server!
I recently installed Ubuntu Natty on an external drive usb wd passport. When I start on my desktop which is about two years old, everything works like a charm. When I start on my new laptop (MSI gt680r system), it slows down after I wake up the computer from sleep, or if I plug another usb disk.
Kworker processes take more and more cpu, and the mouse freezes from time to time.
I have read several solutions on various forums that did not work.
I went into the bios of my laptop, where there was:
I changed for:
and since that, it doesn't freeze anymore on natty on my laptop.
I would enable hand back if and when the problem is corrected.
I think disabling Nepomuk can help you:
http://www.freetechie.com/blog/disable-nepomuk-desktop-search-on-kde-4-4-2-kubuntu-lucid-10-04/