ホームページ  >  記事  >  バックエンド開発  >  gdb を使用した PHP 拡張機能のデバッグ

gdb を使用した PHP 拡張機能のデバッグ

WBOY
WBOYオリジナル
2016-06-20 12:56:121278ブラウズ

出典: http://www.codefrom.com/paper/%E4%BD%BF%E7%94%A8gdb%E8%B0%83%E8%AF%95p...

PHP 拡張機能は c/c++ を使用して開発され、gdb を使用して簡単にデバッグできます。具体的な手順は次のとおりです。
まず、php をコンパイルするときに ** --enable-debug** パラメータを追加する必要があります

./configure --enable-debugmake && make install

私の ubuntu マシンでテストしたところ、拡張ディレクトリはデフォルトになっています/usr/ local/lib/php/extensions/debug-non-zts-20131226/
これは、PHP ソース コードをデバッグする場合にも非常に便利です。
次のステップは拡張機能を作成することです。PHP ソース コードの ext ディレクトリに入り、

./ext_skel --extname=mydebug  

を実行します。mydebug ディレクトリが現在のディレクトリに自動的に生成されます。ディレクトリに入り、 config.m4 ファイルを編集し、次のように 10 ~ 12 行の dnl を削除します

PHP_ARG_WITH(mydebug, for mydebug support,Make sure that the comment is aligned:[  --with-mydebug             Include mydebug support])

最後の行に

if test -z "$PHP_DEBUG"; then        AC_ARG_ENABLE(debug,                [--enable-debg  compile with debugging system],                [PHP_DEBUG=$enableval], [PHP_DEBUG=no]        )fi

を追加しますこれは、拡張機能をデバッグできることを意味します。拡張機能をコンパイルするには、コマンド

phpize ./configure --enable-debugmake && make install

を使用します。ここで、phpize と php-config は事前に環境変数を設定してから、拡張機能をロードする必要があります。私のマシンのアドレスは /usr/local/lib/php/extensions/debug-non-zts-20131226/ です。 mydebug 拡張ソース コード ディレクトリを入力します。デフォルトで生成される関数はconfirm_mydebug_compiled で、mydebug.c で定義され、自動生成される関数を拡張します。

PHP_FUNCTION(confirm_mydebug_compiled){        char *arg = NULL;        int arg_len, len;        char *strg;        if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &arg, &arg_len) == FAILURE) {                return;        }        len = spprintf(&strg, 0, "Congratulations! You have successfully modified ext/%.78s/config.m4. Module %.78s is now compiled into PHP.", "mydebug", arg);        RETURN_STRINGL(strg, len, 0);}

おそらく、文字列パラメーターを取得し、それを文字列に綴って返すことを意味します。 nm コマンドを使用して、生成された mydebug.so によってエクスポートされたシンボルを表示します。

运行 nm mydebug.so返回 zif_confirm_mydebug_compiled    ……

PHP_FUNCTION は実際には関数名の前に zif_ を追加し、gdb デバッグを実行します

第一步运行: gdb php然后运行: break  zif_confirm_mydebug_compiled终端提示:Function "zif_confirm_mydebug_compiled" not defined.Make breakpoint pending on future shared library load? (y or [n]) 输入: y输入:  run /tmp/test.php此时会回显:Breakpoint 1, zif_confirm_mydebug_compiled (ht=1, return_value=0xb7bf0d44, return_value_ptr=0xb7bd6104, this_ptr=0x0, return_value_used=1)    at /...../php-5.6.6/ext/mydebug/mydebug.c:56然后输入: l显示:54      PHP_FUNCTION(confirm_mydebug_compiled)55      {56              char *arg = NULL;57              int arg_len, len;58              char *strg;5960              if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &arg, &arg_len) == FAILURE) {

ファイル /tmp/test.php の内容は次のとおりです:

<?phpecho confirm_mydebug_compiled("hello world");

ご覧のとおり、関数のソース コードが公開されており、デバッグに一般的な gdb コマンドを使用できます。

さらにエキサイティングなオリジナル コンテンツは http://www.codefrom.com/ にあります

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。