欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

利用VSCode進(jìn)行遠(yuǎn)程Linux服務(wù)器、容器開(kāi)發(fā),達(dá)到ide開(kāi)發(fā)項(xiàng)目的效果(最新推薦)

 更新時(shí)間:2022年12月05日 11:12:43   作者:Sintol·D·Kevin  
最方便、最開(kāi)始的開(kāi)發(fā)方式當(dāng)然是在本地ide中,比如初學(xué)者在Windows電腦上使用pycharm來(lái)學(xué)習(xí)python、深度學(xué)習(xí),或者使用devc++、visual?studio等來(lái)編寫c++項(xiàng)目,在本地ide中,可以瀏覽文件夾、查看文本和圖片等,進(jìn)一步還可以運(yùn)行調(diào)試python、C++等項(xiàng)目

本文將介紹“局域網(wǎng)下遠(yuǎn)程ide式開(kāi)發(fā)”、“公網(wǎng)下遠(yuǎn)程ide式開(kāi)發(fā)”、“局域網(wǎng)下遠(yuǎn)程容器的ide式開(kāi)發(fā)”、“公網(wǎng)下遠(yuǎn)程容器的ide式開(kāi)發(fā)”這四種開(kāi)發(fā)流程,讓你無(wú)論在工位上還是在家中,都可以像打開(kāi)本地ide那樣進(jìn)行遠(yuǎn)程的項(xiàng)目開(kāi)發(fā)。

0 本地ide式開(kāi)發(fā)

最方便、最開(kāi)始的開(kāi)發(fā)方式當(dāng)然是在本地ide中,比如初學(xué)者在Windows電腦上使用pycharm來(lái)學(xué)習(xí)python、深度學(xué)習(xí),或者使用devc++、visual studio等來(lái)編寫c++項(xiàng)目。在本地ide中,可以瀏覽文件夾、查看文本和圖片等,進(jìn)一步還可以運(yùn)行調(diào)試python、C++等項(xiàng)目。這樣的開(kāi)發(fā)過(guò)程稱為“ide式開(kāi)發(fā)”,初學(xué)者會(huì)覺(jué)得這些都是理所當(dāng)然的。

1.0 局域網(wǎng)下遠(yuǎn)程終端開(kāi)發(fā)

但是隨著能力的提升、需求的擴(kuò)大,我們需要使用Linux系統(tǒng)來(lái)進(jìn)行開(kāi)發(fā),甚至是純服務(wù)器形式的linux,連顯示屏都沒(méi)有。此時(shí)我們會(huì)初步接觸ssh,連上linux服務(wù)器的終端,然后通過(guò)敲命令的方式來(lái)執(zhí)行一些程序的運(yùn)行,查看結(jié)果。注意只連終端是不可能進(jìn)行代碼編寫、調(diào)試等步驟的,更別說(shuō)看圖片啥的。此時(shí)的做法應(yīng)為在本地機(jī)寫好代碼,再通過(guò)ftp傳輸?shù)椒?wù)器上運(yùn)行。不過(guò)這也算入門linux中的項(xiàng)目開(kāi)發(fā)了。

1.1 局域網(wǎng)下遠(yuǎn)程ide式開(kāi)發(fā)

但是這種方式太low了,就不能實(shí)現(xiàn)windows里ide式開(kāi)發(fā)的效果嗎?可以的!借助強(qiáng)大的vscode的remote-ssh插件,同樣是ssh連接服務(wù)器的22端口,卻可以實(shí)現(xiàn)ide式開(kāi)發(fā),這樣就可以愉快的點(diǎn)來(lái)點(diǎn)去和調(diào)試代碼了。想實(shí)現(xiàn)這個(gè)功能請(qǐng)搜索“vscode遠(yuǎn)程連接linux”,或“vscode remote-ssh連接linux”等教程。

在這個(gè)環(huán)節(jié),我們應(yīng)該對(duì)ssh的原理、公鑰私鑰的概念與使用有所了解,還需要了解sshd_config中各項(xiàng)配置的含義。

1.2 公網(wǎng)下遠(yuǎn)程ide式開(kāi)發(fā)

再進(jìn)一步,我們會(huì)有居家辦公的需求,比如現(xiàn)在疫情比較頻繁,在家里沒(méi)有了公司wifi,脫離了局域網(wǎng)環(huán)境,我們是無(wú)法像以前那樣連接linux服務(wù)器的,因?yàn)閕p是內(nèi)網(wǎng)中的,而我們處在家中的話還去連那個(gè)ip,肯定就不對(duì)了。此時(shí)需要借助“端口轉(zhuǎn)發(fā)”,或者說(shuō)“內(nèi)網(wǎng)穿透”工具來(lái)把處在公司內(nèi)網(wǎng)的linux服務(wù)器的22端口暴露在公網(wǎng)環(huán)境中。對(duì)于計(jì)算機(jī)網(wǎng)絡(luò)不太好的同學(xué)來(lái)說(shuō)不論是理解還是實(shí)現(xiàn)這一功能都是比較困難的。

所謂內(nèi)網(wǎng)穿透,就是借助處在公網(wǎng)中的服務(wù)器作為中介,讓公司的linux服務(wù)器和家里的windows電腦都連接上公網(wǎng)服務(wù)器,windows向中介發(fā)送“sudo apt install vim”命令,中介就把這句話轉(zhuǎn)發(fā)給公司linux服務(wù)器,公司linux服務(wù)器就會(huì)執(zhí)行這個(gè)命令,然后返回“successfully installed vim.”信息給中介,然后中介再把這條信息傳遞給windows電腦,于是整體效果就是win端輸入sudo apt install vim,接著顯示successfully installed vim.這就是內(nèi)網(wǎng)穿透。在內(nèi)網(wǎng)穿透基礎(chǔ)上,通過(guò)vscode的remote-ssh配置一下,就能實(shí)現(xiàn)公網(wǎng)下遠(yuǎn)程ide式開(kāi)發(fā)。

內(nèi)網(wǎng)穿透要注意的細(xì)節(jié)是比較多的,為了方便大家實(shí)現(xiàn),也為了以后自己在新設(shè)備上復(fù)現(xiàn),我做一些詳細(xì)的說(shuō)明。

整個(gè)內(nèi)網(wǎng)穿透流程如下

在這里插入圖片描述

在具體實(shí)施上,有3個(gè)環(huán)節(jié)要做:
1、購(gòu)買并設(shè)置好擁有公網(wǎng)ip的阿里云服務(wù)器,在控制臺(tái)的安全組中(并非在服務(wù)器內(nèi)部,而是在阿里云控制臺(tái)中)開(kāi)放相應(yīng)端口
2、在阿里云服務(wù)器上安裝ssh, 安裝frp,完成frps.ini的配置,開(kāi)啟防火墻,開(kāi)放相應(yīng)端口,frps服務(wù)添加至自啟動(dòng)并開(kāi)啟
3、在公司內(nèi)網(wǎng)服務(wù)器上安裝frp,完成frpc.ini的配置,開(kāi)放相應(yīng)端口,開(kāi)啟ssh,frpc服務(wù)添加至自啟動(dòng)并開(kāi)啟。
具體說(shuō)明:

1、購(gòu)買一個(gè)阿里云服務(wù)器

我買的是1核2g cpu,1Mbps帶寬,100G容量的ecs.n4.small服務(wù)器,1年84元,服務(wù)器會(huì)提供一個(gè)公網(wǎng)ip(無(wú)論在哪個(gè)網(wǎng)絡(luò)環(huán)境下都可以憑借公網(wǎng)ip訪問(wèn)云服務(wù)器,假設(shè)此ip為89.67.45.200)。在阿里云控制臺(tái)的安全組的出和入里面添加服務(wù)端的反向代理監(jiān)聽(tīng)端口(7000),映射端口(6000),為了后續(xù)的別的設(shè)備的端口轉(zhuǎn)發(fā),可以多開(kāi)幾個(gè)端口
?

在這里插入圖片描述

2、阿里云服務(wù)器終端內(nèi)

2.1、先開(kāi)放端口

具體可參考這里

apt install openssh-server
systemctl start firewalld
firewall-cmd --add-port=7000/tcp --permanent
firewall-cmd --add-port=6000/tcp --permanent
firewall-cmd --add-port=6001/tcp --permanent
firewall-cmd --reload

2.2、接下來(lái)配置frp

mkdir /root/apps && cd /root/apps
wget https://github.com/fatedier/frp/releases/download/v0.34.3/frp_0.34.3_linux_amd64.tar.gz
tar -xvf frp_0.34.3_linux_amd64.tar.gz
cd frp_0.34.3_linux_amd64

將frps.ini內(nèi)容改為

[common]
bind_addr = 0.0.0.0
bind_port = 7000
token = 1234

frps表示server端的frp,同理frpc表示client端的frp。
其中bind_port表示監(jiān)聽(tīng)端口。一個(gè)中介服務(wù)器可以同時(shí)完成多個(gè)設(shè)備的端口轉(zhuǎn)發(fā),但是監(jiān)聽(tīng)端口只能有一個(gè)。
token表示密碼,別的設(shè)備想讓中介轉(zhuǎn)發(fā)端口,得有這個(gè)密碼

2.3、設(shè)置自啟動(dòng)

將sysytemd下的frps.service內(nèi)容改為

[Unit]
Description=Frp Server Service
After=network.target

[Service]
Restart=on-failure
RestartSec=5s
ExecStart=/root/apps/frp_0.34.3_linux_amd64/frps -c /root/apps/frp_0.34.3_linux_amd64/frps.ini

[Install]
WantedBy=multi-user.target

然后執(zhí)行

cp ./systemd/frps.service /etc/systemd/system/
systemctl daemon-reload
systemctl enable frps
systemctl start frps

這樣的話中介就配置好了

3、內(nèi)網(wǎng)linux服務(wù)器配置

apt install openssh-server
mkdir /home/user/apps && cd /home/user/apps
wget https://github.com/fatedier/frp/releases/download/v0.34.3/frp_0.34.3_linux_amd64.tar.gz
tar -xvf frp_0.34.3_linux_amd64.tar.gz
cd frp_0.34.3_linux_amd64

將frpc.ini內(nèi)容改為

[common]
server_addr = 89.67.45.200
server_port = 7000
token=1234

[linux_in_company]
type = tcp
local_ip = 127.0.0.1
local_port = 22
remote_port = 6000

server_addr表示中介的公網(wǎng)ip,server_port 是中介的監(jiān)聽(tīng)端口,linux_in_company是這臺(tái)linux服務(wù)器在中介那里的命名,如果有多個(gè)設(shè)備要用中介來(lái)轉(zhuǎn)發(fā)端口,這個(gè)命名不可以重復(fù)
local_port 表示Linux服務(wù)器中要轉(zhuǎn)發(fā)出去的端口,22表示終端
remote_port 是中介上的映射端口。win電腦訪問(wèn)中介的6000端口就能起到訪問(wèn)Linux服務(wù)器22端口的效果
然后做自啟動(dòng),修改systemd下的frpc.service

[Unit]
Description=Frp Client Service
After=network.target
Wants=network.target

[Service]
Restart=on-failure
RestartSec=5s
ExecStart=/home/user/apps/frp_0.34.3_linux_amd64/frpc -c /home/user/apps/frp_0.34.3_linux_amd64/frpc.ini
ExecReload=/home/user/apps/frp_0.34.3_linux_amd64/frpc reload -c /home/user/apps/frp_0.34.3_linux_amd64/frpc.ini

[Install]
WantedBy=multi-user.target

cp ./systemd/frpc.service /etc/systemd/system/
systemctl daemon-reload
systemctl enable frpc
systemctl start frpc

4、Win端ssh連接中介

到這一步就很簡(jiǎn)單了。
ssh user@89.67.45.200 -p 6000即可,想登root就改成ssh root@89.67.45.200 -p 6000,后面相應(yīng)的輸root的密碼即可。有時(shí)記得sudo的密碼卻忘了su的密碼咋整?sudo passwd root重置root密碼即可
此外,還可以通過(guò)密鑰對(duì)來(lái)進(jìn)行免密登陸,這里不做贅述

4.1 局域網(wǎng)下遠(yuǎn)程容器的ide式開(kāi)發(fā)

隨著能力的進(jìn)一步提升,我們不得不面臨越來(lái)越困難、復(fù)雜的環(huán)境配置過(guò)程,比如cuda,tesnorrt的安裝與更換版本等。很多時(shí)候,目的是C,但是為了做C要先把A和B這兩個(gè)配置環(huán)境的環(huán)節(jié)給踩一遍,隨著這種情況的增多,我們就會(huì)發(fā)現(xiàn)原先簡(jiǎn)單的linux服務(wù)器變得越來(lái)越龐大復(fù)雜,里面配置了各種各樣的環(huán)境,復(fù)雜到,嘗試更新顯卡驅(qū)動(dòng)失敗了,導(dǎo)致很多東西都得跟著完蛋,最后連pytorch模型都跑不起來(lái)。
所以,我們直接在服務(wù)器本體上進(jìn)行各種環(huán)境的配置與項(xiàng)目的開(kāi)發(fā)有兩個(gè)缺點(diǎn):其一是耗時(shí)間,有的東西的確沒(méi)必要搞這么清楚,如果有現(xiàn)成的直接用當(dāng)然最好;其二是環(huán)境間容易相互影響產(chǎn)生依賴,一個(gè)出問(wèn)題了其他都得完蛋。
在這種問(wèn)題的驅(qū)動(dòng)下,容器內(nèi)的項(xiàng)目開(kāi)發(fā)流程應(yīng)運(yùn)而生:我們打開(kāi)Linux服務(wù)器,并不直接在其上面進(jìn)行環(huán)境配置與代碼編寫調(diào)試,而是再在linux中創(chuàng)建容器并進(jìn)入,在容器中去進(jìn)行開(kāi)發(fā)。一進(jìn)容器,各種需要的環(huán)境已經(jīng)為你準(zhǔn)備好了,比如英偉達(dá)官方的pytorch容器,里面就配好了cuda,cudnn,pytorch,tensorrt等等,這就為我們節(jié)省了大量寶貴的時(shí)間。再者,在容器里面不管你怎么折騰,只要?jiǎng)e把掛載文件夾里的東西亂刪,那都沒(méi)事,絲毫不影響容器外部的linux服務(wù)器。不小心把容器搞壞了,再run一個(gè),一切照常。
而想要實(shí)現(xiàn)遠(yuǎn)程容器的ide式開(kāi)發(fā)也很簡(jiǎn)單,只要在創(chuàng)建容器時(shí)增加端口映射即可,比如docker run … -p 6666:22 …,然后在容器中安裝好ssh,開(kāi)啟服務(wù),這樣的話訪問(wèn)linux服務(wù)器(稱為host)中的6666端口就等同于訪問(wèn)容器的22端口了。
所以只需把“1.1 局域網(wǎng)下遠(yuǎn)程ide式開(kāi)發(fā)”中的ssh指令的用戶名改為root,端口改為6666,即可在vscode中通過(guò)局域網(wǎng)來(lái)實(shí)現(xiàn)遠(yuǎn)程容器的ide式開(kāi)發(fā)。

4.2 公網(wǎng)下遠(yuǎn)程容器的ide式開(kāi)發(fā)

有了“1.2 公網(wǎng)下遠(yuǎn)程ide式開(kāi)發(fā)”和“2.1 局域網(wǎng)下遠(yuǎn)程容器的ide式開(kāi)發(fā)”的基礎(chǔ),公網(wǎng)下遠(yuǎn)程容器的ide式開(kāi)發(fā)就變得非常簡(jiǎn)單:在公司linux服務(wù)器中的frpc.ini中增加一個(gè)端口轉(zhuǎn)發(fā)請(qǐng)求,把6666端口轉(zhuǎn)發(fā)到中介的6001端口,這樣的話ssh root@89.67.45.200 -p 6001就會(huì)先轉(zhuǎn)到linux服務(wù)器的6666端口,再轉(zhuǎn)到容器的22端口,成功在家中進(jìn)行公司服務(wù)器中容器的ide開(kāi)發(fā)

不過(guò)要注意,ssh連之前要先在linux服務(wù)器中運(yùn)行該容器,并通過(guò)/etc/init.d/ssh start開(kāi)啟ssh服務(wù)。這個(gè)環(huán)節(jié)可以使用容器的初始腳本來(lái)完成,首先在linux服務(wù)器上找個(gè)地方寫一個(gè)腳本~/code/start.sh

#! /bin/bash
if [ -f "/etc/init.d/ssh" ]; then
    echo "ssh OK"
    /etc/init.d/ssh start
else
    echo "ssh not installed. Start intallation."
    /code/install_ssh.sh
fi

/bin/bash

然后chmod 777 ~/code/start.sh

其中安裝ssh的腳本如下,沒(méi)個(gè)容器情況不同,所以僅供參考

#! /bin/bash
cd /
echo -e "deb http://mirrors.aliyun.com/ubuntu/ xenial main restricted universe multiverse\ndeb http://mirrors.aliyun.com/ubuntu/ xenial-security main restricted universe multiverse\ndeb http://mirrors.aliyun.com/ubuntu/ xenial-updates main restricted universe multiverse\ndeb http://mirrors.aliyun.com/ubuntu/ xenial-proposed main restricted universe multiverse\ndeb http://mirrors.aliyun.com/ubuntu/ xenial-backports main restricted universe multiverse\ndeb-src http://mirrors.aliyun.com/ubuntu/ xenial main restricted universe multiverse\ndeb-src http://mirrors.aliyun.com/ubuntu/ xenial-security main restricted universe multiverse\ndeb-src http://mirrors.aliyun.com/ubuntu/ xenial-updates main restricted universe multiverse\ndeb-src http://mirrors.aliyun.com/ubuntu/ xenial-proposed main restricted universe multiverse\ndeb-src http://mirrors.aliyun.com/ubuntu/ xenial-backports main restricted universe multiverse\n" >> sources.list
cp sources.list /etc/apt/sources.list
apt update
apt install -y --allow-downgrades openssh-client=1:7.2p2-4ubuntu2.10
apt install -y openssh-server
echo "ssh installed. Now you need to configure it."

然后chmod 777 ~/code/install_ssh.sh

接下來(lái)創(chuàng)建容器!

docker run --gpus all -it -p 6666:22 --name trt -v ~/code:/code nvcr.io/nvidia/tensorrt:21.10-py3 /bin/bash /code/start.sh

我來(lái)詳細(xì)解讀一下這條指令:

run就是從鏡像創(chuàng)建容器,–gpus all就是把host的所有g(shù)pu都開(kāi)放使用權(quán)利,-it就是以交互模式運(yùn)行容器并為其分配一個(gè)終端命令行,-p 6666:22就是把容器的終端端口22映射到host的6666端口,–name trt就是給這個(gè)容器命名為trt,-v ~ /code:/code就是把host的~/code文件夾掛載到容器中的/code文件夾。nvcr.io/nvidia/tensorrt:21.10-py3就是鏡像的名字,/bin/bash /code/start.sh表示一創(chuàng)建容器就用bash執(zhí)行這條start.sh腳本,而且start.sh腳本末尾還有一行“/bin/bash”就是說(shuō)執(zhí)行完安裝或開(kāi)啟ssh腳本后,執(zhí)行bash,留著終端這個(gè)程序,不然容器會(huì)自動(dòng)退出。

這樣就可以做到一開(kāi)啟容器,就能自動(dòng)開(kāi)啟ssh啦

到此這篇關(guān)于利用VSCode進(jìn)行遠(yuǎn)程Linux服務(wù)器、容器開(kāi)發(fā),達(dá)到ide開(kāi)發(fā)項(xiàng)目的效果的文章就介紹到這了,更多相關(guān)VSCode遠(yuǎn)程Linux服務(wù)器開(kāi)發(fā)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • apache日志配置一例

    apache日志配置一例

    apache日志配置一例,包括指定存儲(chǔ)目錄與格式、自動(dòng)刪除過(guò)期的日志文件,有需要的朋友可以參考下
    2013-02-02
  • 關(guān)于進(jìn)程間通信的Linux小程序

    關(guān)于進(jìn)程間通信的Linux小程序

    這篇文章主要為大家詳細(xì)介紹了一個(gè)關(guān)于進(jìn)程間通信的Linux小程序,主要利用共享內(nèi)存實(shí)現(xiàn)進(jìn)程間通信,使用管道實(shí)現(xiàn)進(jìn)程間競(jìng)爭(zhēng)關(guān)系,感興趣的朋友可以參考一下
    2016-05-05
  • 開(kāi)發(fā)環(huán)境Ubuntu16安裝以后的初始化設(shè)置

    開(kāi)發(fā)環(huán)境Ubuntu16安裝以后的初始化設(shè)置

    今天小編就為大家分享一篇關(guān)于開(kāi)發(fā)環(huán)境ubuntu16安裝以后的初始化設(shè)置,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2018-10-10
  • 解決centos桌面在虛擬機(jī)中界面顯示太小問(wèn)題

    解決centos桌面在虛擬機(jī)中界面顯示太小問(wèn)題

    這篇文章主要介紹了解決centos桌面在虛擬機(jī)中界面顯示太小問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • Ubuntu系統(tǒng)下擴(kuò)展LVM根目錄的方法

    Ubuntu系統(tǒng)下擴(kuò)展LVM根目錄的方法

    這篇文章主要給大家介紹了關(guān)于Ubuntu系統(tǒng)下擴(kuò)展LVM根目錄的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-05-05
  • 關(guān)于linux服務(wù)器hosts文件配置詳解

    關(guān)于linux服務(wù)器hosts文件配置詳解

    在本篇文章里小編給大家整理的是關(guān)于linux服務(wù)器hosts文件配置問(wèn)題,需要的朋友們可以學(xué)習(xí)參考下。
    2020-02-02
  • linux下php加裝mssql模塊的方法

    linux下php加裝mssql模塊的方法

    在linux 下的php連接mssql,就需要安裝第三方的freetds了。需要的朋友可以參考下。
    2011-05-05
  • Linux 解決Deepin無(wú)法在root用戶啟動(dòng)Google Chrome瀏覽器的問(wèn)題

    Linux 解決Deepin無(wú)法在root用戶啟動(dòng)Google Chrome瀏覽器的問(wèn)題

    這篇文章主要介紹了Linux 解決Deepin無(wú)法在root用戶啟動(dòng)Google Chrome瀏覽器的問(wèn)題,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-07-07
  • linux之conda環(huán)境安裝全過(guò)程

    linux之conda環(huán)境安裝全過(guò)程

    這篇文章主要介紹了linux之conda環(huán)境安裝全過(guò)程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • linux memcache安裝配置方法

    linux memcache安裝配置方法

    這篇文章主要介紹了linux memcache安裝配置方法,需要的朋友可以參考下
    2014-07-07

最新評(píng)論