使用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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...