리눅스 성능이란 무엇입니까? 그것을 사용하는 방법? (사용 요약)
다음 칼럼에서는 linux system tutorial 칼럼에서 linux perf의 사용법을 소개하고 정리하겠습니다. 필요한 친구들에게 도움이 되었으면 좋겠습니다!
소개
perf는 Linux 시스템에서 제공되는 성능 분석 도구로 "성능 카운터"라는 커널 하위 시스템을 기반으로 구현되며 하드웨어(CPU, PMU(Performance Monitoring Unit))와 소프트웨어(소프트웨어 카운터)를 모두 지원합니다. ) , 추적점) 수준 성능 분석.
perf
perf의 이벤트는 다른 성능 조정 도구와 마찬가지로 모니터링 개체를 샘플링하고 샘플링 지점 분포를 기반으로 전체 프로그램의 동작을 추론합니다. perf list 명령을 통해 perf가 Branch-misses, CPU-clock 등과 같은 많은 샘플링 이벤트를 지원한다는 것을 알 수 있습니다. 성능에 사전 정의된 이벤트는 하드웨어 생성 이벤트(캐시 적중/분기 누락) 및 소프트웨어 생성 이벤트(컨텍스트 전환/페이지 오류) 등과 같은 다양한 유형에 속합니다.
tracepoint
tracepoint는 Linux 커널에 정의된 일부 후크입니다. 활성화되면 특정 논리가 실행될 때 트리거되어 Perf가 추적점을 사용하는 내부 실행 상태와 같은 정보를 쉽게 얻을 수 있습니다. , 다양한 추적점 이벤트를 기록 및 계산하고 분석 보고서를 생성합니다.
Usage
perf 도구의 구체적인 사용법은 다음과 같습니다.
perf [--version] [--help] COMMAND [ARGS]
COMMAND 목록은 perf --help를 실행하여 볼 수 있습니다.
perf stat
perf stat는 명령을 실행하고 작업 중에 다양한 데이터를 수집하는 데 사용되며 프로그램 실행 상태에 대한 전반적인 개요를 제공할 수 있습니다. 예:
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
위의 예에서 호스트 이름 명령은 perf stat를 통해 실행되었으며 작업 중 작업 시계, 컨텍스트 스위치 등과 같은 일부 표시기가 요약되어 표시되었습니다. 기본적으로 perf stat는 다음과 같이 일반적으로 사용되는 여러 이벤트의 통계를 출력합니다.
task-clock-msecs:cpu 使用率 context-switches:进程切换次数 page-faults:发生缺页的次数 cpu-migrations:表示进程运行过程中发生了多少次CPU迁移,即被调度器从一个CPU转移到另外一个CPU上运行 cycles:处理器时钟,一条机器指令可能需要多个cycles instructions: 机器指令数目 branches:遇到的分支指令数 branch-misses是预测错误的分支指令数
또한 -e 매개변수를 사용하여 다음과 같이 관심 있는 이벤트를 지정할 수 있습니다.
user@localhost:~$ perf stat -e cache-misses hostname localhost Performance counter stats for 'hostname': 682 cache-misses 0.000646676 seconds time elapsed
perf top
perf top은 시스템의 현재 성능 통계를 실시간으로 표시하는 데 사용됩니다. 이전 성능 통계는 특정 프로그램을 분석하는 데 사용되며, 때로는 어떤 프로그램이 시스템 성능에 영향을 미치는지 알 수 없을 수도 있습니다. 이때 성능 상단을 사용하여 의심스러운 프로그램을 찾을 수 있습니다. 예:
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
위의 예에서는 perf가 CPU 시계 이벤트의 데이터를 계산하고 비율에 따라 정렬하는 것을 보여줍니다. perf stat와 마찬가지로 -e 매개변수를 통해 다른 이벤트의 통계를 지정할 수 있습니다. 예를 들어 perf top -e context-switches는 프로세스 스위치가 가장 많은 상위 N개 프로세스를 볼 수 있습니다.
perf 레코드 및 성능 보고서
perf 레코드는 명령을 실행하고 통계 정보를 생성할 수 있지만 perf 레코드는 결과를 표시하지 않고 결과를 파일로 출력합니다. 성능 기록에 의해 생성된 파일은 성능 보고서를 통해 구문 분석될 수 있습니다.
perf 레코드는 -g 매개변수를 사용하여 분석 중에 호출 그래프를 생성하여 더 높은 수준의 논리적 분포를 찾는 데 도움을 줄 수도 있습니다.
Others
예를 통해 성능 분석 결과의 Symbol 열에 C 언어 함수의 이름이 표시되는 것을 확인할 수 있습니다. Java의 경우 JIT 컴파일로 생성된 함수가 Java의 함수 이름 대신 기호에 직접 표시됩니다. 이때 기호를 기호와 결합하는 방법을 추가로 사용해야 합니다. Java 프로그램의 기호 테이블에 대해서는 나중에 자세히 설명합니다.
추천 학습: "linux 비디오 튜토리얼"
위 내용은 리눅스 성능이란 무엇입니까? 그것을 사용하는 방법? (사용 요약)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Apache를 시작하는 단계는 다음과 같습니다. Apache 설치 (명령 : Sudo apt-get Apache2를 설치하거나 공식 웹 사이트에서 다운로드) 시작 apache (linux : sudo systemctl start : windes (선택 사항, Linux : Sudo SystemCtl

Apache 80 포트가 점유되면 솔루션은 다음과 같습니다. 포트를 차지하고 닫는 프로세스를 찾으십시오. 방화벽 설정을 확인하여 Apache가 차단되지 않았는지 확인하십시오. 위의 방법이 작동하지 않으면 Apache를 재구성하여 다른 포트를 사용하십시오. Apache 서비스를 다시 시작하십시오.

Debian Systems에서 ReadDir 시스템 호출은 디렉토리 내용을 읽는 데 사용됩니다. 성능이 좋지 않은 경우 다음과 같은 최적화 전략을 시도해보십시오. 디렉토리 파일 수를 단순화하십시오. 대규모 디렉토리를 가능한 한 여러 소규모 디렉토리로 나누어 읽기마다 처리 된 항목 수를 줄입니다. 디렉토리 컨텐츠 캐싱 활성화 : 캐시 메커니즘을 구축하고 정기적으로 캐시를 업데이트하거나 디렉토리 컨텐츠가 변경 될 때 캐시를 업데이트하며 readDir로 자주 호출을 줄입니다. 메모리 캐시 (예 : Memcached 또는 Redis) 또는 로컬 캐시 (예 : 파일 또는 데이터베이스)를 고려할 수 있습니다. 효율적인 데이터 구조 채택 : 디렉토리 트래버스를 직접 구현하는 경우 디렉토리 정보를 저장하고 액세스하기 위해보다 효율적인 데이터 구조 (예 : 선형 검색 대신 해시 테이블)를 선택하십시오.

Apache 서버를 다시 시작하려면 다음 단계를 따르십시오. Linux/MacOS : Sudo SystemCTL 실행 Apache2를 다시 시작하십시오. Windows : Net Stop Apache2.4를 실행 한 다음 Net Start Apache2.4를 시작하십시오. Netstat -A |를 실행하십시오 서버 상태를 확인하려면 Findstr 80.

이 안내서는 데비안 시스템에서 syslog를 사용하는 방법을 배우도록 안내합니다. Syslog는 로깅 시스템 및 응용 프로그램 로그 메시지를위한 Linux 시스템의 핵심 서비스입니다. 관리자가 시스템 활동을 모니터링하고 분석하여 문제를 신속하게 식별하고 해결하는 데 도움이됩니다. 1. syslog에 대한 기본 지식 syslog의 핵심 기능에는 다음이 포함됩니다. 로그 메시지 중앙 수집 및 관리; 다중 로그 출력 형식 및 대상 위치 (예 : 파일 또는 네트워크) 지원; 실시간 로그보기 및 필터링 기능 제공. 2. Syslog 설치 및 구성 (RSYSLOG 사용) Debian 시스템은 기본적으로 RSYSLOG를 사용합니다. 다음 명령으로 설치할 수 있습니다 : sudoaptupdatesud

다음과 같은 이유로 Apache가 시작할 수 없습니다. 구성 파일 구문 오류. 다른 응용 프로그램 포트와 충돌합니다. 권한 문제. 기억이 없습니다. 프로세스 교착 상태. 데몬 실패. Selinux 권한 문제. 방화벽 문제. 소프트웨어 충돌.

인터넷은 단일 운영 체제에 의존하지 않지만 Linux는 이에 중요한 역할을합니다. Linux는 서버 및 네트워크 장치에서 널리 사용되며 안정성, 보안 및 확장 성으로 인기가 있습니다.

Apache 취약점을 수정하는 단계는 다음과 같습니다. 1. 영향을받는 버전을 결정합니다. 2. 보안 업데이트를 적용합니다. 3. Apache를 다시 시작하십시오. 4. 수정을 확인하십시오. 5. 보안 기능을 활성화합니다.
