Ubuntu 上開啟 SSH 服務、禁用密碼登錄并僅允許密鑰認證

1. 安裝 OpenSSH 服務

如果尚未安裝 SSH 服務,運行以下命令:

sudo apt update
sudo apt install openssh-server

2. 啟動 SSH 服務并設置開機自啟

sudo systemctl start ssh
sudo systemctl enable ssh

3. 生成 SSH 密鑰對(本地機器)

在本地終端生成密鑰對(如未生成過):

ssh-keygen -t ed25519 -C "your_email@example.com"
  • 默認保存路徑:~/.ssh/id_ed25519(私鑰)和 ~/.ssh/id_ed25519.pub(公鑰)。
  • 可選設置密鑰密碼(增強安全性)。

Ubuntu 22.10 及更高版本默認禁用了 ssh-rsa 簽名算法(基于 SHA-1 哈希算法),原因是該算法存在安全風險,OpenSSH 從 8.7 版本開始不再默認支持,所有這里沒有使用rsa簽名算法


4. 將公鑰上傳到服務器

使用 scp 自動上傳公鑰:

 scp .\.ssh\id_ed25519.pub username@server_ip:~/.ssh

復制公鑰內容到服務器的 ~/.ssh/authorized_keys 文件:

sudo cat ~/.ssh/id_ed25519.pub > ~/.ssh/authorized_keys

5. 禁用密碼登錄

編輯 SSH 配置文件:

sudo nano /etc/ssh/sshd_config

修改以下參數:

PasswordAuthentication no
PubkeyAuthentication yes

保存后重啟 SSH 服務:

sudo systemctl restart ssh

6. 驗證配置

  • 測試密鑰登錄
    ssh username@server_ip
    
    應無需輸入密碼直接登錄(若密鑰有密碼則需輸入密鑰密碼)。
  • 檢查密碼登錄是否禁用
    ssh -o PreferredAuthentications=password -o PubkeyAuthentication=no username@server_ip
    
    應提示 Permission denied

7. 防火墻配置(可選)

若啟用 UFW 防火墻,允許 SSH 端口(默認 22):

sudo ufw allow ssh

注意事項

  • 備份密鑰:私鑰(id_ed25519)需妥善保管,丟失將無法登錄。
  • 緊急恢復:禁用密碼前確保密鑰登錄可用,否則可能被鎖。
  • 配置文件路徑:若修改無效,檢查 /etc/ssh/sshd_config.d/ 下的附加配置。

通過以上步驟, Ubuntu 系統將僅允許 SSH 密鑰認證,顯著提升安全性。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/82425.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/82425.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/82425.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

MySQL 索引的增刪改查

MySQL 索引的增刪改查 1 建表時創建索引 [UNIQUE|FULLTEXT|SPATIAL] INDEX|KEY [別名] (字段名 [(長度)] [ASC|DESC] )主鍵直接寫: PRIMARY KEY (Id)例如: CREATE TABLE people (id int NOT NULL PRIMARY KEY AUTO_INCREMENT,last_name varchar(10)…

為什么現代CSS應該選擇OKLCH:從顏色科學到設計系統革新

在數字界面中,顏色不僅是美學的載體,更是信息傳遞的重要工具。CSS Color Level 4 標準引入了 OKLCH 顏色空間, 提供??感知均勻性??(顏色差異與實際視覺感受一致),解決傳統HSL/HSV在調整顏色時的不自然問題。文本幫…

【java】小練習--零錢通

文章目錄 前言一、項目開發流程說明二、功能實現2.1 菜單2.2 零錢通明細2.3 零錢通收益2.4 零錢通消費2.5 零錢通退出確認2.6 零錢通金額校驗2.7 完整代碼 三、零錢通OOP版 前言 本文是我跟著B站韓順平老師的 Java 教程學習時動手實現“零錢通”項目的學習筆記,主要…

人工智能數學基礎實驗(四):最大似然估計的-AI 模型訓練與參數優化

一、實驗目的 理解最大似然估計(MLE)原理:掌握通過最大化數據出現概率估計模型參數的核心思想。實現 MLE 與 AI 模型結合:使用 MLE 手動估計樸素貝葉斯模型參數,并與 Scikit-learn 內置模型對比,深入理解參…

我的第1個爬蟲程序——豆瓣Top250爬蟲的詳細步驟指南

我的第1個爬蟲程序——豆瓣Top250爬蟲的詳細步驟指南 一、創建隔離開發環境 1. 使用虛擬環境(推薦venv) # 在項目目錄打開終端執行 python -m venv douban_env # 創建虛擬環境 source douban_env/bin/activate # Linux/macOS激活 douban_env\Scri…

STM32八股【11】-----Linux Bootloader (U-Boot)

參考U-Boot U-Boot是什么 嵌入式Linux系統需要一個bootloader來加載系統 U-boot就是一個通用開源的嵌入式Linux bootloader 主要實現的功能: 初始化硬件資源(如內存、串口、存儲器等)從存儲介質加載Linux內核到內存中傳遞啟動參數給內核啟…

【設計模式】責任鏈+模板+工程模式使用模板

前言 方便寫出優雅,解耦,高內聚,高復用的代碼。 Demo // 1. 定義驗證器接口(責任鏈模式) public interface Validator {Validator setNext(Validator next);boolean validate(Data data); }// 2. 創建抽象驗證器&am…

Unity3D仿星露谷物語開發49之創建云杉樹

1、目標 創建一顆既可以生長又可以砍伐的云杉樹,這個和之前創建橡樹類似。 2、創建云杉樹預制體 創建新物體命名為CropTreeBlueSpruce,并且添加Box Collider 2D和Crop組件。 在CropTreeBlueSpruce下創建子物體命名為CropSprite,添加3個組件…

【C#】消息隊列的使用

在C#中使用消息隊列,通常是指使用微軟的Message Queuing (MSMQ)技術。MSMQ提供了一種異步通信協議,允許應用程序通過暫時存儲要發送到目的地的消息來相互通信。 安裝MSMQ 首先,確保你的開發機器和部署服務器上都安裝了MSMQ。可以通過“控制…

IP-guard發布新版本4.87.2241.0

IP-guard發布新版本4.87.2241.0 新版本下載地址: https://www.tec-development.com/down/IPguard/Release/V4/IPguard4.87.2241.0.zip?s=901D45ADB22CBBFE5C612DC40AFD6BFB1551A9CD54EF418D5E86BBD256813867 新版本升級地址:

【Linux 服務器磁盤映像備份與恢復實戰指南】虛擬機備份,物理機上云都可以用這套方案!

Linux 服務器磁盤映像備份與恢復實戰指南 背景 在服務器運維中,磁盤健康度下降可能導致數據丟失風險,特別是在未配置 RAID 的情況下。針對這種情況,備份磁盤數據并恢復到新設備是確保數據安全的關鍵。本文記錄了使用 dd 命令通過 NFS 實現全…

深入理解 Linux 的 set、env 和 printenv 命令

在 Linux 和類 Unix 系統中,環境變量是配置和管理 Shell 及進程行為的核心機制。set、env 和 printenv 是與環境變量交互的三個重要命令,每個命令都有其獨特的功能和用途。本文將詳細探討這三個命令的區別,幫助大家更好地理解和使用這些命令。…

icexmoon-tree

icexmoon-tree 一個輕量級的 Java 工具庫&#xff0c;提供樹形結構操作功能。 安裝 <dependency><groupId>cn.icexmoon</groupId><artifactId>icexmoon-tree</artifactId><version>1.0.0</version> </dependency>使用 構建…

機器學習在智能水泥基復合材料中的應用與實踐

“機器學習在智能水泥基復合材料中的應用與實踐” 課程 內容 機器學習基礎模型與復合材料研究融合 機器學習在復合材料中的應用概述機器學習用于復合材料研究的流程復合材料數據收集與數據預處理 實例&#xff1a;數據的收集和預處理 復合材料機器學習特征工程與選擇 實例&a…

微軟 Build 2025:開啟 AI 智能體時代的產業革命

在 2025 年 5 月 19 日的微軟 Build 開發者大會上&#xff0c;薩提亞?納德拉以 "我們已進入 AI 智能體時代" 的宣言&#xff0c;正式拉開了人工智能發展的新紀元。這場匯聚了奧特曼、黃仁勛、馬斯克三位科技領袖的盛會&#xff0c;不僅發布了 50 余項創新產品&#…

[Java惡補day6] 15. 三數之和

給你一個整數數組 nums &#xff0c;判斷是否存在三元組 [nums[i], nums[j], nums[k]] 滿足 i ! j、i ! k 且 j ! k &#xff0c;同時還滿足 nums[i] nums[j] nums[k] 0 。請你返回所有和為 0 且不重復的三元組。 注意&#xff1a;答案中不可以包含重復的三元組。 示例 1&a…

《黃帝內經》數學建模與形式化表征方式的重構

黃帝內經的數學概括&#xff1a;《黃帝內經》數學建模與形式化表征方式的重構 摘要&#xff1a;《黃帝內經》通過現代數學理論如動力系統、代數拓撲和隨機過程&#xff0c;被重構為一個形式化的人體健康模型。該模型包括陰陽動力學的微分幾何、五行代數的李群結構、經絡拓撲與同…

理論篇五:如何優化Webpack的打包速度

優化 Webpack 打包速度是提升前端開發效率的關鍵。以下是 10 種核心優化策略,涵蓋開發和生產環境,附帶具體配置和實測效果對比: 一、縮小文件搜索范圍 1. 指定解析路徑(Resolve) resolve: {extensions: [.js, .jsx],

[Windows] 游戲常用運行庫- Game Runtime Libraries Package(6.2.25.0409)

游戲常用運行庫 合集 整合了許多游戲會用到的運行庫&#xff0c;支持 Windows XP – Windows 11 系統&#xff0c;并且支持自動檢測系統勾選推薦的運行庫&#xff0c;方便快捷。 本版特點&#xff1a; By&#xff1a;mefcl 整合常見最新游戲所需運行庫 根據系統自動勾選推薦…

JDK8中的 Stream流式編程用法優化(工具類在文章最后)

Java從JDK8起提供了Stream流這個功能&#xff0c;于是項目里出現了大量基于Stream流的寫法。隨著項目的進行&#xff0c;慢慢的代碼中鋪天蓋地的都是下面的寫法&#xff1a; List<User> userList null;if (condition) {userList new ArrayList<>();userList.add(…