data:image/s3,"s3://crabby-images/b60ef/b60ef7260058b9b4010dc14edc3bcb7528af9af8" alt=""
shをデバッグするのに、デバッガを利用できないものだと思っていませんか?!
だがしかし!実はできるんです!
そう・・・VSCodeならね!!
サーバサイドエンジニア の方はsh使う人もたくさんいて一度はデバッガとかないかなーとか思ったことあると思います
実は私もそのうちの一人でした
今回はVSCodeでデバッガ構築を行い、shをデバッグできるようにする方法についてを紹介します
この記事を読むことでVSCodeでshのデバッガ構築が簡単にできるようになるので、是非一度構築してみてはどうでしょうか?
VSCodeにshデバッガ構築してデバッグする方法(Windows)
data:image/s3,"s3://crabby-images/047de/047de70c17fbec767994d4b8dcadce7a23daf16f" alt=""
- WSL(Windows Subsystem for Linux)の導入
- Windowsの場合、これ入れないとVSCodeに怒られます
- VMWare使ってる人は注意、これを使えるようにするとVMWareが動かなくなります→後述します
- WSLのdistributionを導入する
- VSCodeプラグインをインストールする
- Bash Debug
- Remote – WSL
- さぁSHデバッグをしよう
WSL(Windows Subsystem for Linux)の導入
- 検索窓で「Windowsの機能の有効化または無効化」を入力してクリック
data:image/s3,"s3://crabby-images/c22d8/c22d86e926518f90728ca73c8f9f6a5d51891ca2" alt=""
- 「Linux用Windowsサブシステム」と「仮想マシンプラットフォーム」を選択してOKをクリック
data:image/s3,"s3://crabby-images/36a3c/36a3c7070a87b4f8ed892d48098ad47ef88d81c8" alt=""
data:image/s3,"s3://crabby-images/60bfc/60bfc53371b9fd27ec8ab5784d6dbe191379798b" alt=""
- 必要な変更が完了になったら、再起動します
data:image/s3,"s3://crabby-images/81bc9/81bc931adfeb454835702d6381272c0cd4ea52de" alt=""
Windowsの場合、これ入れないとVSCodeに怒られます
VSCodeのBash Debugプラグインで、WSLが有効になっていないとSHのデバッガが動作しないので実施は必須です
VMWare使ってる人は注意、これを使えるようにするとVMWareが動かなくなります→後述します
すでにVMWareを使っている方は注意が必要です
この機能を有効にしているとVMWareが動きません
同時に使用することはできないのでVMWareを使いたい方はこれをオフにしてください
WSLのdistributionを導入する
- 本家サイトの「Downloading distros」から好きなdistributionをダウンロードする※今回はUbuntu 20.04を選択
- ダウンロードした「Ubuntu_2004.2020.424.0_x64.appx」をダブルクリックで実行
- インストールをクリック
data:image/s3,"s3://crabby-images/e6e0d/e6e0d0605fce474a9013cdc6ac21bc9b291457fe" alt=""
- 起動されるとこんな感じのエラーが出ます
WslRegisterDistribution failed with error: 0xc03a001a
Error: 0xc03a001a
- 実際に出たエラーは以下
data:image/s3,"s3://crabby-images/8e799/8e79911e697ebcfcade990d5cec0e76d47e8eb9e" alt=""
- これを解決してくれてるものがありました
Go to C:\Users\user name\AppData\Local\Packages folder. If not apparent, it’s probably hidden. Once inside directory, search subdirectory with ‘ubuntu’ string/keyword. Once located, right click the directory > Advanced > uncheck the compression > Apply. Now the ubuntu directory should have the arrows removed, which means you should have a better chance at actually running the distro install.
https://github.com/microsoft/WSL/issues/5325
- 要するに、以下のディレクトリに移動して
C:\Users\ユーザ名\AppData\Local\Packages
data:image/s3,"s3://crabby-images/43ba0/43ba0ffa843c9066a9f44b53c0459b7befd37f1d" alt=""
- Ubuntuを検索して出てきたフォルダを「右クリック>プロパティ」をクリック
data:image/s3,"s3://crabby-images/9ccd5/9ccd55183ee730cafe64c7c74750d898fd8ed0b9" alt=""
- 詳細設定をクリック
data:image/s3,"s3://crabby-images/3d515/3d515b111597d05a4e6d5460e3b6f35ecd6b5dd4" alt=""
- 開くと以下のようになっているので、「内容を圧縮してディスク領域を節約する」のチェックを外してOKをクリック
data:image/s3,"s3://crabby-images/b951f/b951fb427509b774700f7d1200aa8c6c533840c0" alt=""
- その後適用をクリックすると以下の画面が出るのでOKをクリック
data:image/s3,"s3://crabby-images/f524a/f524a9569fa4fb0c4e97203cd40e75d11dbd5923" alt=""
- Windowsアイコンをクリックして、Ubuntu 20.04 LTSがあるはずなので、クリック
data:image/s3,"s3://crabby-images/dcb4e/dcb4e21e60946911a2511155f2daea011963ce98" alt=""
- 今度は成功します
data:image/s3,"s3://crabby-images/d90d3/d90d335728597185275dd2db31a44a591d3da059" alt=""
- usernameとpassword、再度passwordを打つと成功します
data:image/s3,"s3://crabby-images/746c4/746c4b283a7f7c2377ee856305f13f9bc20d540e" alt=""
VSCodeプラグインをインストールする
- VSCodeで以下のプラグインを入れます
Bash Debug
data:image/s3,"s3://crabby-images/faffa/faffa202038e628d90662ce5114be82045713f64" alt=""
Remote – WSL
data:image/s3,"s3://crabby-images/529f3/529f35ccf564f6b006f1098d731e83f288b4f934" alt=""
拡張機能(プラグイン)のインストール方法がわからない方はこちらのサイトが参考になります
さぁSHデバッグをしよう
準備ができたところでいよいよSHデバッグをしていきます
- SHTESTというフォルダに「echo.sh」というファイルをつくります
echo "test1";
echo "test2";
echo "test3";
- デバッグに必要なファイルを生成していきます
- VSCodeのデバッグアイコンをクリック
data:image/s3,"s3://crabby-images/a70d2/a70d27c572845e9a519cce8c05ae8f2a6c3ff635" alt=""
- 「launch.jsonファイルを作成します」をクリック
data:image/s3,"s3://crabby-images/d29bd/d29bde8414c13d65b73d25d7991a8bbbb0b1da98" alt=""
- 「Bash Debug」をクリック
data:image/s3,"s3://crabby-images/d71d0/d71d04c4190b8d65fa0d3760010b6751cf217e74" alt=""
- .vscode > launch.jsonが生成されます
- この状態が出来たらSHデバッグの準備ができてます
data:image/s3,"s3://crabby-images/8a7d5/8a7d576948e9685e1e28dc4641803137fd043765" alt=""
- ブレークポイントを張ります(赤枠部をクリックすると赤●の点がつきます)
data:image/s3,"s3://crabby-images/16513/16513f198a3a91206fdd15ce8df95d2e0fd69911" alt=""
- F5で実行します(このときデバッグコンソールも出しておきましょう、下にカーソルを当ててドラッグして上に引っ張れば出てきます)
data:image/s3,"s3://crabby-images/c75d0/c75d0c3dba5f4ceccaeb8345c5719637e1f3d382" alt=""
- デバッグアイコンをクリックして切り替えると詳細が見れます
data:image/s3,"s3://crabby-images/5573c/5573c420bfd3709c833f13ccb55561e0beb560d5" alt=""
- ステップオーバーします(赤枠部をクリック)
data:image/s3,"s3://crabby-images/dc643/dc6437c22dd2d3493da35b1f6784031e14574a67" alt=""
- 実行するとデバッグコンソールに結果が表示されます
data:image/s3,"s3://crabby-images/52f0d/52f0da03ea9ada221b9f23de9d79decf86034403" alt=""
いかがでしたでしょうか?
VSCodeのデバッガを利用してSHのデバッグが簡単にできましたか?
本記事を読んでいただいて構築するだけでも価値はあるかと思います
実際に私もプロジェクトで運用していてかなり便利と思っています
まずは本記事の通りに環境構築を行って運用してみてはいかがでしょうか