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

Hadoop框架起步之圖解SSH、免密登錄原理和實現(xiàn)方法

 更新時間:2019年07月04日 15:15:33   作者:Kefi123  
這篇文章主要介紹了Hadoop框架起步之圖解SSH、免密登錄原理和實現(xiàn)方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下

1. 前言

emmm….最近學(xué)習(xí)大數(shù)據(jù),需要搭建Hadoop框架,當(dāng)弄好linux系統(tǒng)之后,第一件事就是SSH免密登錄的設(shè)置。對于SSH,我覺得使用過linux系統(tǒng)的程序員應(yīng)該并不陌生??墒前桑闷饋砗唵?,真讓你說出個所以然,還是件比較困難的事(大佬繞路,此篇文章不屬于你~)。然后,我就好奇心大發(fā),打算寫一篇博客詳細介紹一下SSH和免密登錄的原理及實現(xiàn)。

補充:不管是Hadoop的偽分布還是全分布,Hadoop的名稱結(jié)點(NameNode)都需要啟動集群中所有機器的Hadoop守護進程,而這個過程可以通過SSH登錄來實現(xiàn)。由于Hadoop并沒有提供SSH輸入密碼登錄的形式,因此,為了能夠順利登錄每臺機器,就需要對其進行SSH的免密登錄配置。

2. 初見SSH

Secure Shell(安全外殼協(xié)議,簡稱SSH)是一種加密的網(wǎng)絡(luò)傳輸協(xié)議,可以在不安全的網(wǎng)絡(luò)中為網(wǎng)絡(luò)服務(wù)提供安全的傳輸環(huán)境(來自維基百科的定義)。根據(jù)其定義,我們能夠理解SSH最常見的用途就是遠程登錄系統(tǒng),人們通常利用SSH來傳輸命令行界面和遠程執(zhí)行命令。

早期的互聯(lián)網(wǎng)通信,例如Telnet和非安全shell,都是采用明文進行傳輸,一旦被截獲,內(nèi)容就會暴露無遺。而SSH就是其上位的替代品。1995年,芬蘭學(xué)者Tatu Ylonen設(shè)計了SSH協(xié)議,將登錄信息全部加密,成為了互聯(lián)網(wǎng)安全的一個基本解決方案,迅速在全世界獲得推廣。

這里需要注意一下,SSH只是一種協(xié)議(或者可以理解為一種規(guī)定),而它具體的實現(xiàn)有很多,商業(yè),開源的等等。其最流行的實現(xiàn)應(yīng)該是OpenSSH,本文所針對的實現(xiàn)也是基于OpenSSH的。

3. SSH的工作原理

作為以安全性著稱的協(xié)議,SSH是怎么實現(xiàn)的呢?我們首先想到的肯定是對數(shù)據(jù)進行加密,而SSH的加密方式主要有兩種,一個是對稱加密(密鑰加密),另一個是非對稱加密(公鑰加密)。

3.1 對稱加密

所謂的對稱加密就是客戶端與服務(wù)器共用一套密鑰進行數(shù)據(jù)的加解密,詳情見下圖。

圖3-1 對稱加密的過程

這種加密方式很難被破解,但是存在一個問題,如果密鑰泄露,系統(tǒng)數(shù)據(jù)的安全性將不復(fù)存在,為了解決這個問題,非對稱加密應(yīng)運而生。

3.2 非對稱加密

非對稱加密有兩個密鑰:公鑰和私鑰。數(shù)據(jù)使用公鑰加密之后,只能使用私鑰進行解密,而私鑰被破解的概率很低很低,詳情見下圖。

圖3-2 非對稱加密的過程

由于私鑰是服務(wù)器獨有的,所以即使客戶機的登錄信息被截取,也是沒有私鑰進行解密的,保證了數(shù)據(jù)的安全性,充分利用了非對稱加密的特點。

3.3 非對稱加密的缺陷

非對稱加密就一定安全了么?答案是否定的。如果黑客冒充了服務(wù)器,攔截了登錄請求,并且把自己的公鑰發(fā)送給客戶機,再使用自己的私鑰對密碼進行解密,就會獲取到客戶機的登錄信息,從而造成數(shù)據(jù)泄露,這就是中間人攻擊,詳情見下圖。

圖3-3 非對稱加密的缺陷

對于上訴的缺陷,SSH有兩種解決方法,第一種是基于口令的認證;另一種是基于公鑰的認證,俗稱SSH免密登錄。

3.4 基于口令的認證

根據(jù)圖3-3所示,我們可以發(fā)現(xiàn)問題的關(guān)鍵點就在于客戶機沒法分辨出公鑰是否是自己想要登錄的服務(wù)器給的公鑰,所以說客戶機只能自己對公鑰進行確認,通常第一次登錄的時候會出現(xiàn)下面的提示。

1 The authenticity of host 'ssh-server.example.com (12.18.429.21)' can't be established.
2 RSA key fingerprint is 98:2e:d7:e0:de:9f:ac:67:28:c2:42:2d:37:16:58:4d.
3 Are you sure you want to continue connecting (yes/no)?

提示的內(nèi)容是在說,無法確定ssh-server.example.com (12.18.429.21)主機的真實性,但是知道其公鑰指紋,是否繼續(xù)連接。

之所以使用公鑰指紋,是因為RSA算法生成的公鑰長達1024位,但是通過對公鑰進行hash得到的128位的指紋就很容易進行比較。

輸入yes之后,會出現(xiàn)下面的提示。

1 Warning: Permanently added 'ssh-server.example.com,12.18.429.21' (RSA) to the list of known hosts.
2 Password: (enter password)

提示在說,該主機已經(jīng)添加到known hosts的列表里了,接著輸入密碼,按照圖3-2的流程走就行了。

4.基于公鑰的認證

4.1 SSH免密登錄的原理

免去密碼進行登錄,不僅使得登錄信息不會遭到泄露,而且也簡化、方便了系統(tǒng)之間登錄的操作,提高了工作的效率,工作原理見下圖所示。

圖4-1 免密登錄的原理

4.2 SSH免密登錄的實現(xiàn)(openSSH)

第一步:安裝SSH,命令如下。

 yum install –y openssh-clients openssh-server

這里解釋一下,一臺機器既可以是客戶機也可以是服務(wù)器,并且這兩個角色是可以共存的。openssh-clients的功能類似于XShell,可以作為一個客戶端連接上openssh-server。openssh-server的功能主要是作為一個服務(wù)(守護進程)運行在后臺,如果這個服務(wù)開啟了,我們就可以用一些遠程連接工具來連接centos。由于我是用了Centos6.4的mimimal版本,該版本已經(jīng)安裝了openssh-server,但是卻沒有安裝openssh-clients,所以我只需要安裝openssh-clients即可,而具體安裝情況請根據(jù)自己的系統(tǒng)決定。

第二步:生成密鑰,命令如下。

 ssh-keygen –t rsa –P ‘' –f –/.ssh/id_rsa

ssh-keygen是用來生產(chǎn)密鑰的工具。-t:指定生成密鑰的類型(rsa、dsa、ecdsa等);-P:指定passphrase,用于確保私鑰的安全;-f:指定存放密鑰的文件(公鑰和私鑰默認放在相同目錄下面,區(qū)別是,公鑰的文件名有后綴.pub)

第三步:創(chuàng)建用于保存公鑰的文件authorized_keys,并且把本機公鑰添加到此文件,命令如下。

cat ~/.ssh/id_rsa.pub >> ~./ssh/authorized_keys

第四步:對authorized_keys文件進行授權(quán)操作,命令如下。

 chmod 0600 ~/.ssh/authorized_keys

由于每個人使用系統(tǒng)的不同,文件默認的授權(quán)也是不相同的,如果不確定的話,可以執(zhí)行上訴命令,對文件進行授權(quán)。

第五步:登錄,命令如下。

ssh host

5. 總結(jié)和感言

emmm,SSH免密登錄的使用還是挺常見的,也挺簡單的。我覺得吧,凡事不能知其然而不知其所以然,這是我寫這篇博客的目的。同時我也希望讀者能夠通過這篇博客對SSH以及免密登錄能有更好的了解。

這篇博客由于工作的原因,前前后后寫了個把星期,真的很不容易,雖然文中的原理很多是通過學(xué)習(xí)大佬的文章才會的,但是這篇博客中的每個字我都可以負責(zé)任的說是我自己一個一個敲的,所有的圖都是我自己用processOn畫的,如果你有什么問題,可以在博客下留言,我有時間會回復(fù)的。

以上所述是小編給大家介紹的Hadoop框架起步之圖解SSH、免密登錄原理和實現(xiàn)方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

  • kali2021.4a使用virtualenv安裝angr的詳細過程

    kali2021.4a使用virtualenv安裝angr的詳細過程

    在Linux中安裝各種依賴python的軟件時,最頭疼的問題之一就是各個軟件的python版本不匹配的問題,angr依賴python3,因此考慮使用virtualenv來安裝angr,需要的朋友可以參考下
    2022-11-11
  • 詳解git submodule HEAD detached 的問題

    詳解git submodule HEAD detached 的問題

    這篇文章主要介紹了詳解git submodule HEAD detached 的問題,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • 幾道和「黑洞照片」那種海量數(shù)據(jù)有關(guān)的算法問題

    幾道和「黑洞照片」那種海量數(shù)據(jù)有關(guān)的算法問題

    昨晚被一則新聞刷屏:北京時間 4 月 10 日今晚 9 點,人類首張黑洞照片正式發(fā)布
    2019-04-04
  • Caffe圖像數(shù)據(jù)轉(zhuǎn)換成可運行l(wèi)eveldb?lmdb文件

    Caffe圖像數(shù)據(jù)轉(zhuǎn)換成可運行l(wèi)eveldb?lmdb文件

    這篇文章主要為大家介紹了Caffe圖像數(shù)據(jù)轉(zhuǎn)換成可運行l(wèi)eveldb?lmdb文件教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • windows開發(fā)記事本程序紀(jì)實(二)邏輯篇1

    windows開發(fā)記事本程序紀(jì)實(二)邏輯篇1

    從本節(jié)開始介紹windows開發(fā)實現(xiàn)記事本程序的邏輯實現(xiàn)部分。本節(jié)的主要內(nèi)容有以下3點:1. 主窗口定義2. RichEdit控件的選用及初始化3. 整個程序ICON的選擇
    2014-08-08
  • git 優(yōu)雅的撤銷中間某次提交方法

    git 優(yōu)雅的撤銷中間某次提交方法

    這篇文章主要介紹了git 優(yōu)雅的撤銷中間某次提交方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 火車頭采集正文多圖片如何采集下載(只下載一張圖片的情況該如何處理)

    火車頭采集正文多圖片如何采集下載(只下載一張圖片的情況該如何處理)

    文章采集是站長常常會遇到的事,很多人使用火車頭采集器軟件,采集正文中有多個圖片的時候如果設(shè)置錯誤,會遇到只下載一張圖片、采集后的正文多張圖片同一個文件名的情況
    2023-03-03
  • ElasticSearch核心概念

    ElasticSearch核心概念

    Elaticsearch簡稱為es,es是一個開源的高擴展的分布式全文檢索引擎,本文給大家介紹ElasticSearch基礎(chǔ)知識介紹,對ElasticSearch相關(guān)知識感興趣的朋友一起看看吧
    2022-07-07
  • 戲說編碼發(fā)展史

    戲說編碼發(fā)展史

    本文從一個風(fēng)趣的角度詳細介紹了計算機編碼的發(fā)展歷史,十分的有趣,小伙伴們仔細研讀下吧,了解下相關(guān)知識也是非常有必要的。
    2015-01-01
  • delphi使用Chilkat 組件和庫從SFTP下載文件的方法

    delphi使用Chilkat 組件和庫從SFTP下載文件的方法

    這篇文章主要介紹了delphi使用Chilkat 組件和庫從SFTP下載文件的方法,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08

最新評論