SSH服務端配置、優化加速、安全防護

来源:http://www.cnblogs.com/aubin/archive/2017/09/13/7516687.html
-Advertisement-
Play Games

CentOS7自帶的SSH服務是OpenSSH中的一個獨立守護進程SSHD。由於使用telnet在網路中是明文傳輸所以用其管理伺服器是非常不安全的不安全,SSH協議族可以用來對伺服器的管理以及在電腦之間傳送文件。 一、配置文件 伺服器配置文件 /etc/ssh/sshd_config 日誌文件 / ...


CentOS7自帶的SSH服務是OpenSSH中的一個獨立守護進程SSHD。由於使用telnet在網路中是明文傳輸所以用其管理伺服器是非常不安全的不安全,SSH協議族可以用來對伺服器的管理以及在電腦之間傳送文件。

一、配置文件

  • 伺服器配置文件 /etc/ssh/sshd_config
  • 日誌文件 /var/log/secure

二、配置文件詳解

Port    22                  #預設埠
ListenAddress IP            #監聽伺服器端的IP,ss -ntl 查看22埠綁定的iP地址
LoginGraceTime 2m           #登錄時不輸入密碼時超時時間
HostKey                   # HostKey本地服務端的公鑰路徑
UseDNS no                   #禁止將IP逆向解析為主機名,然後比對正向解析的結果,防止客戶端欺騙
PermitRootLogin yes         #是否允許root使用SSH遠程登錄
MaxAuthTries 6              #密碼錯誤的次數6/2=3(MAN幫助中寫明要除2)次後斷開連接
MaxSessions 10              #最大的會話連接數(連接未登錄的會話最大值,預設拒絕舊的連接未登錄的會話)
StrictModes yes             #檢查用戶家目錄中ssh相關的配置文件是否正確
PubkeyAuthentication yes    #是否使用基於key驗證登錄
AuthorizedKeysFile      .ssh/authorized_keys    #key驗證登錄的客戶端公鑰路徑
PasswordAuthentication yes  #是否允許使用密碼登錄
PermitEmptyPasswords no     #用戶使用空口令登錄
GatewayPorts no             #啟用網關功能,開啟後可以將建立的SSH隧道(埠轉發)共用出去
ClientAliveCountMax 3       #探測3次客戶端是否為空閑會話,↓3*10分鐘後斷開連接
ClientAliveInterval 10      #空閑會話時長,每10分鐘探測一次
MaxStartups 10:30:100       #start:rate:full;當連接但為進行認證的用戶超過10個,drop30%(rate/full)的連接當連接但未登錄的連接達到100個後,新建立的連接將被拒絕
Banner /path/file           #認證前輸出的登錄提示信息,指定文件路徑
GSSAPIAuthentication no 
AllowUsers username         #白名單,如果白名單有用戶只有白名單的用戶可以登陸
DenyUsers                  #黑名單,被拒絕的用戶,如果即允許又拒絕則拒絕生效
AllowGroups                 #組白名單
DenyGroups                  #組黑名單

三、免密登錄(基於KEY驗證登錄)

在客戶端成功密鑰對,然後將公鑰複製到要免密登錄的伺服器即可。
註:名稱只能為 authorized_keys ,添加多個公鑰信息可以直接追加>> .ssh/authorized_keys

ssh-keygen -t rsa -p “1234”                     #創建密鑰對,-t類型為rsa,-p私鑰密碼為1234
ssh-copy-id -i ~/.ssh/id_rsa.pub IP     #-i指定公鑰路徑後將公鑰複製到遠程IP ~/.ssh/authorized_keys

四、常見故障

  • 提示 ssh_exchange_identification: Connection closed by remote host
    多數情況為配置文件出錯,可以使用 sshd -T對配置文件進行逐一檢查
  • 提示:server refused our key 免密登錄被拒絕
    使用免密登錄 公鑰文件的許可權不正確所以會拒絕登錄,檢查客戶端複製到服務端的公鑰信息文件許可權是否正確

五、優化加速

伺服器端修改配置文件中一下兩項進行修改

vim /etc/ssh/sshd_conf
UseDNS no               
GSSAPIAuthentication no

UseDNS 會對客戶端進行DNS反向解析,然後在比對正向解析的結果查看是否一致。
GSSAPIAuthentication大多數情況下使用密碼驗證或者秘鑰驗證所以關閉GSSAPI驗證即可

六、日誌分析

  • 查看方式
    手動查看日誌文件 /var/log/secure
    systemctl查看日誌文件systemctl suts sshd

  • 常見警告
    提示:Authentication refused:bad ownership or modes for diectory
    ssh連接的用戶的家目錄下.ssh目錄所有者或者許可權不正確(正確為700),sshd會發出警告但依然允許登錄

七、安全相關

- DOS

SSH也可能成為DOS攻擊的對象,例如惡意用戶連接SSH但不輸入密碼進行驗證,由於設置了MaxStartups會導致正常用戶無法進行登錄。針對此情況建議:

  • 修改預設埠
  • MaxStartups調大一些例如 MaxStartups 100:30:1000
  • LoginGraceTime 10 調整連接超時未10秒
  • MaxSessions 10 設置連接但未登錄的用戶最大值為10

- 其他優化

  • 限制可登錄用戶
  • 設定空閑會話超時時長
  • 充分利用防火牆設置ssh訪問策略
  • 僅監聽指定IP的ssh
  • 禁止使用空口令登錄
  • 禁止使用root直接進行登錄
  • 做好日誌分析
  • 加強用戶登錄的密碼口令

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

-Advertisement-
Play Games
更多相關文章
  • 本節目標: 通過DMA,無需中斷,接收不定時長的串口數據 描述:當在串口多數據傳輸下,CPU會產生多次中斷來接收串口數據,這樣會大大地降低CPU效率,同時又需要CPU去做其它更重要的事情,我們應該如何來優化?比如四軸飛行器,當在不停地獲取姿態控制方向時,又要去接收串口數據.答:使用DMA,無需CPU ...
  • 繼續第三天學習,每天下班後積累一點點,始終相信厚積薄發。 一、處理文件的命令 touch dest_file:在當前目錄下創建指定的文件。 cp source dest:將指定的猿文件複製到目標文件,並且以dest命名。雖然說這個命令有點重命名文件的影子,但是區別就是目標文件有新的修改時間。 cp ...
  • RHEL(Oracle Linxu/CentOS)系統下,如果使用sendmail發送郵件,如果不特殊設置,一般發件箱地址為user@hostname,例如,hostname為DB-Server.localdomain,在root用戶下使用下麵命令發送一封郵件: [root@DB-Server ~]... ...
  • nginx編譯安裝步驟 ①. 檢查軟體安裝的系統環境 cat /etc/redhat-release uname -r ②. 安裝nginx的依賴包(pcre-devel openssl-devel) 假設不進行安裝 yum install -y pcre-devel openssl-devel ③ ...
  • 我們可以把路由器比作網路世界的骨架,我們之所以能夠在網路世界里暢游,很大程度上是得益於這個鐵盒子。 路由器硬體架構 隨著專用多核網路處理器、專用轉發晶元的出現,使得現代路由器擺脫了以往純軟體轉發的局限,向著高吞吐率、硬體快速轉發等方向發展。高端的路由器設計成多板分散式+冗餘備份的架構,使轉發能力成倍 ...
  • 本文目錄: 1.幾個顯示函數2.action函數3.is_true和is_false函數4.confirm函數5.pid檢測相關函數 5.1 checkpid、__pids_var_run和__pids_pidof函數 5.2 pidfileofproc和pidofproc函數6.重頭戲(一):da ...
  • 原文發表於cu:2016-07-04 參考文檔: http://seanlook.com/2015/01/21/openldap-install-guide-ssl/ 一.環境 Server:基於CentOS-7-x86_64-1511 Server IP: 172.18.12.203 OpenLD ...
  • 依賴包和常用包yum install gcc gcc-c++ make zlib-devel readline readline-devel tkutil tk tkutil-devel tk-devel openssl openssl-devel wget vim ntp -y下載rediswge ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...