Measuring performance with the perf kernel tool
On Fire
perf
can also even create pretty graphics. Thanks to flame graphs, admins and developers can determine the most frequently used software paths. The developer tools integrated into browsers can also generate graphics (Figure 3).
The x-axis shows the load of the individual processes; the y-axis the resolution of each function call. The wider the blocks, the more resources their processes require, which helps you see which areas are problematic are most in need of optimizing.
Admins can also generate flame graphs from perf
data. You do not have to write the script yourself – look for the script on GitHub [5]:
git clone https://github.com/brendangregg/FlameGraph
The commands from Listing 5 record the performance data and create a flame graph with perf script
(Figure 4). The flame graph shows that, although the browser is playing a 720p video, the kernel is pretty much in sleep mode. In the browser, individual sections of the flame graph can be zoomed in and out.
Listing 5
Commands for Creating a Flame Graph
01 sudo perf record -F 99 -a -g -- sleep 10 02 sudo perf script > out.perf 03 ./stackcollapse-perf.pl out.perf > out.folded 04 ./flamegraph.pl out.folded > out.svg 05 firefox out.svg
Dynamic Tracing
Using the perf
probe
subcommand and the --add
switch, admins can define dynamic trace points. Listing 6 shows the procedure using the Linux tcp_sendmsg()
function as an example.
Listing 6
tcp_sendmsg as Dynamic Trace Point
01 $ sudo perf probe --addd='tcp_sendmsg' 02 Added new event: 03 probe:tcp_sendmsg (on tcp_sendmsg) 04 [...] 05 $ sudo perf record -e probe:tcp_sendmsg -aR sleep 5 06 [ perf record: Woken up 1 times to write data ] 07 $ sudo perf report --stdio 08 [...]
Dynamic Duo
The Linux perf
subsystem and the perf
tool collection offer many possibilities for analyzing a system. Admins can easily collect and evaluate data with existing tools and scripts to achieve an overview. Correct interpretation of the data requires some knowledge of the perf
subsystem. Because the Linux kernel delivers perf
directly, you won't need to worry about installing external modules.
« Previous 1 2 3 4 Next »
Buy this article as PDF
(incl. VAT)
Buy Linux Magazine
Subscribe to our Linux Newsletters
Find Linux and Open Source Jobs
Subscribe to our ADMIN Newsletters
Support Our Work
Linux Magazine content is made possible with support from readers like you. Please consider contributing when you’ve found an article to be beneficial.
News
-
Latest Cinnamon Desktop Releases with a Bold New Look
Just in time for the holidays, the developer of the Cinnamon desktop has shipped a new release to help spice up your eggnog with new features and a new look.
-
Armbian 24.11 Released with Expanded Hardware Support
If you've been waiting for Armbian to support OrangePi 5 Max and Radxa ROCK 5B+, the wait is over.
-
SUSE Renames Several Products for Better Name Recognition
SUSE has been a very powerful player in the European market, but it knows it must branch out to gain serious traction. Will a name change do the trick?
-
ESET Discovers New Linux Malware
WolfsBane is an all-in-one malware that has hit the Linux operating system and includes a dropper, a launcher, and a backdoor.
-
New Linux Kernel Patch Allows Forcing a CPU Mitigation
Even when CPU mitigations can consume precious CPU cycles, it might not be a bad idea to allow users to enable them, even if your machine isn't vulnerable.
-
Red Hat Enterprise Linux 9.5 Released
Notify your friends, loved ones, and colleagues that the latest version of RHEL is available with plenty of enhancements.
-
Linux Sees Massive Performance Increase from a Single Line of Code
With one line of code, Intel was able to increase the performance of the Linux kernel by 4,000 percent.
-
Fedora KDE Approved as an Official Spin
If you prefer the Plasma desktop environment and the Fedora distribution, you're in luck because there's now an official spin that is listed on the same level as the Fedora Workstation edition.
-
New Steam Client Ups the Ante for Linux
The latest release from Steam has some pretty cool tricks up its sleeve.
-
Gnome OS Transitioning Toward a General-Purpose Distro
If you're looking for the perfectly vanilla take on the Gnome desktop, Gnome OS might be for you.