亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > PHP > 正文

xhprof php7問題

2019-11-06 08:03:20
字體:
來源:轉載
供稿:網友

xhPRof php7問題

xhprof 是facebook 開發的一個測試php性能的擴展,

現存的問題

xhprof不支持php7,代碼已經幾年沒有更新過了, 由于Facebook的優化方向是HHVM,所以這個擴展可以預見不會再有官方維護了。

目前github上有一些個人維護的php7版本, 但是完成的質量都不高,存在各種坑,很不幸我們踩了一個: 內存泄漏

內存泄漏

test環境之前安裝的版本: https://github.com/RustJason/xhprof/tree/php7

之前用著一直好好的, 一經壓測就完蛋了,原因就是內存泄漏。

用valgrind檢測結果, 摘抄部分如下:

==19323== 32 bytes in 1 blocks are definitely lost in loss record 10 of 30==19323== at 0x4C2210C: malloc (vg_replace_malloc.c:195)==19323== by 0x7F76AA: __zend_malloc (zend_alloc.c:2853)==19323== by 0xA5B9534: zend_string_alloc (zend_string.h:121)==19323== by 0xA5B94DB: zend_string_init (zend_string.h:157)==19323== by 0xA5B9E3F: hp_begin (xhprof.c:1688)==19323== by 0xA5B7D4D: zif_xhprof_enable (xhprof.c:403)==19323== by 0xA5B9B68: hp_execute_internal (xhprof.c:1586)==19323== by 0x883CFC: ZEND_DO_FCALL_SPEC_HANDLER (zend_vm_execute.h:844)==19323== by 0x882A30: execute_ex (zend_vm_execute.h:417)==19323== by 0xA5B980C: hp_execute_ex (xhprof.c:1527)==19323== by 0x882B47: zend_execute (zend_vm_execute.h:458)==19323== by 0x82A134: zend_execute_scripts (zend.c:1427)...................等等...................==19323== LEAK SUMMARY:==19323== definitely lost: 192 bytes in 6 blocks==19323== indirectly lost: 0 bytes in 0 blocks==19323== possibly lost: 0 bytes in 0 blocks==19323== still reachable: 2,633 bytes in 26 blocks==19323== suppressed: 0 bytes in 0 blocks==19323== Reachable blocks (those to which a pointer was found) are not shown.==19323== To see them, rerun with: --leak-check=full --show-reachable=yes

可以看到明顯有內存泄漏: definitely lost: 192 bytes in 6 blocks 從上面的日志可以看出問題所在的調用棧:

xhprof_enable() -> hp_begin() -> zend_string_init() -> zend_string_alloc() -> __zend_malloc() -> malloc()

對著擴展的源碼找一下問題出在哪:

static void hp_begin(long level, long xhprof_flags TSRMLS_DC) { ................something..................... BEGIN_PROFILING(&hp_globals.entries, zend_string_init(ROOT_SYMBOL, sizeof(ROOT_SYMBOL) - 1, 1), hp_profile_flag); return; ..............................

這塊申請了內存, 但是并沒有進行釋放!看了下代碼這個問題有些復雜, 下面這個結構體是一個全局變量保存了所有php函數的調用棧, 以及每個函數用的時間、cpu使用等信息。zend_string 是用來保存函數名的,就是這一塊的內存發生了泄漏。由于這是一個全局變量, 整體代碼中這個結構體耦合非常高, 改起來不容易。

typedef struct hp_entry_t { zend_string *name_hprof; /* function name */ int rlvl_hprof; /* recursion level for function */ uint64 tsc_start; /* start value for TSC counter */ long int mu_start_hprof; /* memory usage */ long int pmu_start_hprof; /* peak memory usage */ struct rusage ru_start_hprof; /* user/sys time start */ struct hp_entry_t *prev_hprof; /* ptr to prev entry being profiled */ uint8 hash_code; /* hash_code for the function name */

而且,這個版本完成的質量不高,其作者也在readme中提到” Please do not use this in an production env.生產環境勿用。代碼簡直沒法看。

所以我放棄直接修復這個版本的bug, 而選擇尋找其他方案

解決辦法

在嘗試解決問題的時候發現了一個擴展Tideways, 這是基于xhprof的二次開發版本,是一整套解決方案(包括xhprof,以及性能分析的圖形化界面等等)。需要注意的是這是一個這是一個商業版本, 其中圖形化性能分析工具是收費的, xhprof功能是免費的, 對我們來說已經夠用了。

測試了一下:

用法與xhprof一樣,功能沒有問題,滿足我們需求valgrind檢測無內存泄漏壓測內存未見異常。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
疯狂做受xxxx欧美肥白少妇| 亚洲小视频在线| 欧美激情视频三区| 亚洲福利视频在线| 日韩中文字幕第一页| 亚洲欧美日韩天堂一区二区| 97福利一区二区| 成人美女免费网站视频| 欧美激情在线观看视频| 91国内产香蕉| 91九色综合久久| 亚洲影院色在线观看免费| 一个人看的www欧美| 日本不卡视频在线播放| 午夜精品一区二区三区在线视频| 成人精品福利视频| 26uuu国产精品视频| 日本最新高清不卡中文字幕| 亚洲午夜精品久久久久久性色| 久久这里只有精品99| 欧美激情第99页| 成人精品aaaa网站| 国产69精品久久久久9| 最近2019中文免费高清视频观看www99| 色综合色综合网色综合| 国产99视频在线观看| 91人成网站www| 亚洲欧美一区二区激情| 亚洲午夜精品久久久久久性色| 91九色单男在线观看| 4444欧美成人kkkk| 国产美女扒开尿口久久久| 国产欧美久久久久久| 北条麻妃一区二区在线观看| 亚洲国产精品福利| 久久精品国产99国产精品澳门| 97超级碰碰人国产在线观看| 亚洲精品日韩av| 久青草国产97香蕉在线视频| 久久久久久欧美| 国产精品观看在线亚洲人成网| 国产精品综合网站| 亚洲伊人第一页| 亚洲free性xxxx护士hd| 亚洲第一视频网| 韩国国内大量揄拍精品视频| 国产午夜精品理论片a级探花| 91啪国产在线| 久久九九全国免费精品观看| 欧美疯狂性受xxxxx另类| 91av在线播放视频| 97精品久久久| 热久久这里只有精品| 国产日本欧美一区二区三区在线| 青草青草久热精品视频在线网站| 成人日韩av在线| 日韩国产中文字幕| 亚洲图片在区色| 91精品视频在线免费观看| 精品国产自在精品国产浪潮| 亚洲欧洲成视频免费观看| 久久成人18免费网站| 欧美三级xxx| 日韩在线观看免费全集电视剧网站| 欧美日韩激情小视频| 黑人巨大精品欧美一区二区免费| 97国产真实伦对白精彩视频8| 欧美精品一区三区| 精品国产乱码久久久久久虫虫漫画| 欧美野外猛男的大粗鳮| 国产成人精品a视频一区www| 91精品久久久久久综合乱菊| 92国产精品久久久久首页| 久久久久久一区二区三区| 国产91成人video| 成人亚洲欧美一区二区三区| 欧美日韩裸体免费视频| 国产日韩欧美91| 91网站免费看| 国产精品嫩草视频| 2019亚洲男人天堂| 亚洲综合小说区| 成人有码视频在线播放| 日韩在线视频国产| 亚洲激情小视频| 欧美重口另类videos人妖| 久久久久北条麻妃免费看| 亚洲视频在线看| 欧美老少配视频| 国产免费一区视频观看免费| 欧美精品生活片| 色综合久久精品亚洲国产| 中文字幕一区二区三区电影| 欧美成人激情视频| 欧美国产亚洲视频| 精品亚洲国产成av人片传媒| 日韩有码视频在线| 久久深夜福利免费观看| 亚洲免费一在线| 国内精品久久久久影院优| 按摩亚洲人久久| 国产mv免费观看入口亚洲| 亚洲福利在线播放| 日韩中文字幕av| 欧美黄色片在线观看| 国产精品香蕉国产| 2019中文字幕免费视频| 18一19gay欧美视频网站| 国产suv精品一区二区三区88区| 成人免费观看a| 欧美在线欧美在线| 91精品国产一区| 性欧美长视频免费观看不卡| 午夜精品久久久久久久白皮肤| 亚洲第一精品久久忘忧草社区| 91色琪琪电影亚洲精品久久| 成人在线视频网| 久久精品亚洲热| 欧美国产亚洲精品久久久8v| 久久久久国产精品免费网站| 日韩福利在线播放| 精品久久久久久亚洲精品| 国产亚洲欧美aaaa| 日韩欧美在线视频免费观看| 亚洲欧美一区二区三区情侣bbw| 亚洲欧美日韩久久久久久| 激情亚洲一区二区三区四区| 精品福利樱桃av导航| 在线精品播放av| 亚洲国产精品成人精品| 中文字幕在线看视频国产欧美在线看完整| 最近的2019中文字幕免费一页| 国产999精品久久久影片官网| 亚洲欧美国产日韩中文字幕| 欧美激情aaaa| 另类视频在线观看| 国产精品91久久久久久| 亚洲福利影片在线| 久久精品视频在线观看| 亚洲欧美国内爽妇网| 中文字幕精品一区久久久久| 国产在线精品自拍| 69久久夜色精品国产7777| 国产伦精品一区二区三区精品视频| 亚洲精品国产免费| 日韩精品在线私人| 色老头一区二区三区| 中文字幕欧美在线| 久久久久久久久久久免费| 国产成人精品一区| 正在播放欧美一区| 91av在线播放| 久久国产精品亚洲| 在线视频欧美性高潮| 日韩欧美亚洲一二三区| 91精品久久久久久久久久久久久| 国产精品爽爽爽爽爽爽在线观看| 久久精品电影网| 久久久久久久亚洲精品| 国产亚洲一区二区在线| 国产欧美久久一区二区| 久久精品视频va| 久久精品99无色码中文字幕| 亚洲精品视频二区|