使用ssh keys實現免驗證登陸遠程伺服器

来源:https://www.cnblogs.com/zhuangmingnan/archive/2018/05/10/9021718.html
-Advertisement-
Play Games

引言 程式員或者伺服器運維人員在日常工作中,經常會遇到很多台伺服器需要管理的情況,如果伺服器多了,一般的做法都是通過一個ssh客戶端工具來管理,例如:securityCRT、Xshell、putty等遠程工具,這類工具有兩個特點:1.可以將伺服器存儲成一個列表,配置一次伺服器信息之後,下次直接雙擊就 ...


引言

------------------
程式員或者伺服器運維人員在日常工作中,經常會遇到很多台伺服器需要管理的情況,如果伺服器多了,一般的做法都是通過一個ssh客戶端工具來管理,例如:securityCRT、Xshell、putty等遠程工具,這類工具有兩個特點:
1.可以將伺服器存儲成一個列表,配置一次伺服器信息之後,下次直接雙擊就可以使用;
2.可以保存賬號密碼,埠,ip地址等信息,備註一個簡單易記的名字之後,還可以分組管理,實現多台機器的管理;

那麼對於linux的使用者或者沒有工具的人員,如何使用系統自帶的ssh客戶端去實現和遠程伺服器的免密碼登陸呢?本文基於Ubuntu18.04系統,自帶的命令行ssh客戶端測試通過。

 

一、什麼是SSH?
------------------
簡單說,SSH是一種網路協議,用於電腦之間的加密登錄。

如果一個用戶從本地電腦,使用SSH協議登錄另一臺遠程電腦,我們就可以認為,這種登錄是安全的,即使被中途截獲,密碼也不會泄露。

最早的時候,互聯網通信都是明文通信,一旦被截獲,內容就暴露無疑。1995年,芬蘭學者Tatu Ylonen設計了SSH協議,將登錄信息全部加密,成為互聯網安全的一個基本解決方案,迅速在全世界獲得推廣,目前已經成為Linux系統的標準配置。

需要指出的是,SSH只是一種協議,存在多種實現,既有商業實現,也有開源實現。本文針對的實現是OpenSSH,它是自由軟體,應用非常廣泛。

 

 

二、SSH應用的場景
------------------
常見的SSH應用場景有:
1. Git、SVN等CVS(版本控制系統,System Version System)的身份認證,都需要本機生成ssh密鑰對,然後和代碼倉庫進行交換鑒權;
2. 遠程連接伺服器的時候,需要通過ssh客戶端和遠程伺服器互認;
3. 其他需要電腦之間互相認可時候的場景

 

 

三、如何通過ssh keys實現免驗證登陸遠程伺服器(基於Ubuntu18.04)
-----------------

1. 檢查自己本地是否已經生成了ssh的密鑰對,在~/.ssh下有對應的id_rsa(密鑰)、id_rsa.pub(公鑰)文件,如果沒有,可以通過命令 

ssh-keygen

生成,直接回車即可,預設生成在 /home/<username>/.ssh 目錄下
確認.ssh存在並且存在公鑰、密鑰之後進行下一步操作;


2. ssh-copy-id是一個ssh公鑰拷貝工具,在很多系統多都有預裝,通過命令 

ssh-copy-id <username>@<remote_host>

輸入密碼之後,會提示 # Are you sure you want to continue connecting (yes/no)? # 鍵入yes回車即可,這裡的操作是將ssh的公鑰複製到遠程伺服器的可信名單中,下次通過該認證名單即可免驗證登陸伺服器。ssh-copy-id的預設連接埠是22,如果是其他的埠,可以使用命令

ssh-copy-id -p <port> <username>@<remote_host>

配置。

3. 如果配置完成,通過ssh連接登陸命令 

ssh [-p <port>] <username>@<remote_host>

即可實現免驗證登陸遠程伺服器;

4. 如果希望遠程伺服器只能通過ssh密鑰認證登陸,那麼可以關閉遠程伺服器的密碼登陸功能:
  I. 登陸遠程伺服器:

ssh [-p <port>] <username>@<remote_host>

  II.  編輯ssh服務端配置文件

vim /etc/ssh/sshd_config

  III. 搜索修改 PasswordAuthentication <config> ===> PasswordAuthentication no
  IV. 重新啟動ssh服務端程式
  V. 即可禁止通過ssh密碼遠程登陸遠程伺服器

註:第2步可以通過手動將本機的公鑰複製到遠程伺服器的認證密鑰文件中實現相同功能,操作如下:

cat ~/.ssh/id_rsa.pub | ssh [-p <port>] <username>@<remote_host> "mkdir -p ~/.ssh && touch ~/.ssh/authorized_keys && chmod -R go= ~/.ssh && cat >> ~/.ssh/authorized_keys"

該命令主要是將本機的ssh公鑰複製到遠程伺服器的用戶目錄下的.ssh/authorized_keys,實現遠程伺服器對各個客戶端的辨別感知能力

 


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

-Advertisement-
Play Games
更多相關文章
  • ThreadLocal 稱為線程本地存儲,它為每一個使用它的線程提供一個其值(value)的副本。可以將 ThreadLocal<T> 理解成 Map<Thread, T>,即使用當前線程為 key 的一個 Map,ThreadLocal 的 get() 方法從 Map 里取本地變數(本地 valu ...
  • EF Core (EntityFramework Core)是實體關係映射(O/RM)資料庫訪問框架。這個模式的好處就是讓開發人員可以用對象模型來操作資料庫,這是一種對開發人員較為友好的方式。O/RM牛逼在哪?非對象模型操作資料庫,就要直接用sql語言來做大量的CURD操作(Creat 創建;upd... ...
  • StackExchange.Redis 擴展,更簡單的泛型操作,並提供一些的適用於業務場景中的擴展 ...
  • 前言: 前些日子,因為工作原因,接觸到了求解曲線周長,真的是搞了很久,學生時代真的很簡單,但是如今的我來說,忘記了....很多人跟我應該一樣。 所以來鞏固加強一下記憶。一開始的時候,求周長嘛,找公式唄,什麼matlab呀,亂七八糟的,暈,最後找到了可能還不能滿足項目的需求,因為可能計算量過大。(我就 ...
  • 最近看了一句話,說的是在現實生活中,會寫字的人不見得會寫出好文章,學習編程語言就像是學會了寫字,學會了編程語言並不一定能寫出好程式。 我覺得就是很有道理,以前讀書的時候,基本學完了C#中的語法知識,算是入了個門,但是一到寫程式就毫無頭緒,做出來的程式就像是小學生日記,僅僅只是用一些簡單的api把功能 ...
  • 這兩天在摸索WCF中的共用埠,參考了下麵的博客WCF:如何將net.tcp協議寄宿到IIS[WCF實踐]1.WCF使用net.tcp寄宿到IIS中這兩篇博客中提到的內容解決了實際開發中大多數的問題。這裡根據自己實踐,也總結一下寫在這裡:依照上面的兩篇博文,如果還是遇到下麵的錯誤提示:已嘗試創建到達... ...
  • 1、pipe 本質: 匿名管道 內核緩衝區 偽文件(偽文件和操作文件類似) 創建方式: fd[0] 表示讀端 fd[1] 表示寫端 返回值: 成功返回0,失敗返回-1 特點: 有讀端和寫端,對應兩個文件描述符,數據從寫端流入,讀端流出 操作管道的進程掛掉後管道自動釋放 管道預設是阻塞的 管道原理: ...
  • 一、用戶與群組 Linux是多人多任務的操作系統,每個用戶有一個主目錄(或者叫家目錄 /home),其他用戶可以瀏覽,但是能否查看文件要看具體的許可權設置。文件擁有者可以修改許可權,選擇是否允許其他用戶進行查看或者編輯等操作。在團隊工作中,群組的概念非常有用,文件擁有者可以通過許可權設定,賦予相應群組一定 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...