SSH端口轉(zhuǎn)發(fā)實(shí)現(xiàn)內(nèi)網(wǎng)穿透

轉(zhuǎn)載自 ? 寧哥的小站 ? SSH端口轉(zhuǎn)發(fā)實(shí)現(xiàn)內(nèi)網(wǎng)穿透

“世界上最遙遠(yuǎn)的距離就是你在外網(wǎng)請(qǐng)求,我在內(nèi)網(wǎng)測(cè)試〕镌#”

這句話(huà)的內(nèi)容档悠,對(duì)于開(kāi)發(fā)人員來(lái)說(shuō)粱侣,特別容易理解傻粘。很多情況下熏纯,我們的開(kāi)發(fā)及測(cè)試環(huán)境在單位的內(nèi)網(wǎng)下,只能通過(guò)位于內(nèi)網(wǎng)的機(jī)器來(lái)連接操作先口,位于外網(wǎng)的機(jī)器是連不到內(nèi)網(wǎng)環(huán)境的。比如說(shuō)蜻拨,如果我們周末在家工作池充,而家里的機(jī)器又不在單位內(nèi)網(wǎng)環(huán)境下,那該如何連接內(nèi)網(wǎng)的環(huán)境呢缎讼?難不成我們還要大周末的跑到單位去加班嗎收夸?

答案是否定的。這是種普遍又迫切的需求血崭,叫“內(nèi)網(wǎng)穿透”卧惜。這里我們使用SSH端口轉(zhuǎn)發(fā)的技術(shù),解決這種問(wèn)題夹纫。

SSH本地端口轉(zhuǎn)發(fā)

假設(shè)咽瓷,host1和host2位于內(nèi)網(wǎng),host3位于外網(wǎng)舰讹,host3可以連接host1和host2茅姜,但host1不能連接host3和host2。我們要做的是月匣,通過(guò)位于外網(wǎng)的host3钻洒,讓host1來(lái)連接host2奋姿。

具體步驟

首先,在host1上進(jìn)行如下操作:


ssh -L 2222:host2:22 user3@host3

其中素标,-L參數(shù)指定了“本地主機(jī)端口:目標(biāo)主機(jī):目標(biāo)主機(jī)端口”称诗。這表示,讓host1作為sshd服務(wù)端头遭,監(jiān)聽(tīng)它自己的2222端口寓免,然后將所有數(shù)據(jù)經(jīng)由host3,轉(zhuǎn)發(fā)到host2的22端口计维。

這種情況下袜香,host1不能連接host3,但由于host1的配置享潜,使得從host1到host3建立了一條“SSH隧道”困鸥。

然后,在host1上進(jìn)行如下操作:


ssh -p 2222 user2@localhost

其中剑按,-p參數(shù)指定了ssh連接的端口疾就,默認(rèn)為22,這里指定了2222端口艺蝴。這表示猬腰,讓host1作為ssh客戶(hù)端,連接它自己的2222端口猜敢,相當(dāng)于連接host2的22端口姑荷。

一般情況下,host2與host3為一臺(tái)主機(jī)缩擂,換句話(huà)說(shuō)鼠冕,我們只要實(shí)現(xiàn)連接host3,那么再連接host2也不成問(wèn)題胯盯。

這時(shí)懈费,命令分別轉(zhuǎn)換為:


ssh -L 2222:localhost:22 user3@host3
ssh -p 2222 user3@localhost

SSH本地端口轉(zhuǎn)發(fā)的本質(zhì)

本質(zhì)上,SSH本地端口轉(zhuǎn)發(fā)博脑,主要是實(shí)現(xiàn)以下兩個(gè)方面:


1\. 將本地主機(jī)的端口憎乙,轉(zhuǎn)發(fā)到目標(biāo)主機(jī)的端口
2\. 在本地主機(jī)上,連接本地主機(jī)的端口叉趣,相當(dāng)于連接目標(biāo)主機(jī)的端口

SSH遠(yuǎn)程端口轉(zhuǎn)發(fā)

假設(shè)泞边,host1和host2位于內(nèi)網(wǎng),host3位于外網(wǎng)疗杉,host1可以連接host3和host2阵谚,但host3不能連接host1和host2。我們要做的是,通過(guò)位于內(nèi)網(wǎng)的host1梢什,讓host3來(lái)連接host2闻牡,也就是實(shí)現(xiàn)所謂的“內(nèi)網(wǎng)穿透”

具體步驟

首先绳矩,在host1上進(jìn)行如下操作:


ssh -R 2222:host2:22 user3@host3

其中,-R參數(shù)指定了“遠(yuǎn)程主機(jī)端口:目標(biāo)主機(jī):目標(biāo)主機(jī)端口”玖翅。這表示翼馆,讓host3作為sshd服務(wù)端,監(jiān)聽(tīng)它自己的2222端口金度,然后將所有數(shù)據(jù)經(jīng)由host1应媚,轉(zhuǎn)發(fā)到host2的22端口。

這種情況下猜极,host3不能連接host1中姜,但由于host1的配置,使得從host1到host3建立了一條“SSH反向隧道”跟伏。

然后丢胚,在host3上進(jìn)行如下操作:


ssh -p 2222 user2@localhost

其中,-p參數(shù)指定了ssh連接的端口受扳,默認(rèn)為22携龟,這里指定了2222端口。這表示勘高,讓host3作為ssh客戶(hù)端峡蟋,連接它自己的2222端口,相當(dāng)于連接host2的22端口华望。

一般情況下蕊蝗,host2與host1為一臺(tái)主機(jī),換句話(huà)說(shuō)赖舟,我們只要實(shí)現(xiàn)連接host1蓬戚,那么再連接host2也不成問(wèn)題。

這時(shí)建蹄,命令分別轉(zhuǎn)換為:


ssh -R 2222:localhost:22 user3@host3
ssh -p 2222 user1@localhost

SSH遠(yuǎn)程端口轉(zhuǎn)發(fā)的本質(zhì)

本質(zhì)上碌更,SSH遠(yuǎn)程端口轉(zhuǎn)發(fā),主要是實(shí)現(xiàn)以下兩個(gè)方面:


1\. 將遠(yuǎn)程主機(jī)的端口洞慎,轉(zhuǎn)發(fā)到目標(biāo)主機(jī)的端口
2\. 在遠(yuǎn)程主機(jī)上痛单,連接遠(yuǎn)程主機(jī)的端口,相當(dāng)于連接目標(biāo)主機(jī)的端口

SSH實(shí)現(xiàn)內(nèi)網(wǎng)穿透

內(nèi)網(wǎng)穿透劲腿,簡(jiǎn)單來(lái)說(shuō)就是旭绒,利用位于外網(wǎng)的主機(jī),來(lái)連接位于內(nèi)網(wǎng)的主機(jī),這符合SSH遠(yuǎn)程端口轉(zhuǎn)發(fā)的情況挥吵。但由于實(shí)際情況中重父,SSH連接經(jīng)常由于這樣那樣的問(wèn)題,導(dǎo)致連接斷開(kāi)忽匈,因此我們不得不重新去在內(nèi)網(wǎng)主機(jī)上建立與外網(wǎng)主機(jī)的連接房午,也就是維持這條“SSH反向隧道”,autossh能實(shí)現(xiàn)連接斷開(kāi)之后自動(dòng)重連功能丹允。

自動(dòng)重連

autossh與ssh用法類(lèi)似郭厌,只要將ssh命令替換成autossh命令即可,如下所示:


autossh -M 2345 -NTR 2222:localhost:22 user3@host3

其中雕蔽,-M參數(shù)指定了autossh監(jiān)聽(tīng)的端口折柠,注意這里與其轉(zhuǎn)發(fā)的端口要區(qū)分開(kāi)。

另外批狐,-N表示禁止執(zhí)行遠(yuǎn)程命令扇售,-T表示禁止分配偽終端,這兩個(gè)參數(shù)結(jié)合起來(lái)表示SSH連接不允許用戶(hù)交互執(zhí)行遠(yuǎn)程操作嚣艇,只能用來(lái)傳數(shù)據(jù)承冰,從而保證了遠(yuǎn)程主機(jī)的安全。

自動(dòng)登錄

每次重新建立連接髓废,autossh都需要確認(rèn)一下登錄身份巷懈。要保證自動(dòng)重連,前提就是要實(shí)現(xiàn)自動(dòng)登錄慌洪。

一種常見(jiàn)的做法顶燕,就是使用公鑰登錄進(jìn)行免密登錄,將host1上的公鑰傳送至host3上冈爹。這樣涌攻,每次在進(jìn)行SSH登錄的時(shí)候,host3都會(huì)向host1發(fā)送一段隨機(jī)字符串频伤,host1用自己的私鑰加密后將數(shù)據(jù)返回恳谎,然后host3用事先存好的公鑰對(duì)返回的數(shù)據(jù)進(jìn)行解密,如果成功憋肖,則證明host1的身份可信因痛,允許直接登錄,不再要求密碼岸更。

還有一種做法鸵膏,就是利用sshpass將密碼明文傳輸給autossh,如下所示:


sshpass -p "xxxxxx" autossh -M 2345 -NTR 2222:localhost:22 user3@host3

其中怎炊,-p參數(shù)指定了登錄的密碼谭企。除了命令行輸入密碼的形式廓译,sshpass還包含-f、-e等參數(shù)债查,分別支持文件輸入密碼及系統(tǒng)環(huán)境變量輸入密碼等形式非区,如圖所示。

其他端口

實(shí)現(xiàn)內(nèi)網(wǎng)穿透盹廷,除了轉(zhuǎn)發(fā)22端口外征绸,我們也可以轉(zhuǎn)發(fā)其他應(yīng)用的端口,如web服務(wù)的80端口俄占、mysql的3306端口等歹垫,這里就不一一細(xì)說(shuō)了。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末颠放,一起剝皮案震驚了整個(gè)濱河市最蕾,隨后出現(xiàn)的幾起案子溜宽,更是在濱河造成了極大的恐慌,老刑警劉巖胁澳,帶你破解...
    沈念sama閱讀 221,635評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件鹿驼,死亡現(xiàn)場(chǎng)離奇詭異欲低,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)畜晰,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,543評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)砾莱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人凄鼻,你說(shuō)我怎么就攤上這事腊瑟。” “怎么了块蚌?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,083評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵闰非,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我峭范,道長(zhǎng)财松,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,640評(píng)論 1 296
  • 正文 為了忘掉前任纱控,我火速辦了婚禮辆毡,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘甜害。我一直安慰自己舶掖,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,640評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布唾那。 她就那樣靜靜地躺著访锻,像睡著了一般褪尝。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上期犬,一...
    開(kāi)封第一講書(shū)人閱讀 52,262評(píng)論 1 308
  • 那天河哑,我揣著相機(jī)與錄音,去河邊找鬼龟虎。 笑死璃谨,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的鲤妥。 我是一名探鬼主播佳吞,決...
    沈念sama閱讀 40,833評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼棉安!你這毒婦竟也來(lái)了底扳?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,736評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤贡耽,失蹤者是張志新(化名)和其女友劉穎衷模,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體蒲赂,經(jīng)...
    沈念sama閱讀 46,280評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡阱冶,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,369評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了滥嘴。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片木蹬。...
    茶點(diǎn)故事閱讀 40,503評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖若皱,靈堂內(nèi)的尸體忽然破棺而出镊叁,到底是詐尸還是另有隱情,我是刑警寧澤走触,帶...
    沈念sama閱讀 36,185評(píng)論 5 350
  • 正文 年R本政府宣布意系,位于F島的核電站,受9級(jí)特大地震影響饺汹,放射性物質(zhì)發(fā)生泄漏蛔添。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,870評(píng)論 3 333
  • 文/蒙蒙 一兜辞、第九天 我趴在偏房一處隱蔽的房頂上張望迎瞧。 院中可真熱鬧,春花似錦逸吵、人聲如沸凶硅。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,340評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)足绅。三九已至捷绑,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間氢妈,已是汗流浹背粹污。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,460評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留首量,地道東北人壮吩。 一個(gè)月前我還...
    沈念sama閱讀 48,909評(píng)論 3 376
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像加缘,于是被迫代替她去往敵國(guó)和親鸭叙。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,512評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容