Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
RayでPHPのデバッグをちょっと快適にする
Search
muno92
PRO
February 26, 2025
Technology
710
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
RayでPHPのデバッグをちょっと快適にする
muno92
PRO
February 26, 2025
More Decks by muno92
See All by muno92
PHPでバイナリをパースして理解するASN.1
muno92
PRO
0
520
forteeの改修から振り返るPHPerKaigi 2026
muno92
PRO
3
380
Cloudflare Tunnelで開発環境をインターネットに公開する
muno92
PRO
0
110
2年のAppleウォレットパス開発の振り返り
muno92
PRO
0
270
PsySHから紐解くREPLの仕組み
muno92
PRO
1
860
Appleウォレット / Googleウォレットに チケットを保存する方法
muno92
PRO
2
4.7k
歴史を重ねたシステムの開発に趣味で関わり始めて
muno92
PRO
1
610
PHPでGoogle Walletにチケットを追加する
muno92
PRO
0
870
カンファレンススタッフはいいぞ
muno92
PRO
1
420
Other Decks in Technology
See All in Technology
SteampipeとExcel Power QueryでAWS構成定義書の作成を自動化する
jhashimoto
0
180
MUSUBI 田中裕一『AIと共に行う「しごとのリデザイン」- スモールバックオフィス編』AI Ops Lab #4
musubi
0
310
When Platform Engineering Meets GenAI
sucitw
0
170
AWS Security Hub CSPMの成功・失敗体験
cmusudakeisuke
0
540
千葉での単身赴任からAWSをやり続け、千葉に戻ってきた話
yama3133
1
120
フルAIで個人開発して学んだあれこれ / yuruai vol.1
isaoshimizu
0
110
Agile and AI Redmine Japan 2026
hiranabe
4
470
気軽に使える"情報のハブ"としてのNotion活用 〜フロー情報の集積点 と、 Claude Code × Notion AI〜
syucream
1
180
AWS Security Agent といっしょに脅威モデリングをやってみよう
amarelo_n24
1
210
Zenoh on Zephyr on LiteX
takasehideki
2
110
GitHub Copilot 最新アップデート – 「一歩先」の実践活用術
moulongzhang
5
1.7k
【2026年版】 ベクトル検索とEmbedding最前線
mocobeta
23
7.5k
Featured
See All Featured
Unlocking the hidden potential of vector embeddings in international SEO
frankvandijk
0
850
StorybookのUI Testing Handbookを読んだ
zakiyama
31
6.8k
How to Align SEO within the Product Triangle To Get Buy-In & Support - #RIMC
aleyda
2
1.6k
Data-driven link building: lessons from a $708K investment (BrightonSEO talk)
szymonslowik
1
1.1k
More Than Pixels: Becoming A User Experience Designer
marktimemedia
3
450
Why Our Code Smells
bkeepers
PRO
340
58k
Paper Plane (Part 1)
katiecoart
PRO
0
9.2k
Cheating the UX When There Is Nothing More to Optimize - PixelPioneers
stephaniewalter
287
14k
Max Prin - Stacking Signals: How International SEO Comes Together (And Falls Apart)
techseoconnect
PRO
0
190
The Limits of Empathy - UXLibs8
cassininazir
1
370
svc-hook: hooking system calls on ARM64 by binary rewriting
retrage
2
310
WCS-LA-2024
lcolladotor
0
650
Transcript
Ray でPHP のデバッグをちょっと快適 にする 2025/2/26 第173 回 PHP 勉強会@東京 @muno_92
1
自己紹介 X ( 旧Twitter): @muno_92 趣味: カンファレンススタッフ PHP カンファレンス名古屋2025 (
当日) PHPerKaigi 2025 ( コア) PHP カンファレンス小田原2025 ( コア) PHP Conference Japan 2025 ( 実行委員) 2
( 宣伝) PHPerKaigi 2025 日程: 2025 年3 月21 日( 金)
〜23 日( 日) 会場: 中野セントラルパークカンファレンス & ニコニコ生放送 チケット販売中! 当日スタッフ & PHPer コードバトル予選 (3/8 土) 参加者募集中! https://phperkaigi.jp/2025/ 3
( 宣伝) PHP カンファレンス小田原2025 日程: 2025 年4 月12 日( 土)
会場: おだわら市民交流センター「UMECO 」 チケット販売中! https://phpcon-odawara.jp/2025 4
デバッグどうしてますか? print デバッグ Xdebug PsySH Debugbar etc 5
こんな時ありませんか? ブレークポイントで止めずに一気に処理を流したいが、変数の中身 やどこを通ったかは確認したい ログは見やすく表示されて欲しい ( 色々な理由があって) Xdebug を使えない 6
こんな時ありませんか? ブレークポイントで止めずに一気に処理を流したいが、変数の中身 やどこを通ったかは確認したい ログは見やすく表示されて欲しい ( 色々な理由があって) Xdebug を使えない ↓ Ray
はどうでしょう? 7
Ray ならこんな事ができます ray('Hello'); ray(['a' => 1, 'b' => 2]); 8
目次 Ray とは 使い方 Ray の仕組み 便利な機能 まとめ 9
Ray とは デバッグ結果を表示するデスクトップアプリ 有償 (4,566 円/ 年) 。お試し可能 対応OS Windows
/ Mac / Linux 対応言語 PHP / JavaScript / Bash / Go / Ruby 仕組み( 後述) 的に他の言語でも使えそう https://myray.app/ 10
使い方 11
セットアップ 1. デスクトップアプリをインストール 2. ray() をPC 共通 or プロジェクト単位でインストール PC
共通 composer global require spatie/global-ray global-ray install プロジェクト単位 composer require spatie/ray https://myray.app/docs/php/vanilla-php/installation 12
ログの出力 ray() これだけで十分便利 配列・オブジェクトは折りたたみ・展開可能 色を変更可能 (green / orange / red
/ blue / purple / gray) ray("It's green")->green(); 13
PhpStorm と連携 ログのファイル名をクリックするとPhpStorm で該当ファイル・該 当行を開いてくれる 便利 14
仕組み 15
シンプル Ray アプリがポート23517 番で待ち受け ~ > lsof -i:23517 COMMAND PID
USER FD TYPE DEVICE SIZE/OFF NODE NAME Ray 45800 ******* 50u IPv6 0xd2f89e7cd65af8a 0t0 TCP *:23517 (LISTEN) プログラムからlocalhost:23517 にPOST curl_exec($curlHandle); https://github.com/spatie/ray/blob/441f904ae89e825a18d11e2e5 819a60a1c7e632a/src/Client.php#L84 16
つまりコンテナを使った開発では そのままだとホスト側のアプリに繋がらない 設定ファイル(ray.php) でPOST 先を切り替える必要あり return [ 'host' => 'host.docker.internal',
'port' => 23517, 'remote_path' => null, 'local_path' => null, ]; https://myray.app/docs/environments/docker 17
適切な形式でPOST さえすればログ出力可能 { "uuid": "ca539a10-bfd5-3e5a-6271-0c4a95612132", "payloads": [ { "type": "custom",
"content": { "content": "<em>hello world!</em>", "label": "HTML" }, "origin": { "function_name": "test", "file": "/home/user/projects/test-project/test.php", "line_number": 16, "hostname": "my-hostname" } } ], "meta": { "php_version": "7.4.16", "php_version_id": 70416, "ray_package_version": "1.20.1.0" } } https://myray.app/docs/developing-ray-libraries/payload 18
便利な機能 19
表示を見やすくするしてくれる機能 指定形式の文字列を配列同等の折りたたみ表示に ray()->json('JSON形式の文字列') ray()->xml('XML形式の文字列') ray()->carbon(Carbonインスタンス) 20
デバッグ時に便利な機能 ray()->backtrace() ray()->if(条件式)->text('ログ') 条件式がtrue の場合のみメソッドチェーンで繋げた処理が実行さ れる ray()->once('ログ') ループの最初の一回にログ出力を限定できる ray()->notify('通知メッセージ') デスクトップ通知
21
計測 ray()->measure(); // 何か重い処理 ray()->measure(); // 何か重い処理 ray()->measure(); 22
まとめ Ray を使うとデバッグログをデスクトップアプリから見やすい形式 で確認できるようになる 色々便利な機能はあるが、シンプルに ray() 関数を使うだけでも十 分便利 PHP で開発する際のデバッグツールの選択肢に加えてみるのもアリ
ではないでしょうか 23
ご清聴ありがとうございました 24
補足 (ray 関数の削除忘れ防止) ray() を削除するRector のカスタムルール https://myray.app/docs/php/vanilla-php/automatically-remove- ray-calls ray() の削除忘れ検知
PHPStan https://myray.app/docs/php/vanilla-php/phpstan 検知用公式パッケージ https://myray.app/docs/php/vanilla-php/x-ray 25
補足 ( リモートサーバーから使う場合) SSH 接続情報を設定すれば使用可能 https://myray.app/docs/environments/remote 26
補足 (WSL から使う場合) 下記①〜③のいずれかの方法で使用可能(公式推奨は①・②) Windows に特定のIP を設定した上でRay の通信先に設定 ① 固定IP
を振る ② DHCP Reservation を設定 ③都度都度Windows のIP アドレスを設定 https://myray.app/docs/environments/windows#wsl2 27