本篇文章給大家介紹一下vscode遠(yuǎn)程調(diào)試Node程序的方法。有一定的參考價(jià)值,有需要的朋友可以參考一下,希望對(duì)大家有所幫助。
視頻教程推薦:vscode基礎(chǔ)教程、node js教程
遠(yuǎn)程環(huán)境配置
首先要在遠(yuǎn)程服務(wù)器中打開SSH server功能,ubuntu系統(tǒng)基本都自帶,沒有的話,安裝一下
apt-get install openssh-server
本地安裝vscode插件
下載 VScode Insider版本,然后安裝Remote Development擴(kuò)展,安裝 Remote Development擴(kuò)展后,其它的Remote-SSH會(huì)自動(dòng)安裝,若不自動(dòng)安裝,請(qǐng)手動(dòng)按照截圖安裝。

配置用戶名/密碼認(rèn)證, 需要編輯一下VSCode的settings.json文件,打開的方式如下圖,點(diǎn)擊setting,點(diǎn)擊任意一個(gè)‘Edit in settings.json’。

然后在settings.json 添加 "remote.SSH.showLoginTerminal": true

點(diǎn)擊左下角的“open a remote window”,選擇 ‘connect to Host’


根據(jù)圖片順序打開config文件,并填寫遠(yuǎn)程主機(jī)的Host和登錄名

彈出一個(gè)新窗口,根據(jù)提示,輸入linux的密碼

已經(jīng)連接上了以后 ,點(diǎn)擊 文件->打開文件夾(或者文件),可以顯示出linux的文件夾(或者文件)

配置公鑰
上面的步驟每次都要輸入密碼,非常麻煩,可以通過配置公鑰來解決這個(gè)問題。
1、打開Git的安裝目錄,把 Gitusrbin 放到環(huán)境變量。
2、然后打開過程 編輯主機(jī)config文件的目錄 C:Usersye.ssh (不同的電腦user名字會(huì)不一樣),執(zhí)行 ssh-keygen。
路回車即可! 完成后多了id_rsa,id_rsa.pub兩個(gè)文件.
3、我們需要將id_rsa.pub 文件,復(fù)制一份到linux服務(wù)器上~/.ssh/目錄下。若沒有該目錄,請(qǐng)執(zhí)行mkdir ~/.ssh創(chuàng)建,然后將id_rsa.pub,遠(yuǎn)程傳輸?shù)皆撃夸浵?
4、然后切換到該目錄下,執(zhí)行 cat id_rsa.pub >> authorized_keys,
5、修改 /etc/ssh/sshd_config文件下的
PubkeyAuthentication yes
,
AuthorizedKeysFile .ssh/authorized_keys .ssh/authorized_keys2
,兩條是不是正常,若有注釋,請(qǐng)取消,若不相同,請(qǐng)修改或者添加

6、重啟遠(yuǎn)程主機(jī)的ssh服務(wù) /etc/init.d/ssh resart
7、然后回到Windows的命令行,執(zhí)行ssh (用戶名)@192.168.160.132
括號(hào)中的請(qǐng)?zhí)鎿Q為您的Linux用戶名,請(qǐng)一定要按照這種格式登陸,一定要輸入用戶名和IP,不要只輸IP

此時(shí)打開文件的時(shí)候就不會(huì)再提示輸入密碼了
遠(yuǎn)程調(diào)試
找到遠(yuǎn)程服務(wù)器中 node 的路徑
which node
在 launch.json 中添加配置
{ // Use IntelliSense to learn about possible attributes. // Hover to view descriptions of existing attributes. // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 "version": "0.2.0", "configurations": [ { "type": "node", "request": "launch", "name": "Launch Program", "program": "${workspaceFolder}/server/server.js", "runtimeExecutable": "/root/.nvm/versions/node/v8.6.0/bin/node" // 就增加這行 } ] }