管道傳輸
管道傳輸允許透過管道程式與遠端 shell 通訊。例如,Linux 上的 ssh
。隨著 Visual Studio Code 遠端開發 的推出,管道傳輸主要適用於 IoT 情境。
操作指南
pipeTransport
是 launch.json 檔案中的一個選項。結構如下
"pipeTransport": {
"pipeCwd": "/usr/bin",
"pipeProgram": "/usr/bin/ssh",
"pipeArgs": [
"-pw",
"<password>",
"user@10.10.10.10"
],
"debuggerPath": "/usr/bin/gdb"
},
pipeArgs
可以是設定和驗證管道連線所需的任何一組引數。在範例中,使用了密碼,但您也可以使用 SSH 金鑰。
您可能還需要新增 sourceFileMap
,以將程式碼在遠端 shell 上的路徑對應到本機路徑
"sourceFileMap": {
// "remote": "local"
"/home/user/src": "/src/projectA/src"
}
附加
您也可以使用上述 pipeTransport
區塊來附加至遠端程序。在附加的情況下,您需要指定 processId
。擴充功能可以從遠端機器查詢程序。若要執行此操作,請將 processId": "${command:pickProcess}
變更為 processId": "${command:pickRemoteProcess}
。pipeTransport
設定將用於查詢遠端機器上的程序。然後從下拉式清單中選取程序。與 launch
一樣,您可能需要設定 sourceFileMap
。
Docker 範例
pipeTransport
也可用於偵錯 Docker 容器中的程序。對於附加,launch.json 將包含
"pipeTransport": {
"pipeCwd": "${workspaceFolder}",
"pipeProgram": "docker",
"pipeArgs": [
"exec",
"-i",
"hello_gdb",
"sh",
"-c"
],
"debuggerPath": "/usr/bin/gdb"
},
其中 hello_gdb
是您的容器名稱。
透過啟動容器來啟動程序,然後使用相同的 pipeTransport
在容器中啟動其他程序。請參閱此 launch.json 以取得 完整範例。