Home Operation and Maintenance Linux Operation and Maintenance What is linux perf? how to use? (Usage summary)

What is linux perf? how to use? (Usage summary)

Nov 05, 2021 pm 05:50 PM
linux

The following column linux system tutorial will introduce and summarize the use of linux perf. I hope it will be helpful to friends in need!

Introduction

perf is a performance analysis tool provided in Linux systems. It is implemented based on a kernel subsystem called "Performance counters" and supports hardware (CPU, Performance analysis at the PMU (Performance Monitoring Unit) and software (software counters, tracepoint) levels.

Events in perf

Perf, like other performance tuning tools, infers the entire program by sampling monitoring objects and based on the distribution of sampling points. Behavior. Through the perf list command, we can see that perf supports many sampling events, such as branch-misses, cpu-clock, etc. The predefined events in perf belong to different types, such as hardware-generated events (cache hit/branch miss) and software-generated events (context switch/page fault), etc.

tracepoint

Tracepoint is some hooks defined in the Linux kernel. If enabled, they will be triggered when specific logic is executed to facilitate other tools to obtain the system For internal running status and other information, perf uses tracepoint. It records and counts various tracepoint events and generates analysis reports.

Usage

The specific usage of the perf tool is as follows:

perf [--version] [--help] COMMAND [ARGS]
Copy after login

The COMMAND list can be viewed by executing perf --help, listed below Several commonly used commands.

perf stat

The function of perf stat is to execute a command and collect various data during its operation. It can provide an overall overview of the running status of a program. For example:

user@localhost:~$ perf stat hostname
localhost
 Performance counter stats for 'hostname':
          0.313464      task-clock (msec)         #    0.481 CPUs utilized          
                 2      context-switches          #    0.006 M/sec                  
                 0      cpu-migrations            #    0.000 K/sec                  
               153      page-faults               #    0.488 M/sec                  
           896,723      cycles                    #    2.861 GHz                    
           620,709      instructions              #    0.69  insn per cycle         
           121,143      branches                  #  386.465 M/sec                  
             6,247      branch-misses             #    5.16% of all branches        
       0.000651441 seconds time elapsed
Copy after login

In the above example, the hostname command is run through perf stat, and some indicators during its operation are summarized and displayed, such as task-clock, context-switches and waiting. By default, perf stat will output statistics of several commonly used events, such as:

task-clock-msecs:cpu 使用率
context-switches:进程切换次数
page-faults:发生缺页的次数
cpu-migrations:表示进程运行过程中发生了多少次CPU迁移,即被调度器从一个CPU转移到另外一个CPU上运行
cycles:处理器时钟,一条机器指令可能需要多个cycles
instructions: 机器指令数目
branches:遇到的分支指令数
branch-misses是预测错误的分支指令数
Copy after login

In addition, we can use the -e parameter to specify the events we are interested in, such as:

user@localhost:~$ perf stat -e cache-misses hostname
localhost
 Performance counter stats for 'hostname':
          682      cache-misses                                                
       0.000646676 seconds time elapsed
Copy after login

perf top

The function of perf top is to display the current performance statistics of the system in real time. The previous perf stat is used to analyze a specific program, and sometimes we may not know which program affects system performance. At this time, we can use perf top to find suspicious programs. For example:

Samples: 775  of event 'cpu-clock', Event count (approx.): 92931021
Overhead  Shared Object       Symbol
   8.93%  [kernel]            [k] vsnprintf
   7.73%  perf                [.] rb_next
   5.92%  [kernel]            [k] kallsyms_expand_symbol.clone.0
   5.07%  [kernel]            [k] format_decode
   4.59%  [kernel]            [k] number
   3.40%  perf                [.] symbols__insert
   3.03%  libslang.so.2.2.1   [.] SLtt_smart_puts
Copy after login

The above example shows that perf counts the data of cpu-clock events and sorts them according to the proportion. Like perf stat, we can specify statistics of other events through the -e parameter. For example, perf top -e context-switches can view the top N processes with the most process switches.

perf record & perf report

perf record is similar to perf stat. It can run a command and generate statistical information, but perf record will not display the results. out, instead outputting the results to a file. The files generated by perf record can be parsed with perf report.

perf record can also use the -g parameter to generate a calling graph during analysis to help locate the higher-level logical distribution.

Others

Through the example, we can find that the Symbol column in the perf analysis results displays the names of c language functions. For Java, the functions generated by JIT compilation will be directly displayed in the symbol instead of the function name of Java. At this time, it is not so easy to locate the problem. We need to use additional means to combine the symbol with the symbol table of the Java program. Correspondence will be discussed in detail later.

Recommended learning: "linux video tutorial"

The above is the detailed content of What is linux perf? how to use? (Usage summary). For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

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

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to use docker desktop How to use docker desktop Apr 15, 2025 am 11:45 AM

How to use Docker Desktop? Docker Desktop is a tool for running Docker containers on local machines. The steps to use include: 1. Install Docker Desktop; 2. Start Docker Desktop; 3. Create Docker image (using Dockerfile); 4. Build Docker image (using docker build); 5. Run Docker container (using docker run).

Difference between centos and ubuntu Difference between centos and ubuntu Apr 14, 2025 pm 09:09 PM

The key differences between CentOS and Ubuntu are: origin (CentOS originates from Red Hat, for enterprises; Ubuntu originates from Debian, for individuals), package management (CentOS uses yum, focusing on stability; Ubuntu uses apt, for high update frequency), support cycle (CentOS provides 10 years of support, Ubuntu provides 5 years of LTS support), community support (CentOS focuses on stability, Ubuntu provides a wide range of tutorials and documents), uses (CentOS is biased towards servers, Ubuntu is suitable for servers and desktops), other differences include installation simplicity (CentOS is thin)

What to do if the docker image fails What to do if the docker image fails Apr 15, 2025 am 11:21 AM

Troubleshooting steps for failed Docker image build: Check Dockerfile syntax and dependency version. Check if the build context contains the required source code and dependencies. View the build log for error details. Use the --target option to build a hierarchical phase to identify failure points. Make sure to use the latest version of Docker engine. Build the image with --t [image-name]:debug mode to debug the problem. Check disk space and make sure it is sufficient. Disable SELinux to prevent interference with the build process. Ask community platforms for help, provide Dockerfiles and build log descriptions for more specific suggestions.

How to view the docker process How to view the docker process Apr 15, 2025 am 11:48 AM

Docker process viewing method: 1. Docker CLI command: docker ps; 2. Systemd CLI command: systemctl status docker; 3. Docker Compose CLI command: docker-compose ps; 4. Process Explorer (Windows); 5. /proc directory (Linux).

What computer configuration is required for vscode What computer configuration is required for vscode Apr 15, 2025 pm 09:48 PM

VS Code system requirements: Operating system: Windows 10 and above, macOS 10.12 and above, Linux distribution processor: minimum 1.6 GHz, recommended 2.0 GHz and above memory: minimum 512 MB, recommended 4 GB and above storage space: minimum 250 MB, recommended 1 GB and above other requirements: stable network connection, Xorg/Wayland (Linux)

Detailed explanation of docker principle Detailed explanation of docker principle Apr 14, 2025 pm 11:57 PM

Docker uses Linux kernel features to provide an efficient and isolated application running environment. Its working principle is as follows: 1. The mirror is used as a read-only template, which contains everything you need to run the application; 2. The Union File System (UnionFS) stacks multiple file systems, only storing the differences, saving space and speeding up; 3. The daemon manages the mirrors and containers, and the client uses them for interaction; 4. Namespaces and cgroups implement container isolation and resource limitations; 5. Multiple network modes support container interconnection. Only by understanding these core concepts can you better utilize Docker.

What is vscode What is vscode for? What is vscode What is vscode for? Apr 15, 2025 pm 06:45 PM

VS Code is the full name Visual Studio Code, which is a free and open source cross-platform code editor and development environment developed by Microsoft. It supports a wide range of programming languages ​​and provides syntax highlighting, code automatic completion, code snippets and smart prompts to improve development efficiency. Through a rich extension ecosystem, users can add extensions to specific needs and languages, such as debuggers, code formatting tools, and Git integrations. VS Code also includes an intuitive debugger that helps quickly find and resolve bugs in your code.

vscode cannot install extension vscode cannot install extension Apr 15, 2025 pm 07:18 PM

The reasons for the installation of VS Code extensions may be: network instability, insufficient permissions, system compatibility issues, VS Code version is too old, antivirus software or firewall interference. By checking network connections, permissions, log files, updating VS Code, disabling security software, and restarting VS Code or computers, you can gradually troubleshoot and resolve issues.

See all articles