一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

電子發(fā)燒友App

硬聲App

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>電子資料>Deliverer PHP項目調(diào)度追蹤工具

Deliverer PHP項目調(diào)度追蹤工具

2022-06-30 | zip | 0.02 MB | 次下載 | 免費

資料介紹

授權(quán)協(xié)議 GPL
開發(fā)語言 PHP
軟件類型 開源軟件

軟件簡介

Deliverer 是一個 PHP 項目調(diào)度追蹤工具,主要用于線上故障排查。

使用場景

  1. 如果你有一些老的 PHP (PHP5 和 PHP7)項目,對線上一個項目運行邏輯不熟悉;
  2. 或者你對某個方法的調(diào)用來源不清楚;
  3. 又或者線上有一個接口不知道是哪里異常退出了;
  4. 還有線上調(diào)用特別耗時,都比較適合使用 Deliverer 來解決,幫助你避免跑路。

使用方法

  • 可以根據(jù)函數(shù)名、類名、方法名、路由來過濾輸出
  • 可以在查詢到指定過濾內(nèi)容 n 次之后退出
  • 可以根據(jù) request id 回放細看整個完整的調(diào)用鏈
  • 過濾的內(nèi)容會高亮顯示
  • 調(diào)用棧比較深的可以指定 -l 來隱藏深度調(diào)用的展示

原理

其實比較簡單,分兩步,第一步收集日志,第二步分析日志。

第一步

PHP_MINIT階段,通過zend_set_user_opcode_handler?來設(shè)置對?ZEND_DO_UCALL?、ZEND_DO_FCALL_BY_NAMEZEND_DO_FCALL?三類?opcode?的處理分析。

注意其中會涵蓋一些內(nèi)置函數(shù)和方法的調(diào)用,我們可以通過類型進行過濾。

然后在PHP_RINIT階段新建日志文件,寫入請求的信息

pid-ts sapi http_method http_url

請求過程中在自定義的 handler 里面打印調(diào)用棧信息

最后在PHP_RSHUTDOWN關(guān)閉日志文件的寫入

第二步

對收集好的日志,利用bin/deliverer進行分析和整理,這塊是 php 腳本,就不贅述了。

安裝使用

下載

$ sudo wget http://github.com/zhoumengkang/deliverer/archive/refs/tags/1.0.4.zip
$ unzip 1.0.4.zip
$ rm -f 1.0.4.zip
$ cd deliverer-1.0.4/extension

編譯

$ whereis phpize
phpize: /usr/bin/phpize /usr/share/man/man1/phpize.1.gz

# 如果前面的路徑(/usr/bin)在環(huán)境變量里,也可以簡寫為 phpize,如果不太懂,直接復(fù)制執(zhí)行
$ /usr/bin/phpize

$ whereis php-config
php-config: /usr/bin/php-config /usr/share/man/man1/php-config.1.gz

$ ./configure --with-php-config=/usr/bin/php-config
$ make && sudo make install

配置 php.ini

$ php -i|grep php.ini
Configuration File (php.ini) Path => /etc
Loaded Configuration File => /etc/php.ini

# 編輯 /etc/php.ini 文件
$ sudo vim /etc/php.ini
# 文件末尾增加以下兩行
[deliverer]
extension=deliverer.so

重啟 php-fpm

sudo service php-fpm restart

使用分析工具

可以移動./bin/deliverer到你覺得合適的目錄,假如在當前目錄

# 回到文件的解壓目錄,開啟監(jiān)聽
$ cd ..
$ ./bin/deliverer -t

用一段我自己很久之前的祖?zhèn)鞔a(我的博客)來跑下

$ ./bin/deliverer -t

這樣會一直監(jiān)控所有的 php 進程的執(zhí)行

poYBAGK5rfGAEgTaAAoOtd0DHFU186.jpg

$ ./bin/deliverer -tAction::initUser -n3 -l5

pYYBAGK5rfOAY_UyAAP_oSUXyC0167.jpg
pYYBAGK5rfWAN8uBAAm7xtb5VLk160.jpg

參數(shù) 解釋
-t Action::initUser 過濾包含該調(diào)用的請求
-n 3 統(tǒng)計三次然后退出
-l 5 函數(shù)(方法)調(diào)用深度顯示,最多顯示 5 層,超出部分在末尾標出
$ ./bin/deliverer -v7979-1624369150991941

通過?-v?requestId?來詳細查看完整調(diào)用棧

poYBAGK5rfeAeIKcAAPcI9q_wqw563.jpg

$ ./bin/deliverer -tSqlExecute::getAll -n1 -l3

當要查詢方法,函數(shù)調(diào)用棧過深,不在層級查詢范圍之內(nèi),則其外層調(diào)用顯示紅色

pYYBAGK5rfmAfkA0AALExGAE_70855.jpg

?

下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1DD3118電路圖紙資料
  2. 0.08 MB   |  1次下載  |  免費
  3. 2AD庫封裝庫安裝教程
  4. 0.49 MB   |  1次下載  |  免費
  5. 3PC6206 300mA低功耗低壓差線性穩(wěn)壓器中文資料
  6. 1.12 MB   |  1次下載  |  免費
  7. 4網(wǎng)絡(luò)安全從業(yè)者入門指南
  8. 2.91 MB   |  1次下載  |  免費
  9. 5DS-CS3A P00-CN-V3
  10. 618.05 KB  |  1次下載  |  免費
  11. 6海川SM5701規(guī)格書
  12. 1.48 MB  |  次下載  |  免費
  13. 7H20PR5電磁爐IGBT功率管規(guī)格書
  14. 1.68 MB   |  次下載  |  1 積分
  15. 8IP防護等級說明
  16. 0.08 MB   |  次下載  |  免費

本月

  1. 1貼片三極管上的印字與真實名稱的對照表詳細說明
  2. 0.50 MB   |  103次下載  |  1 積分
  3. 2涂鴉各WiFi模塊原理圖加PCB封裝
  4. 11.75 MB   |  89次下載  |  1 積分
  5. 3錦銳科技CA51F2 SDK開發(fā)包
  6. 24.06 MB   |  43次下載  |  1 積分
  7. 4錦銳CA51F005 SDK開發(fā)包
  8. 19.47 MB   |  19次下載  |  1 積分
  9. 5PCB的EMC設(shè)計指南
  10. 2.47 MB   |  16次下載  |  1 積分
  11. 6HC05藍牙原理圖加PCB
  12. 15.76 MB   |  13次下載  |  1 積分
  13. 7802.11_Wireless_Networks
  14. 4.17 MB   |  12次下載  |  免費
  15. 8蘋果iphone 11電路原理圖
  16. 4.98 MB   |  6次下載  |  2 積分

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935127次下載  |  10 積分
  3. 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計
  4. 1.48MB  |  420064次下載  |  10 積分
  5. 3Altium DXP2002下載入口
  6. 未知  |  233089次下載  |  10 積分
  7. 4電路仿真軟件multisim 10.0免費下載
  8. 340992  |  191390次下載  |  10 積分
  9. 5十天學(xué)會AVR單片機與C語言視頻教程 下載
  10. 158M  |  183342次下載  |  10 積分
  11. 6labview8.5下載
  12. 未知  |  81588次下載  |  10 積分
  13. 7Keil工具MDK-Arm免費下載
  14. 0.02 MB  |  73815次下載  |  10 積分
  15. 8LabVIEW 8.6下載
  16. 未知  |  65989次下載  |  10 積分