安全運維之遠程訪問

来源:https://www.cnblogs.com/lynk/archive/2019/12/21/12076043.html
-Advertisement-
Play Games

為了方便使用,一般伺服器都會通過配置遠程訪問來保證隨時配置伺服器,但是不正確的遠程訪問配置會對系統產生安全隱患,產生被入侵的風險。 使用安全的登錄認證方式 現代伺服器環境往往需要用戶遠程登錄,而遠程登錄本身就具有一定的安全風險————中間人攻擊。 在早期,telnet是一種常用的登錄方式,但它過於古 ...


為了方便使用,一般伺服器都會通過配置遠程訪問來保證隨時配置伺服器,但是不正確的遠程訪問配置會對系統產生安全隱患,產生被入侵的風險。

使用安全的登錄認證方式

現代伺服器環境往往需要用戶遠程登錄,而遠程登錄本身就具有一定的安全風險————中間人攻擊。
在早期,telnet是一種常用的登錄方式,但它過於古老,而且使用明文傳輸,這使得對其的攻擊代價十分之小,極易遭到攔截與偽造。現代遠程登錄已經基本拋棄了telnet,而是通過SSH服務遠程登錄伺服器。
SSH會加密所有的傳輸數據,並且可以防禦DNS和IP欺騙,經過SSH壓縮的數據也可以提高遠程訪問的傳輸效率。
SSH在服務端運行的是sshd服務,sshd服務對應的主配置文件是/etc/ssh/sshd_config

使用強密碼

很多時候,為了方便記憶,用戶往往會使用一些簡單的密碼。例如自己的生日、某個時間點或者一些其他內容,但這些密碼其實安全性很低,在撞庫攻擊下很容易就受到攻破。所以建議使用隨機生成的高位強密碼,並周期性更換。
Linux系統自帶的openssl就可以生成一串強密碼供用戶使用,建議使用32位以上的強密碼,這樣可以有效的防止撞庫攻擊。
如生成一串十六位的密碼:

$ openssl rand -base64 16
WjzyDqedkWf3e5A3tJw/c=

使用密鑰認證

使用強密碼認證仍存在一定的風險,如管理員忘記或遺失密碼,甚至泄露密碼。而密鑰認證則是一種更加安全的認證方式,因為其將密鑰文件存儲在客戶端與伺服器中,不必輸入密碼就可以進行登錄,避免了密碼泄露的風險。
這裡以Xshell6為例,講解通過密鑰認證方式遠程登錄Linux伺服器的實現方法。

  1. 首先打開Xshell,選擇“工具-新建用戶密鑰生成嚮導”,進入密鑰生成視窗。選擇密鑰類型為RSA,長度建議至少為1024位。點擊下一步
  2. 等待密鑰生成,生成完畢後直接點擊下一步。
  3. 輸入密鑰信息,以及密鑰密碼,點擊下一步。
  4. 點擊“保存為文件”,將pub尾碼的公鑰保存到本地,完成。
  5. 此時私鑰已經被Xshell保存在本地了,通過“工具-用戶密鑰管理者”可以查看生成的密鑰。
  6. 到目前為止,已經成功的生成密鑰,並將公鑰與私鑰都保存在了本地,接下來我們需要設置用戶使用SSH2協議,如,將user01設置為使用SSH2登錄
$ mkdir /home/user01/.ssh
$ chmod 700 /home/user01/.ssh

然後將公鑰上傳到伺服器,並且導入密鑰,在將公鑰上傳後,使用以下命令將公鑰導入到伺服器,並修改公鑰文件的許可權:

$ ssh-keygen && cat /上傳公鑰的路徑/id_rsa_2048.pub >> /home/user01/.ssh/authorized_keys
$ chmod 600 /home/user01/.ssh/authorized_keys
  1. 為了伺服器的安全,我們還需要將SSH2修改為只能接受PublicKey認證的方式來驗證用戶:
$ vim /etc/ssh/sshd_config
##修改以下配置:
Protocol 2                             #僅允許使用SSH2
PubkeyAuthentication yes               #啟用PublicKey認證
AuthorizedKeyFile .ssh/authorized_keys #PublicKey文件路徑
PasswordAuthentication no              #不使用口令認證

最後重啟sshd服務:

$ systemctl restart sshd
  1. 接下來就可以使用密鑰方式來登錄伺服器了,在Xshell的會話屬性中,將用戶身份認證方式改為PublicKey方式,並且選擇用戶密鑰就可以使用密鑰方式登陸伺服器。

shell命令日誌

用戶在shell中的操作記錄會被保存在用戶目錄下的.bash_history文件中,通過這個文件可以查詢shell命令的執行歷史,有助於進行系統審計與問題排查。
並且,在遭受到黑客攻擊後,也可以通過這個文件查詢黑客登錄伺服器所執行的歷史命令操作,但是黑客在攻擊會為了毀滅痕跡而刪除.bash_history文件,所以我們要對該文件進行保護。
預設的.bash_history並不會區分不同用戶操作命令與執行時間,我們可以通過以下方式來讓history命令記錄所有的shell命令的執行時間,編輯/etc/bashrc文件:

HISTFILESIZE=4000        #定義保存命令的總數
HISTSIZE=4000            #定義輸出的命令總數
HISTTIMEFORMAT='%F %T'   #定義時間格式
export HISTTIMEFORMAT    #傳遞變數

然後可以利用以下方法來實現詳細記錄登陸過系統的用戶、IP地址、shell命令以及詳細操作時間,並將這些信息以文件方式保存在一個安全的目錄,
將以下代碼添加到/etc/profile文件中:

#history
USER_IP='who -u am i 2>/dev/null| awk '{print SNF}'|sed -e 's/[()]//g''
HISTDIR=/usr/share/.history
if [ -z $USER_IP ]
then
USER_IP='hostname'
fi
if[ ! -d $HISTDIR ]
then
mkdir -p $HISTDIR

chmod 777 $HISTDIR
 fi
 if [ ! -d $HISTDIR/${LOGNAME} ]
 then
 mkdir -p $HISTDIR/${LOGNAME}
 chmod 300 $HISTDIR/${LOGNAME}
 fi
 export HISTSIZE=4000
 DT='date +%Y$m$d_%H%M%S'
 export HISTFILE="$HISTDIR/${LOGNAME}/${USER_IP}.history.SDT"
 export HISTTIMEFORMAT="[%Y.%m.%d %H:%M:%S]"
 chmod 600 $HISTDIR/${LOGNAME}/*.history* 2>/dev/null

tcp_wrappers防火牆

tcp_wrappers是Linux中用於分析TCP/IP數據包的軟體,類似的如iptables,與iptables不同的是,iptables通過監視系統運行狀態阻擋惡意攻擊。而tcp_wrappers可以實現對系統中提供某些服務的控制。
tcp_wrappers有一個TCP的守護進程叫作tcpd。以ssh為例,每當有ssh的連接請求時,tcpd即會截獲請求,先讀取系統管理員所設置的訪問控制文件,符合要求,則會把這次連接原封不動的轉給真正的ssh進程,由ssh完成後續工作;如果這次連接發起的ip不符合訪問控制文件中的設置,則會中斷連接請求,拒絕提供ssh服務。

但tcp_wrappers仍存在有一定的局限性,Linux中的一個服務是否可以使用tcp_wrappers,取決於服務是否應用了libwrapped庫文件,系統中預設的一些服務,如sshd、portmap、sendmail、xinetd、vsftpd、tcpd等都可以使用tcp_wrappers。

我們可以通過以下命令來檢查系統中是否安裝有tcp_wrappers

$ rpm -q tcp_wrappers

如果輸出有關tcp_warppers的信息,則說明系統中已經安裝了tcp_warppers。

tcp_wrappers有兩個配置文件:/etc/hosts.allow/etc/hosts.deny
Linux對配置文件的執行是順序的,先讀取/etc/hosts.allow,一旦滿足就應用,而拋棄後面的配置,所以可以只設定/etc/hosts.allow文件,然後在/etc/hosts.deny中設置為所有電腦都不能登陸。
配置文件準從如下語法:

service:host(s) [:action]

其中,

  • service:服務名,如sshd、vsftpd、sednmail等
  • host(s):主機名或IP地址,可以有多個。
  • action:動作,符合條件後採取的動作。
    常見關鍵字有:
  • ALL:所有服務或所有IP。
  • ALL EXCEPT:除指定的以外所有的服務或IP。

例如:

ALL:ALL EXCEPT 192.168.123.8

表示除192.168.123.8以外的請求都會被允許或拒絕,取決於以上內容寫在哪個配置文件里。

附錄

/etc/ssh/sshd_config文件內容

文本 作用
Port 22 用來設置sshd監聽的介面,建議修改為5位數字以上的陌生數字埠
Protocol 2 設置使用的SSH協議版本為SSH1或SSH2,SSH1存在漏洞,建議不變
ListenAddress 0.0.0.0 用於設置sshd伺服器綁定的IP地址
HostKey /etc/ssh/ssh_host_dsa_key 用於設置伺服器密鑰文件的位置
KeyRegenerationInterval 1h 用於設置生成密鑰的周期。可以防止入侵者利用盜取的密鑰
ServerKeyBits 1024 用於定義密鑰長度
SyslogFacility AUTHPRIV 用於設置在記錄來自sshd的消息時,是否給出facility code
LogLevel INFO 用於設置log文件的消息級別
LoginGraceTime 2m 如果用戶登錄失敗,在切斷鏈接前。伺服器需要等待的時間。
PermitRootLogin no 是否允許root用戶登錄,建議設置為no
StrictModes yes 用於設置SSH在接受登陸請求之前是否檢查用戶根目錄和rhosts文件的許可權和屬主。建議設置為yes
RSAAuthentication no 設置是否開啟RSA密鑰認證,只針對SSH1,使用RSA密鑰登錄時,需要開啟
PubkeyAuthentication yes 設置是否使用公鑰驗證,使用公鑰驗證時,需要開啟
authorizedKeyFile .ssh/authorized_key 用於設置公鑰文件路徑,與PubkeyAuthenticatio配合使用
IgnoreUserKnownHosts no 用於設置SSH在進行RSAAuthentication安全認證時忽略用戶的$HOME/.ssh/known_hosts文件
IgnoreRhosts yes 用於設置驗證時是否使用~/.rhosts~/.shosts文件。
PassWordAuthentication yes 用於設置是否開啟密碼驗證
PermitEmptyPasswds no 用於設置是否允許用空密碼登錄系統,必須為no
ChallengeResponseAuthenthtication no 禁用s/key密碼
UsePAM no 是否使用PAM認證
X11Forwarding yes 用於設置是否允許X11轉發
PrintMotd yes 用於設置是否顯示歡迎登錄信息,建議加入警告信息以震懾攻擊者
PrintLastLog no 是否顯示上次登錄信息
Compression yes 是否壓縮命令
TCPKeepAlive yes 是否防止死鏈接,通過心跳包的方式來進行連接
UseDNS no 是否使用DNS反向解析
MaxStartups 允許幾個尚未登陸的連接,已建立的連接不算入其中。設置為5個可以防止對伺服器進行惡意連接
MaxAuthTries 3 設置最大失敗嘗試登陸次數,合理設置可以防禦撞庫攻擊
AllowUser <用戶名> 指定用戶允許通過遠程登錄訪問,多個用戶以空格分隔
AllowGroups <組名> 指定用戶組允許通過遠程登錄訪問,多個用戶組以空格分隔
DenyUsers <用戶名> 指定用戶禁止通過遠程登錄訪問,多個用戶以空格分隔
DenyGroups <組名> 指定用戶組禁止通過遠程登錄訪問,多個用戶組以空格分隔

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

-Advertisement-
Play Games
更多相關文章
  • 接下來我們在 Centos7 系統下使用 yum 命令安裝 MySQL,需要註意的是 CentOS 7 版本中 MySQL資料庫已從預設的程式列表中移除,所以在安裝前我們需要先去官網下載 Yum 資源包: 使用yum安裝mysql: 啟動mysql,並查看mysql運行狀態: 安裝成功,找出mysq ...
  • 引言 具體不記得是在群里還是什麼地方有人問過,.NETCore有沒有漢化包,答案是有,目前微軟已經為我們提供了.NETCore多種語言的語言包。下麵看看如何安裝與使用吧。 本文介紹: 如何安裝這些下載的本地化版本。 如何修改Visual Studio安裝以使用其他語言。 先決條件 .NET Core ...
  • 簡介 LiteByte是一種輕量級的二進位數據交換格式。體積小巧、簡單易用是設計目標。主要用於解決前後臺數據傳輸量的問題。 作者:冰封百度(ZhangYu)設計的靈感來源於C# struct記憶體對齊後的緊湊格式。暫時只實現了C#版本。 特點 1.緊湊的二進位數據格式,支持變長整型,數據量小。2.用近 ...
  • 在上一篇文章abp(net core)+easyui+efcore實現倉儲管理系統——ABP WebAPI與EasyUI結合增刪改查之四(三十) 中我們實現了新增組織部門信息功能,不過還存在一些BUG,如下圖。“自動展開和子級”沒有顯示,“上級組織”下拉框中沒有數據顯示。今天我們來繼續完善組織部門信... ...
  • 16.1.1 進程與程式 ·程式 (program):通常為 binary program ,放置在儲存媒體中 (如硬碟、光碟、軟盤、磁帶等), 為實體文 件的型態存在; ·進程 (process):程式被觸發後,執行者的許可權與屬性、程式的程式代碼與所需數據等都會被載入記憶體中, 操作系統並給予這個內 ...
  • 電子產品要正常工作,就離不開電源。像手機、智能手環這種消費類電子,其充電介面都是標準的接插件,不存在接線的情況,更不會存在電源接反的情況。但是,在工業、自動化應用中,有很多產品是需要手動接線的,即使操作人員做事情再認真,也難免會出錯。如果把電源線接反了,可能會導致產品被燒掉。 圖1 - 手工接線 那 ...
  • 最近發現一個問題,ps命令輸出裡面進程狀態為S+的含義,網上好多文章都說是表明進程“位於在後臺進程組”。 例如下麵這個ps命令輸出說明: 但其實這是不對的,後面有加號說明進程是“位於在前臺進程組”。也就是進程可以使用鍵盤輸出。下麵做一個試驗證明這點: 首先,在終端一個會話執行一個sleep命令,讓其 ...
  • 有些時候,一些很好的開源產品有很好的功能特征,並且能夠提供很好的服務,下麵我進行簡要記錄,以後建立新的環境的時候,可以參考: 私有雲: Seafile: https://www.seafile.com/home/ Owncloud: https://owncloud.org/ 保持更新: 保持更新, ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...