成人无码视频,亚洲精品久久久久av无码,午夜精品久久久久久毛片,亚洲 中文字幕 日韩 无码

資訊專欄INFORMATION COLUMN

使用phpAnalysis打造PHP應(yīng)用非侵入式性能分析器

BDEEFE / 855人閱讀

使用phpAnalysis打造PHP應(yīng)用非侵入式性能分析器,查找PHP性能瓶頸。

什么是phpAnalysis

phpAnalysis是一款輕量級(jí)非侵入式PHP應(yīng)用性能分析器,適用于開(kāi)發(fā)、測(cè)試及生產(chǎn)環(huán)境部署使用,方便開(kāi)發(fā)及測(cè)試工程師診斷性能問(wèn)題:

通過(guò)tideways收集PHP程序單步運(yùn)行過(guò)程中所有的函數(shù)調(diào)用時(shí)間及CPU內(nèi)存消耗等信息

信息永久存儲(chǔ)到MySQL數(shù)據(jù)庫(kù)

分析每個(gè)請(qǐng)求執(zhí)行的信息,幫助開(kāi)發(fā)測(cè)試人員快速定位性能問(wèn)題

非侵入式,不需修改項(xiàng)目PHP代碼

被動(dòng)分析器,對(duì)性能的影響最小,同時(shí)收集足夠的信息用于診斷性能問(wèn)題

當(dāng)我們發(fā)現(xiàn)生產(chǎn)環(huán)境的某個(gè)接口執(zhí)行時(shí)間特別長(zhǎng)時(shí)應(yīng)該怎么做?
直接登錄線上機(jī)器單步調(diào)試?
打大量的log然后分析?

一般我們可以把分析流程拆分為如下幾步操作:

分析開(kāi)發(fā)/測(cè)試環(huán)境下執(zhí)行是否會(huì)慢

分析預(yù)發(fā)/Mirror環(huán)境執(zhí)行是否會(huì)慢

生產(chǎn)環(huán)境分析代碼執(zhí)行慢的原因

1,2,3步驟都需要去分析代碼,看哪部分執(zhí)行時(shí)間長(zhǎng)。如果人工一行代碼去排查,需要消耗大量的開(kāi)發(fā)人員的時(shí)間并且定位難度很大,于此,phpAnalysis誕生了 :)

安裝 準(zhǔn)備

依賴的PHP擴(kuò)展:tideaways, PDO, pdo_mysql, zlib

PHP版本>= 5.4.0

安裝phpAnalysis

下載源代碼

cd /home/www
git clone https://github.com/dreamans/phpAnalysis.git
cd phpAnalysis

修改配置文件

文件位置:/home/www/phpAnalysis/config/database.php
修改數(shù)據(jù)庫(kù)鏈接信息
數(shù)據(jù)庫(kù)需要自己創(chuàng)建
建表語(yǔ)句請(qǐng)見(jiàn)install.sql

return [

    "connection" => [

        "host" => "127.0.0.1", // 數(shù)據(jù)庫(kù)主機(jī)名

        "port" => 3306, // 數(shù)據(jù)庫(kù)端口號(hào)

        "user" => "root", // 用戶名

        "pass" => "root", // 密碼

        "db" => "phpAnalysis", // 數(shù)據(jù)庫(kù)名

        "tb_prefix" => "pa_",  // 表前綴
    ],
];

修改Web Server配置,以Nginx為例

server {
    listen       8000;
    server_name  localhost;
    root  /home/www/phpAnalysis/public;
    index index.html;

    location ~ .php$ {
        fastcgi_pass   127.0.0.1:9000;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME $document_root$fastcgi_script_name;
        include        fastcgi_params;
    }
}

修改php.ini

; 告訴PHP程序在執(zhí)行前首先調(diào)用此文件
auto_prepend_file = /home/www/phpAnalysis/agent/header.php
[tideways]
extension=tideways.so
;不需要自動(dòng)加載,在程序中控制就行
tideways.auto_prepend_library=0
;頻率設(shè)置為100,在程序調(diào)用時(shí)能改
tideways.sample_rate=100

重啟php-fpm進(jìn)程

如果安裝順利,此時(shí)訪問(wèn) http://localhost:8000 能看到效果

預(yù)覽

請(qǐng)求列表

支持按應(yīng)用實(shí)例名稱、請(qǐng)求時(shí)段、url模糊查詢篩選列表

請(qǐng)求執(zhí)行基本信息

請(qǐng)求攜帶的數(shù)據(jù)

調(diào)用明細(xì)

說(shuō)明

項(xiàng)目處于開(kāi)發(fā)階段,權(quán)限控制未完成且未做性能優(yōu)化,請(qǐng)勿在生產(chǎn)環(huán)境中部署,感謝支持!

對(duì)項(xiàng)目有任何意見(jiàn)建議請(qǐng)?zhí)醝ssue https://github.com/dreamans/p...

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.hztianpu.com/yun/28213.html

相關(guān)文章

  • Tideways、xhprof 和 xhgui 打造 PHP 侵入監(jiān)控平臺(tái)

    摘要:參考配置添加,告訴程序在執(zhí)行前要調(diào)用的服務(wù)或者也可以在修改配置文件,告訴程序在執(zhí)行前要調(diào)用的服務(wù)參考鏈接 showImg(https://segmentfault.com/img/bVbt7t1?w=2880&h=2608); 推薦閱讀 Tideways、xhprof 和 xhgui 打造 PHP 非侵入式監(jiān)控平臺(tái) 超全的設(shè)計(jì)模式簡(jiǎn)介(45種) design-patterns-for...

    shevy 評(píng)論0 收藏0
  • Tideways、xhprof 和 xhgui 打造 PHP 侵入監(jiān)控平臺(tái)

    摘要:參考配置添加,告訴程序在執(zhí)行前要調(diào)用的服務(wù)或者也可以在修改配置文件,告訴程序在執(zhí)行前要調(diào)用的服務(wù)參考鏈接 showImg(https://segmentfault.com/img/bVbt7t1?w=2880&h=2608); 推薦閱讀 Tideways、xhprof 和 xhgui 打造 PHP 非侵入式監(jiān)控平臺(tái) 超全的設(shè)計(jì)模式簡(jiǎn)介(45種) design-patterns-for...

    Cympros 評(píng)論0 收藏0
  • Docker的LNMP一鍵安裝開(kāi)發(fā)環(huán)境 + PHP侵入監(jiān)控平臺(tái)xhgui(優(yōu)化系統(tǒng)性能、定位Bu

    摘要:的一鍵安裝開(kāi)發(fā)環(huán)境非侵入式監(jiān)控平臺(tái)優(yōu)化系統(tǒng)性能定位的神器之前在用做本地開(kāi)發(fā)環(huán)境,因?yàn)闆](méi)有這些對(duì)程序性能追蹤及分析的工具,所以索性基于的編排了一套自己使用。 DNMP PLUS dnmp = Docker + Nginx + MySQL + PHP + Redis + MongDB plus = xhgui + xhprof + tideways dnmp-plus = PHPer 的一...

    AlanKeene 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

閱讀需要支付1元查看
<