終於,病毒向我伸出了魔爪......

来源:https://www.cnblogs.com/starry-skys/archive/2020/07/17/13332666.html
-Advertisement-
Play Games

前言 伺服器好端端的竟然中了挖礦病毒!!! 可憐我那 1 核 2 G 的伺服器,又弱又小,卻還免除不了被拉去當礦工的命運,實在是慘啊慘。 事情原來是這樣的。。。 就在今天下午,我準備登陸自己的遠程伺服器搞點東西的時候,突然發現 ssh 登陸不上了。 如上,提示被拒絕。這個問題很明顯就是伺服器沒有我的 ...


前言

伺服器好端端的竟然中了挖礦病毒!!!

可憐我那 1 核 2 G 的伺服器,又弱又小,卻還免除不了被拉去當礦工的命運,實在是慘啊慘。

事情原來是這樣的。。。

就在今天下午,我準備登陸自己的遠程伺服器搞點東西的時候,突然發現 ssh 登陸不上了。

如上,提示被拒絕。這個問題很明顯就是伺服器沒有我的公鑰,或者不識別我的公鑰,然後拒絕登錄。

這就很難辦了,我確定我的公鑰是一直沒有變動過的,不應該會出現這種情況啊。

還有讓我頭疼的是,我當初為了安全起見,設置過此台伺服器只能通過 ssh 的方式免密登錄。而且禁止了密碼直接登錄,這樣也防止了別人通過破解我的密碼而登錄伺服器。

當前,只有我這個 mac 還有家裡的 win 兩臺電腦有 ssh 許可權。(其實,當時我也想到了這種情況,就怕萬一有一天某臺電腦登錄不上,另外一臺還能做備選。嘿嘿,我是不是很機智!)

那麼,目前的解決辦法,就是要麼等著下班回家,用另外一個電腦操作,把當前這個電腦的公鑰加到伺服器的authorized_keys 文件里。要麼,就只能把伺服器重裝了。

但是,好奇心驅使我去探究一下,到底是什麼原因導致了伺服器連接不上,而不是直接重裝伺服器。那樣的話,就太沒意思了。

通過 VNC 方式登錄伺服器

因為我用的是騰訊雲伺服器嘛,於是,就登錄到了騰訊雲的控制台,想看一下是否還有其它“走後門”的方式,讓我繞過 ssh 或者不受密碼登錄的限制。

沒想到,還真的有方法。如下圖,可以通過 VNC 的方式進去,然後輸入賬號密碼就可以直接登錄,不受限制。

可以看到已經進入伺服器了。上一次登錄時間是昨天下午,這個時間點沒錯。

發現問題

當然,正常來講,我應該先去 authorized_keys 文件檢查一下我的公鑰是否有問題。但是,習慣性的操作讓我 top 了一下,卻發現了另外一個問題。

等等,這是什麼鬼! 有一個 sysupdate 進程占用了 CPU 51.2%,另外還有一個進程 networkservice 占用了 47.8% 。這兩個加起來,就已經占用了 99% 了。

實際上,在騰訊雲後臺也能監控到伺服器的實時狀況。

很明顯,這兩個進程是比較異常的。而且,之前也沒有見過這種名字。於是,習慣性的,我就在網上搜了一下 sysupdate。直接,就出來了一堆結果,挖礦病毒。

我去,聽這名字,難不成就是傳說中的比特幣挖礦?不管那麼多了,先解決當前的問題吧。

解決問題

1、確認病毒位置

先通過 systemctl status {進程號} 查看一下它的狀態信息,以及有沒有相關聯的進程。以 sysupdate 進程號 16142為例。

可以發現它是從昨天晚上九點開始運行起來的。怪不得,昨天下午下班前還能用,今天就不能用了。

還可以通過 ls -l proc/{進程號}/exe 命令查看它具體的位置。最後發現都在 /etc 目錄下。

如上圖,這五個都是“挖礦病毒所用到的文件”。哼哼,從顏色上就能看出來他們是一伙的。

然而,我並沒有著急把它們清除掉,卻突然腦子一抽,想研究一下它們的腳本。因為我看到有一個 update.sh ,裡邊肯定寫了一些病毒執行相關的命令。

我把他們全部都複製到了我自己的目錄下 /root/test/。然後打開了 update.sh 腳本,看裡邊寫了些什麼。

我估計,能看著伺服器都被病毒攻擊了,還有閑情研究人家是怎麼製作病毒的,我是第一個吧。。

雖然菜雞我對 linux 不熟,但是大概可以看出來一些東西,如SELINUX 系統被關閉了,我的 authorized_keys 文件也被改動了,竟然無恥的還把 wget、curl 等命令改了名字。

下邊,還可以看到病毒腳本的網路路徑。難不成是從這個地址下載下來的?

2、刪除定時任務

看一下有沒有定時任務,因為有可能它會跑一個定時任務,定時的執行腳本,生成病毒文件和進程等。

可以進入 /var/spool/cron/ 目錄查看定時任務。也可以通過 crontab -l查看。

沒想到卻都沒有發現。

如果有的話 ,刪除 /var/spoool/cron/目錄下的所有文件。或者執行crontab -r命令,清空任務列表。

3、殺掉進程,刪除病毒文件

kill -9 {進程號} 把上邊的兩個進程都殺掉,然後刪除 /etc 目錄下的那五個文件。

註意刪除文件時,直接用普通的 rm -rf 不能行。因為病毒文件被鎖定了,需要通過 chattr -i {文件名} 解鎖之後,再刪除。

4、刪除 authorized_keys 文件

這個文件里記錄了可以通過 ssh 免密登錄的所有終端的公鑰。路徑在 ~/.ssh/authorized_keys 。通過 vi 命令打開。

可以看到文件里已經被改動了,多了兩個未知的公鑰,這肯定就是攻擊者的公鑰。前面的三個都是我自己的公鑰。

可以直接刪除此文件,等稍後再修複為自己的公鑰。

5、恢復 wget 和 curl 命令

從 update.sh 文件中可以看到這兩個命令名稱被改了,對於習慣了這樣使用的人來說肯定不爽,那就改回來就好了。

如下為可選的的命令。我這裡就需要前兩行就行了,因為 which cur 之後發現,只存在 /bin下,/usr/bin/不存在

mv /bin/wge /bin/wget
mv /bin/cur /bin/curl
mv /usr/bin/wge /usr/bin/wget
mv /usr/bin/cur /usr/bin/curl

6、修複 SELINUX

SELinux 是 linux 的一個安全子系統。可以通過命令 getenforce 查看服務狀態。

其實從 update.sh 文件中也可以看到此服務被關閉了。

修改 /etc/selinux/config 文件,將 SELINUX=disabled 修改為 SELINUX=enforcing。

修改完成後,需要重啟伺服器才能生效。

找到原因

其實,以上步驟搞完,還差一步。

你總不能被攻擊的不明不白吧,為什麼別人會攻擊到你的伺服器呢。

後來,從網上找到了一篇介紹,說:

挖礦病毒,利用Redis的未授權訪問漏洞進行攻擊。
Redis 預設配置為6379埠無密碼訪問,如果redis以root用戶啟動,攻擊者可以通過公網直接鏈接redis,向root賬戶寫入SSH公鑰文件,以此獲取伺服器許可權註入病毒

我去,看完之後,感覺這個描述簡直不能太準了。

因為,昨天下午,我就是因為要測試通過 redis 的 zset 來實現延時隊列的一個功能。用本地代碼連接了伺服器的 redis 。當時就在防火牆中把 6379 埠打開了。

誰曾想,一晚上的功夫,就被人家攻擊了。

我想,挖礦人肯定也是找大量的機器來實驗,看能否通過這些漏洞(肯定不限於只有 redis),操縱對方的伺服器。於是,我就幸運的成為了那個倒霉蛋。

最後,我粗暴的把 redis 服務關了,並且去掉了 6379 的埠。

額,其實有更溫柔的方案可選,比如更改 redis 的預設埠號,或者給 redis 添加密碼。

最後

感覺整篇下來,好像除了知道 redis 的這個漏洞外,就沒有其他收穫了。主要是,我的安全意識還是比較薄弱吧。

畢竟,伺服器只是拿來玩玩用的。最後實在不行也可以重裝系統,完事又是一條好漢。

公司的伺服器肯定不會這樣的,都有專門的運維人員來做這些安全工作。如果是線上伺服器被人家拉去挖礦,好歹能拿我這篇文章吹牛逼了。。。


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

-Advertisement-
Play Games
更多相關文章
  • 第12章 創建引用 12.1什麼是引用 引用是一個別名。創建引用時,使用另一個對象(目標)的名稱來初始化它,從此以後該引用就像是目標的另一個名稱,對引用執行的任何操作實際上針對的就是目標。 有些書上說引用就是指針,這不正確。雖然引用常常是使用指針實現的,但是只有編譯器開發人員關心這一點,作為程式員, ...
  • Mac安裝oracle(使用Docker) 博客說明 文章所涉及的資料來自互聯網整理和個人總結,意在於個人學習和經驗彙總,如有什麼地方侵權,請聯繫本人刪除,謝謝! 安裝 拉取oracle 11g 鏡像,這個版本可以自行選擇 docker pull registry.cn-hangzhou.aliyu ...
  • Mac安裝Docker配置網易源 博客說明 文章所涉及的資料來自互聯網整理和個人總結,意在於個人學習和經驗彙總,如有什麼地方侵權,請聯繫本人刪除,謝謝! 安裝 使用brew安裝 brew cask install docker 這個過程有一會兒 安裝成功後打開Docker,需要驗證一下 配置源 找到 ...
  • # 導入requests 和 BeautifulSoupimport requestsfrom bs4 import BeautifulSoupdef download_page(url): # 定義頭部,用來騙過瀏覽器 headers ={'User-Agent': 'Mozilla/5.0 (W ...
  • Python入指南.pdf python標準庫.pdf Python編程指南.pdf Python高級編程.pdf python核心筆記.pdf Python源碼剖析.pdf 簡明python教程.pdf Python庫參考手冊.pdf Python技術參考大全.pdf 用Pyth... ...
  • 【一、項目背景】 隨著互聯網時代的快速發展,便捷人民的生活,提高生活質量,外賣系統應運而生。 人們也喜歡享受著“足不出戶,美食到家”的待遇,促使網上訂餐行業快速發展。 【二、項目目標】 1. 設計一款應用程式-外賣系統,有文字和圖片顯示,通過選擇一種或多種食物,每種食物可以選擇一份或多份,點擊結算後 ...
  • 線程安全與不安全集合 線程不安全集合: ArrayList LinkedList HashMap HashSet TreeMap TreeSet StringBulider 線程安全集合: Vector HashTable Properties 集合線程安全與解決方案 ArrayList線程安全問題 ...
  • 1.同步塊 同步塊(synchronized(obj)){ },obj稱之為同步監視器 1.obj可以是任何對象,但是推薦使用共用資源作為同步監視器 2.同步方法中無需指定同步監視器,因為同步方法的同步監視器時this即該對象本身,或class即類的模子 同步監視器執行過程 1.第一個線程訪問,鎖定 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...