목차
mongo服务器的配置
백엔드 개발 PHP7 xhprof를 사용하여 php7에서 PHP 성능을 테스트하는 방법은 무엇입니까? (방법 소개)

xhprof를 사용하여 php7에서 PHP 성능을 테스트하는 방법은 무엇입니까? (방법 소개)

Jul 15, 2020 pm 05:11 PM
php7 PHP 성능

xhprof를 사용하여 php7에서 PHP 성능을 테스트하는 방법은 무엇입니까? (방법 소개)

Introduction

1 배경

  • PHP의 xhprof 확장 Facebook은 더 이상 업데이트 및 유지 관리되지 않습니다. Faceboo는 HHVM을 완전히 사용하고 더 이상 PHP zend 엔진을 사용하지 않기 때문입니다.

  • xhprof는 새 버전의 PHP(PHP7)를 지원하지 않습니다.

  • tideways는 UI 서비스에 대해서만 비용을 청구합니다. 실제로 xhgui는 일상적인 요구 사항을 완벽하게 충족할 수 있습니다.

2 기능

Tideways는 PHP 성능을 테스트하는 데 사용되는 확장 프로그램입니다. PHP 실행 전 과정에서 호출되는 함수, 함수 호출 횟수, 실행 시간, CPU 시간, 메모리 사용량, 메모리 피크 값, 총 실행 시간, 총 CPU 시간, 총 메모리 사용량, 총 메모리 피크 값을 얻을 수 있습니다. 위의 데이터를 통해 PHP의 성능 병목 현상을 파악하고, PHP 실행 과정을 분석하는 등의 데이터를 분석할 수 있습니다.

3 장점

tideways는 xhgui와 결합된 PHP 확장이므로 코드를 모니터링하기 위해 PHP 코드에 코드를 묻어둘 필요가 없습니다.
  • 실행 빈도를 설정할 수 있습니다(예: 1/100), 모든 요청이 실행 로그를 생성할 때마다 수행할 필요가 없으므로 성능 손실이 발생하며 요청 매개변수를 통해 실행 로그 생성 여부를 적극적으로 제어할 수도 있습니다(debug=1)
  • 간단한 방법이 있습니다. 그리고 데이터를 변환하는 다이렉트 UI
  • 특정 인터페이스 분석, 특정 기간의 인터페이스 요청 분석 등 조건에 따라 데이터를 자유롭게 필터링할 수 있습니다.
4 단점

비록 비침해적이므로 각 인터페이스 로그에 대해 실행이 생성되면 CPU 및 메모리 소비를 무시할 수 없습니다.

5 구현 원칙

tideways 확장 프로그램은 실행 로그 생성을 담당합니다.

    nginx는 fastcgi_param PHP_VALUE auto_prepend_file로 구성되며, auto_prepend_file로 구성된 PHP 파일은 요청이 시작되기 전에 실행됩니다. Tideways 임베딩을 구현하기 위해 Tideways_disable을 호출하면 실행 로그가 mongodb 또는 mysql 또는 파일에 저장되고 xhgui로 분석된 후 표시됩니다. 표시 형식에는 히스토그램, 폭포 및 Flame 그래프가 포함됩니다.
애플리케이션

다음으로 두 가지 애플리케이션 방법을 소개합니다: Intrusive

Non-intrusive Intrusive는 코드에 코드를 추가하는 것을 의미하고 Intrusive는 기본 UI를 사용합니다. 침입적이란 코드를 변경하지 않고 nginx/apache를 변경하여 코드 삽입이 이루어짐을 의미합니다. intrusive:

git clone "https://github.com/tideways/php-xhprof-extension.git"
cd php-xhprof-extension
phpize
./configure --with-php-config=/usr/local/php7/bin/php-config
make
sudo make install
로그인 후 복사
여기서 생성된 .xhprof 파일은 tmp 디렉터리에 있으며 기본 UI도 tmp 디렉터리에서 .xhprof 파일을 검색합니다.

데이터를 찾으려면 기본 UI를 설치하세요

<?php
tideways_xhprof_enable();

// your application code

$data = tideways_xhprof_disable();
file_put_contents(
    sys_get_temp_dir() . "/" . uniqid() . ".yourapp.xhprof",
    serialize($data)
);

  // $data = tideways_xhprof_disable();
  // file_put_contents(
  //     sys_get_temp_dir() . "/" . date(&#39;His&#39;, time()) . ".material.xhprof",
  //     serialize($data)
  // );
로그인 후 복사

이 저장소에서 추적 목록을 확인하세요. 함수 호출 메모를 보려면 Callgraph를 설치해야 합니다

Install Callgraph

Callgraph는 실제로 세 가지 도구로 구성됩니다. 하나는 C 함수 호출 트리를 생성하는 데 사용되는 cflow 또는 calltree입니다. 다음은 주로 cflow를 소개합니다.

graphviz로 강화된 도트 텍스트 그래픽 언어 처리 도구입니다. xhprof_libxhprof_html目录安装到您的Web文件夹中,并导航xhprof_html/index.php

C 함수 호출 트리를 도트 형식으로 변환하는 스크립트: tree2dotx

Ubuntu를 예로 들어 각각 설치합니다.

git clone git@github.com:phacility/xhprof.git
로그인 후 복사
다음으로 기본적으로 /usr/local/bin에 설치되는 tree2dotx와 Callgraph를 설치합니다.
sudo apt-get install cflow graphviz
로그인 후 복사
다음 두 렌더링이 표시됩니다.

침투적:

xhgui를 침입적으로 사용하려면 xhgui

를 설치하려면 mongodb

가 필요합니다. reee

Nginx 구성

wget -c https://github.com/tinyclub/linux-0.11-lab/raw/master/tools/tree2dotx
wget -c https://github.com/tinyclub/linux-0.11-lab/raw/master/tools/callgraph
sudo cp tree2dotx callgraph /usr/local/bin
sudo chmod +x /usr/local/bin/{tree2dotx,callgraph}
로그인 후 복사

여기서 의미하는 바는 프로젝트 PHP 코드를 실행하기 전에 header.php를 실행하여 비침해적 탐지 성능의 목적을 달성한다는 것입니다

xhgui 구성(로그 생성 빈도)

xhgui의 구성에서 /config.default.php에서 샘플링 히트 수를 설정할 수 있습니다

return rand(1, 100) === 42; 为1%的采样率,改成return True;则标识每次都采样

&#39;profiler.enable&#39; => function() {
   // url 中包含debug=1则百分百捕获
   if(!empty($_GET['debug'])){
       return True;
   }else{
       // 1%采样
       return rand(1, 100) === 42;
   }
}
로그인 후 복사

mongodb的配置

   xhgui/config/config.default.php

// Can be either mongodb or file.
   /*
   'save.handler' => 'file',
   'save.handler.filename' => dirname(__DIR__) . '/cache/' . 'xhgui.data.' . microtime(true) . '_' . substr(md5($url), 0, 6),
   */
   'save.handler' => 'mongodb',
   // Needed for file save handler. Beware of file locking. You can adujst this file path
   // to reduce locking problems (eg uniqid, time ...)
   //'save.handler.filename' => __DIR__.'/../data/xhgui_'.date('Ymd').'.dat',
   'db.host' => 'mongodb://127.0.0.1:27017',
   'db.db' => 'xhprof',
로그인 후 복사

mongo服务器的配置

mongo
 > use xhprof
 > db.results.ensureIndex( { 'meta.SERVER.REQUEST_TIME' : -1 } )
 > db.results.ensureIndex( { 'profile.main().wt' : -1 } )
 > db.results.ensureIndex( { 'profile.main().mu' : -1 } )
 > db.results.ensureIndex( { 'profile.main().cpu' : -1 } )
 > db.results.ensureIndex( { 'meta.url' : 1 } )
로그인 후 복사

最后展示几张xhgui的效果图

 

 

 

 相关学习推荐:PHP编程从入门到精通

위 내용은 xhprof를 사용하여 php7에서 PHP 성능을 테스트하는 방법은 무엇입니까? (방법 소개)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

php7에서 tcp 포트가 작동하지 않는 것을 감지했을 때 문제를 해결하는 방법 php7에서 tcp 포트가 작동하지 않는 것을 감지했을 때 문제를 해결하는 방법 Mar 22, 2023 am 09:30 AM

php5에서는 fsockopen() 함수를 사용하여 TCP 포트를 감지할 수 있습니다. 이 기능은 네트워크 연결을 열고 일부 네트워크 통신을 수행하는 데 사용할 수 있습니다. 그러나 php7에서는 fsockopen() 함수에 포트를 열 수 없거나 서버에 연결할 수 없는 등의 몇 가지 문제가 발생할 수 있습니다. 이 문제를 해결하기 위해, 우리는 소켓_create() 함수와 소켓_연결() 함수를 사용하여 TCP 포트를 감지할 수 있습니다.

php7.0에 플러그인이 설치되어 있는데 여전히 설치되지 않은 것으로 표시되면 어떻게 해야 합니까? php7.0에 플러그인이 설치되어 있는데 여전히 설치되지 않은 것으로 표시되면 어떻게 해야 합니까? Apr 02, 2024 pm 07:39 PM

PHP 7.0에서 설치된 플러그인이 표시되지 않는 문제를 해결하려면: 플러그인 구성을 확인하고 플러그인을 활성화하세요. 구성 변경 사항을 적용하려면 PHP를 다시 시작하세요. 플러그인 파일 권한이 올바른지 확인하세요. 플러그인이 올바르게 작동하도록 하려면 누락된 종속성을 설치하세요. 다른 모든 단계가 실패하면 PHP를 다시 빌드하세요. 다른 가능한 원인으로는 호환되지 않는 플러그인 버전, 잘못된 버전 로드 또는 PHP 구성 문제 등이 있습니다.

php7.0에 mongo 확장을 설치하는 방법 php7.0에 mongo 확장을 설치하는 방법 Nov 21, 2022 am 10:25 AM

php7.0에서 mongo 확장을 설치하는 방법: 1. mongodb 사용자 그룹 및 사용자를 생성합니다. 2. mongodb 소스 코드 패키지를 다운로드하고 소스 코드 패키지를 "/usr/local/src/" 디렉터리에 넣습니다. "src/" 디렉터리를 입력합니다. 4. 소스 코드 패키지의 압축을 풉니다. 5. mongodb 파일 디렉터리를 생성합니다. 6. "mongodb/" 디렉터리에 파일을 복사합니다. 7. mongodb 구성 파일을 생성하고 구성을 수정합니다.

성능 분석 및 튜닝에 PHP를 사용하는 방법 성능 분석 및 튜닝에 PHP를 사용하는 방법 Jun 06, 2023 pm 01:21 PM

널리 사용되는 서버측 언어인 PHP는 웹사이트 개발 및 운영에 중요한 역할을 합니다. 그러나 PHP 코드의 양이 계속 증가하고 애플리케이션의 복잡성이 증가함에 따라 성능 병목 현상이 발생할 가능성이 점점 더 커지고 있습니다. 이러한 문제를 방지하기 위해서는 성능 분석과 튜닝이 필요합니다. 이 기사에서는 성능 분석 및 조정에 PHP를 사용하여 애플리케이션에 보다 효율적인 실행 환경을 제공하는 방법을 간략하게 소개합니다. 1. PHP 성능 분석 도구 1.XdebugXdebug는 널리 사용되는 코드 분석 도구입니다.

PHP 서버 환경 FAQ 가이드: 일반적인 문제를 신속하게 해결 PHP 서버 환경 FAQ 가이드: 일반적인 문제를 신속하게 해결 Apr 09, 2024 pm 01:33 PM

PHP 서버 환경에 대한 일반적인 솔루션에는 올바른 PHP 버전이 설치되어 있는지, 관련 파일이 모듈 디렉터리에 복사되었는지 확인하는 것이 포함됩니다. SELinux를 일시적으로 또는 영구적으로 비활성화합니다. 필요한 확장이 추가되고 올바르게 설정되었는지 확인하려면 PHP.ini를 확인하고 구성하십시오. PHP-FPM 서비스를 시작하거나 다시 시작합니다. 해결 문제에 대해서는 DNS 설정을 확인하세요.

php7.0을 설치하고 배포하는 방법 php7.0을 설치하고 배포하는 방법 Nov 30, 2022 am 09:56 AM

php7.0 설치 및 배포 방법: 1. PHP 공식 웹사이트로 이동하여 로컬 시스템에 해당하는 설치 버전을 다운로드합니다. 2. 다운로드한 zip 파일을 지정된 디렉터리에 추출합니다. 3. 명령줄 창을 열고 다음으로 이동합니다. "E:\php7" 디렉토리 "php -v" 명령을 실행하세요.

시스템 재시작 후 UnixSocket의 권한을 자동으로 설정하는 방법은 무엇입니까? 시스템 재시작 후 UnixSocket의 권한을 자동으로 설정하는 방법은 무엇입니까? Mar 31, 2025 pm 11:54 PM

시스템이 다시 시작된 후 UnixSocket의 권한을 자동으로 설정하는 방법. 시스템이 다시 시작될 때마다 UnixSocket의 권한을 수정하려면 다음 명령을 실행해야합니다.

php8과 php7 중 어느 것이 더 낫나요? php8과 php7 중 어느 것이 더 낫나요? Nov 16, 2023 pm 03:09 PM

PHP7과 비교하여 PHP8은 성능, 새로운 기능 및 구문 개선, 유형 시스템, 오류 처리 및 확장 측면에서 몇 가지 장점과 개선 사항을 가지고 있습니다. 그러나 사용할 버전을 선택하는 것은 특정 요구 사항과 프로젝트 상황에 따라 다릅니다. 자세한 소개: 1. 성능 향상, PHP8은 코드 실행 속도를 향상시킬 수 있는 JIT(Just-in-Time) 컴파일러를 도입합니다. 2. 새로운 기능 및 구문 개선, PHP8은 명명된 매개 변수 및 선택적 매개 변수 선언을 지원합니다. 함수 만들기 호출이 더 유연해졌습니다. 익명 클래스, 속성 유형 선언 등이 도입되었습니다.

See all articles