Vagrant + PhpStorm + Xdebug でブレークポイントを張って変数の状態をデバッグする方法を紹介します。Vagrant の synced_folder でソースコードを共有し、開発はホスト PC で、PHP 実行は仮想マシンで行っている方を対象としています。ホスト PC の PhpStorm でデバッグ実行ができるようになります。
ローカル PHP をデバッグする方法は以前書いた記事が参考になると思います。
PhpStorm+Xdebugでローカル環境のPHPをデバッグする方法
動作確認環境
- Mac OSX Mountain Lion
- PhpStorm7
目次
Vagrant 仮想マシンの Xdebug を有効化
Vagrant 仮想マシンの Xdebug を有効化します。php.ini(xdebug.ini) を以下のように設定します。
xdebug.remote_enable=1
xdebug.remote_autostart=1
xdebug.remote_host="192.168.33.1"
xdebug.remote_port=9000
xdebug.idekey="PHPSTORM"
xdebug.remote_host は仮想マシンから見たホスト PC の IP アドレスを設定します。$_SERVER['REMOTE_ADDR'] と同じ値にしておけば良いと思います。Vagrant 仮想マシンの IP アドレスによって適宜変更してください。
xdebug.remote_port はデフォルトが 9000 ですが、PHP-FPM のポート番号のデフォルトも 9000 なので、かぶらないようにしましょう。
Xdebug のポート番号を確認
PhpStorm の Xdebug ポート番号を確認します。仮想マシンの xdebug.remote_port と同じ数字にしておきます。
data:image/s3,"s3://crabby-images/a0d1a/a0d1a272647f92bc8a8c047928e4510a9373eeb2" alt="config-xdebug"
- PhpStorm の 設定ウィンドウを開き、Project Settings > PHP > Debug をクリック
- 必要に応じて Xdebug のポート番号を変更
Deployment を設定
仮想サーバに各種ファイルをデプロイする方法を設定します。仮想マシンの Xdebug の状態を PhpStorm から確認するために設定が必要です。
設定は過去に書いた記事と同じです。以下のリンクからご確認ください。
PhpStormでVagrant仮想マシンのPHPUnitを実行する # Deployment を設定
Xdebug 実行サーバの設定
Servers
設定ウィンドウを開き、左メニューから Project Setting > PHP > Servers を選択します。「+」ボタンをクリックして新規追加します。
data:image/s3,"s3://crabby-images/24175/2417519dd12cc9fb7d8f23e03b6236d30070685f" alt="phpunit-php-server-add"
Xdebug 実行サーバを設定します。
data:image/s3,"s3://crabby-images/2111a/2111ae9ffe88512a7a5097396a0d01333e41586e" alt="phpunit-php-server"
- Name は管理しやすい名前を入力
- Host は Vagrant 仮想マシンの IP アドレスを入力
- Port は PHP アプリケーションのポート番号を入力
- Debugger は Xdebug を選択
- Use path mappings にチェック
- File/Directoryで synced_folder で共有しているローカルのディレクトリを選択し、その右にある Absolute path on serverに仮想マシンの共有ディレクトリを入力
Validate remote environment
Servers 設定の Validate remote environment ボタンをクリックして、Vagrant 仮想マシンの Xdebug の状態を確認します。Xdebug に問題があるとここで警告してくれます。
data:image/s3,"s3://crabby-images/70a7d/70a7d88f88bc888542b1ec777c345765489b1452" alt="phpunit-php-server-validate"
- Deployment は先ほど設定したデプロイ設定を選択
- Local path to create validation script は Vagrant の synced_folder のルートを選択
- Validate ボタンをクリック
PHP Remote Debug 設定
メニュー > Run > Edit Configurations を選択します。
data:image/s3,"s3://crabby-images/eefc0/eefc0a93622056c7bbff0ad48bfa2b3806f6908c" alt="run-edit-config"
左上の「+」ボタンをクリックし、PHP Remote Debug を選択します。
data:image/s3,"s3://crabby-images/a6e2b/a6e2bd66eed628a96889d508b63511aa791a1241" alt="phpunit-remote-debug-add"
PHP Remote Debug を設定します。
data:image/s3,"s3://crabby-images/68c3a/68c3afc75ae4f44bd380f74a15e6f857a829daf6" alt="phpstorm-remote-debug-config"
- Name は管理しやすい名前を入力
- Servers は Xdebug 実行サーバの設定で設定したサーバを選択
- Ide key は PHPSTORM と入力(php.ini の xdebug.idekey と同じ値に)
デバッグ実行
これまでの手順でデバッグの準備が整いました。ブレークポイントを張ってデバッグしてみましょう。
まず、PhpStorm をデバッグ待ち受け状態にします。
- 右上のプルダウンメニューから登録した Remote Debug を選択
- 電話機みたいなアイコン(Start Listen PHP Debug Connections)をクリック
data:image/s3,"s3://crabby-images/7b99d/7b99d0863cd4feb7675dd1f80ab37769d54c9206" alt="xdebug-pull-down"
ソースコードにブレークポイントを張り、ブラウザからアクセスします。ブレークポイントの位置でプログラムの実行が止まります。
data:image/s3,"s3://crabby-images/a0d44/a0d4447aef386b9fb031ddd7b69cbd44ae3605a7" alt="phpunit-remote-debug-break"
デバッグ実行を終了したい場合は「■(停止)」ボタンをクリックします。
data:image/s3,"s3://crabby-images/c6e11/c6e11f58876df66c514a80d977e0a28f6bd0fb8f" alt="phpunit-remote-debug-stop"
テストを書いていればデバッガは不要になるはず
デバッガを起動するということは、そのコードの動きがよく分からないことを意味します。フレームワークなど、他人の書いたコード解析するためにデバッガを使うのは OK ですが、自分で書いたコードでデバッガを使うのは NG だと思います。デバッガに頼った開発をしている方は、今すぐデバッガを封印してテストを書く意識を持ちましょう。