L07-Linux配置ssh免密遠程登錄

来源:https://www.cnblogs.com/suhaha/archive/2018/05/22/9071216.html
-Advertisement-
Play Games

本文配置可實現:集群伺服器之間相互可以ssh免密登錄。若只想從單一機器(如master)ssh免密登錄其他機器(slave1、slave2),則只跟著操作到第二步即可。 建議先花兩三分鐘把全文看完再跟著步驟操作 操作步驟: 1.集群環境:master、slave1和slave2;操作系統為Cento ...


本文配置可實現:集群伺服器之間相互可以ssh免密登錄。若只想從單一機器(如master)ssh免密登錄其他機器(slave1、slave2),則只跟著操作到第二步即可。

 

建議先花兩三分鐘把全文看完再跟著步驟操作


 

操作步驟:

1.集群環境:master、slave1和slave2;操作系統為Centos7。為接下來敘述方便,除了master,其他所有slave統稱為slaveX

所有伺服器的/etc/hosts文件中都添加了必要的IP到主機名的映射,如下。

192.168.137.20 master

192.168.137.21 slave1

192.168.137.22 slave2

 

2.配置使得master上可免密登錄slaveX。

在master主機上執行以下命令。可以是非root用戶,我操作時用的是hadoop用戶。且根據我到目前為止的測試,用哪個用戶來做配置,最後就只能通過那個用戶實現免密登錄,其他用戶遠程登錄還是需要密碼的。

 2.1 cd ~  //切換到用戶家目錄下

 2.2 ls -al //查看家目錄下有無隱藏路徑是 .ssh。如果沒有,創建一個。註意查看.ssh目錄的許可權,是否是 700 (drwx --- ---), 不是的話修改為700

 2.3 cd .ssh  //進入到.ssh目錄下

 2.4 ssh-keygen -t rsa  //命令執行時連續敲回車符即可;

           //該命令將會用rsa演算法在~/.ssh目錄下生成私鑰id_rsa公鑰id_rsa.pub

 2.5 ssh-copy-id master  //該命令把生成的公鑰文件的內容追加到master的authorized_keys 文件中;

            //註意執行此命令之前authorized_keys文件可能並不存在,沒關係,直接執行該命令就行,會自動生成的,當然也可以自己創建一個;需註意authorized_keys文件的許可權得是600;

            //除了ssh-copy-id命令,也可以用cat  id_rsa.pub >> authorized_keys的方式將公鑰內容追加到authorized_keys 文件中,實在不行你用複製粘貼的方式把內容追加進去應該也是可以的。

            //執行完該步驟之後在master上就可以通過ssh  master命令免密登錄自己了。(在這一步之前即使是通過ssh登錄自己,也是每一次都需要手動輸入密碼的)

            //authorized_keys文件中的內容是以ssh-rsa開頭的一組字元串,如下圖:

註:圖中的主機名跟文中描述的master、slaveX不一致,但是不影響對uthorized_keys 文件中內容格式的理解。

 

 2.6 ssh-copy-id slaveX  //把master的公鑰追加到slaveX的authorized_keys 文件中,之後master可免密登錄slaveX

 

3.配置使得slaveX可以免密登錄集群中其他機器

經過上面第二步之後,在master上便已經可以ssh免密登錄master、slaveX了,但是從slaveX上依然無法ssh免密登錄其他機器(master、slaveX),若想使得slaveX也像master那樣可以免密登錄其他機器,則需要在slaveX上也執行第2步同樣的步驟,即:在slaveX上生成自己的私鑰公鑰對,然後將它的公鑰追加到其他機器的authorized_keys 文件中。

 

綜上,若想配置集群伺服器之間相互可以ssh免密登錄,可以有以下兩種方法:(兩種方法的本質是一樣的,只不過執行的過程步驟有些許不同)

方法一:一臺一臺伺服器地按照第2步那樣操作下去,直到所有機器都配置完成為止;

方法二:所有機器,包括master和slaveX,先分別用ssh-keygen -t rsa命令生成各自的私鑰公鑰對,接著用ssh-copy-id master命令將master和slaveX的公鑰都追加到master的authorized_keys 文件中,當全部追加完畢之後,master的authorized_keys 文件中便已有集群中所有伺服器(包括master自己和其他slave)的公鑰信息了(可知此時集群中所有機器都可免密ssh登錄master了),它是一份完整的公鑰信息文件,這個時候再用scp命令將master上的authorized_keys依次發送到各個slave的~/.ssh/目錄下(scp命令示例:scp ~/.ssh/authorized_keys   hadoop@node01:~/.ssh/)。如此,便使得整個集群相互之間都可以免密ssh登錄了。

 


 

至於下麵這一步,在網上查詢資料時在個別博文中看到操作中有這步,我操作時沒有配置這項,我不知道它對結果有什麼影響,因為我沒有做這步配置也使得ssh免密登錄成功了。如果一定要配置的話,則是在第2步執行之前完成這項配置。

集群中的每台主機上

sudo vim /etc/ssh/sshd_config

開啟下麵的選項

RSAAuthentication yes   //允許用RSA密鑰進行身份驗證

PubkeyAuthentication yes  //允許用公鑰進行身份驗證

AuthorizedKeysFile .ssh/authorized_keys  //本機保存的公鑰的文件(這個比較重要

 

對於/etc/ssh/sshd_config文件,網上查詢到的建議:『除非有必要,否則請不要更改 /etc/ssh/sshd_config 這個檔案的設定值!』因為預設的情況下通常都是最嚴密的 SSH 保護了,因此,可以不需要更動他!

 


 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在bash shell中,環境變數分為: >全局變數 >局部變數 全局變數,不僅對shell可見,對其子進程也可見 查看預設的全局環境變數: 這兩個命令都可以列印全局環境變數 HOME是一個全局環境變數,保存用戶的家目錄 上面說了,全局環境變數對子shell也有用,我們就開啟一個子進程,來驗證一下: ...
  • 大家都知道i.MX RT105x是i.MX RT系列第一款產品,在提這款產品特性的時候,我們往往說的是i.MXRT1052DVL6B的特性,這也是RT105x系列主推的一款核心晶元,目前一些第三方硬體公司(比如ZLG、野火、正點原子、安富萊)做的RT105x開發板基本上都是基於這款晶元,但其實i.M... ...
  • 一款i.MXRT晶元名字共有10部分組成,從晶元名字上我們主要可以得到五種有效信息,分別是所屬子系列、溫度範圍、封裝、最大運行頻率等級、Tapeout版本。 ...
  • 上一次我們講解了vclient 5.5 的安裝以及連接ESXI5.5,但vclient只能管理一臺ESXI,管理多台還需要切換登陸,非常麻煩。所以這次我們就來講解一下vcenter server的相關知識及操作,它可以管理多台esxi主機。 一、實驗拓撲圖 註意:sql和vcenter在一臺主機中。 ...
  • 1、 實驗拓撲圖: 2、 實驗要求 (1) 新建一臺exsi主機,安裝exsi5.5系統。 步驟: 1)新建虛擬機,導入光碟。 2)安裝esxi系統 (2)在exsi主機中,配置IP地址為192.168.10.10,首選dns為202.106.0.20 步驟:1)配置ip和dns後退出 配置完成後按 ...
  • 問題: 最近在使用 wget ,感覺有很多的功能都不會,現在進行寫一篇文章,更新一些wget的使用技巧,防止以後忘記的時候,重新回來進行查閱。 正文: 未完。 ...
  • 在開始先來看一個有意思的東西: 結果是負數!!!! 這個結果理論上是非常不應該的,這已經違背了我們的常識,畢竟正數的乘積,最後的結果應該還是一個正數,但是這裡出現負數的情況,雖然結果不對,但是好在即使我們各種交換順序,結果都是一致的 我們再來試試浮點數呢 從結果看浮點數好像也沒好到哪裡去,也算錯了, ...
  • Nginx使用Location匹配URL進行偽靜態,location [ = | ~ | ~* | ^~ ] uri { ... }中=、~、~*、^*、^~等的區別。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...