xhprof를 사용하여 php7에서 PHP 성능을 테스트하는 방법은 무엇입니까? (방법 소개)
Introduction
1 배경
PHP의 xhprof 확장 Facebook은 더 이상 업데이트 및 유지 관리되지 않습니다. Faceboo는 HHVM을 완전히 사용하고 더 이상 PHP zend 엔진을 사용하지 않기 때문입니다.
xhprof는 새 버전의 PHP(PHP7)를 지원하지 않습니다.
tideways는 UI 서비스에 대해서만 비용을 청구합니다. 실제로 xhgui는 일상적인 요구 사항을 완벽하게 충족할 수 있습니다.
Tideways는 PHP 성능을 테스트하는 데 사용되는 확장 프로그램입니다. PHP 실행 전 과정에서 호출되는 함수, 함수 호출 횟수, 실행 시간, CPU 시간, 메모리 사용량, 메모리 피크 값, 총 실행 시간, 총 CPU 시간, 총 메모리 사용량, 총 메모리 피크 값을 얻을 수 있습니다. 위의 데이터를 통해 PHP의 성능 병목 현상을 파악하고, PHP 실행 과정을 분석하는 등의 데이터를 분석할 수 있습니다.
3 장점tideways는 xhgui와 결합된 PHP 확장이므로 코드를 모니터링하기 위해 PHP 코드에 코드를 묻어둘 필요가 없습니다.
- 실행 빈도를 설정할 수 있습니다(예: 1/100), 모든 요청이 실행 로그를 생성할 때마다 수행할 필요가 없으므로 성능 손실이 발생하며 요청 매개변수를 통해 실행 로그 생성 여부를 적극적으로 제어할 수도 있습니다(debug=1)
- 간단한 방법이 있습니다. 그리고 데이터를 변환하는 다이렉트 UI
- 특정 인터페이스 분석, 특정 기간의 인터페이스 요청 분석 등 조건에 따라 데이터를 자유롭게 필터링할 수 있습니다.
비록 비침해적이므로 각 인터페이스 로그에 대해 실행이 생성되면 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
데이터를 찾으려면 기본 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('His', time()) . ".material.xhprof", // serialize($data) // );
이 저장소에서 추적 목록을 확인하세요. 함수 호출 메모를 보려면 Callgraph를 설치해야 합니다
Install Callgraph
Callgraph는 실제로 세 가지 도구로 구성됩니다. 하나는 C 함수 호출 트리를 생성하는 데 사용되는 cflow 또는 calltree입니다. 다음은 주로 cflow를 소개합니다.
graphviz로 강화된 도트 텍스트 그래픽 언어 처리 도구입니다. xhprof_lib
和xhprof_html
目录安装到您的Web文件夹中,并导航xhprof_html/index.php
git clone git@github.com:phacility/xhprof.git
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}
xhgui 구성(로그 생성 빈도)
xhgui의 구성에서 /config.default.php에서 샘플링 히트 수를 설정할 수 있습니다return rand(1, 100) === 42; 为1%的采样率,改成return True;则标识每次都采样
'profiler.enable' => 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 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)

뜨거운 주제











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

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

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

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

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

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

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

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