0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

各種Shell命令的用法和作用

Linux愛好者 ? 來源:Linux愛好者 ? 作者:小白學(xué)黑客 ? 2021-01-11 10:47 ? 次閱讀

【前言】通過排查挖礦病毒的一次“有趣”經(jīng)歷,本文不僅展示了各種 Shell 命令的用法和作用,也能加深讀者對Linux 進(jìn)程和文件系統(tǒng)的理解。

同時(shí)在本文中,還出現(xiàn)了各種不同的工具類網(wǎng)站,相信對于一些專業(yè)人士會很有幫助。

希望能對大家有所幫助。

CPU起飛了

最近有朋友在群里反饋,自己服務(wù)器的CPU一直處于高占用狀態(tài),但用top、ps等命令卻一直找不到是哪個(gè)進(jìn)程在占用,懷疑中了挖礦病毒,急的團(tuán)團(tuán)轉(zhuǎn)。

b5e495f4-523c-11eb-8b86-12bb97331649.png

b6008322-523c-11eb-8b86-12bb97331649.png

根據(jù)經(jīng)驗(yàn),我趕緊讓他看一下當(dāng)前服務(wù)器的網(wǎng)絡(luò)連接,看看有沒有可疑連接,果然發(fā)現(xiàn)了有點(diǎn)東西:

b60fb694-523c-11eb-8b86-12bb97331649.png

上Shodan查一下這IP地址:

b66a4956-523c-11eb-8b86-12bb97331649.png

反向查找,發(fā)現(xiàn)有諸多域名曾經(jīng)解析到這個(gè)IP地址:

b69b5dac-523c-11eb-8b86-12bb97331649.png

這是一個(gè)位于德國的IP地址,開放了4444,5555,7777等數(shù)個(gè)特殊的服務(wù)端口

b6d88786-523c-11eb-8b86-12bb97331649.png

其中這位朋友服務(wù)器上發(fā)現(xiàn)的連接到的是7777端口,鐘馗之眼顯示,這是一個(gè)HTTP服務(wù)的端口,直接訪問返回的信息如下:

b7319416-523c-11eb-8b86-12bb97331649.png

mining pool!,服務(wù)器正在挖礦實(shí)錘了!

但神奇的是,這個(gè)進(jìn)程像是隱身了一般,找不到存在的任何痕跡。

進(jìn)程如何隱藏

現(xiàn)在說回到本文的正題:Linux操作系統(tǒng)上,進(jìn)程要隱藏起來,有哪些招數(shù)?

要回答這個(gè)問題,先來知道ps、top等命令枚舉系統(tǒng)的進(jìn)程列表的原理。

Linux的設(shè)計(jì)哲學(xué)是:一切皆文件!

進(jìn)程也不例外, Linux系統(tǒng)中有一個(gè)特殊的目錄:/proc/,這個(gè)目錄下的內(nèi)容,不是硬盤上的文件系統(tǒng),而是操作系統(tǒng)內(nèi)核暴露出的內(nèi)核中進(jìn)程、線程相關(guān)的數(shù)據(jù)接口,也就是procfs,里面記錄了系統(tǒng)上正在運(yùn)行的進(jìn)程和線程信息,來查看一下:

b7884bda-523c-11eb-8b86-12bb97331649.png

這些以數(shù)字命名的目錄,就是一個(gè)進(jìn)程的PID,里面記錄了該進(jìn)程的詳細(xì)信息。

而ps、top等命令的工作原理,實(shí)質(zhì)上就是遍歷這個(gè)目錄。

知道了原理,想實(shí)現(xiàn)隱藏就有以下幾個(gè)思路:

命令替換

直接替換系統(tǒng)中的ps、top命令工具。可以從GitHub上下載它們的源碼,加入對應(yīng)的過濾邏輯,在遍歷進(jìn)程的時(shí)候,剔除挖礦進(jìn)程,實(shí)現(xiàn)隱藏的目的。

模塊注入

編寫一個(gè)動態(tài)鏈接庫so文件,在so中,HOOK遍歷相關(guān)的函數(shù)(readdir/readdir64),遍歷的時(shí)候,過濾挖礦進(jìn)程。

通過修改LD_PRELOAD環(huán)境變量或/etc/ld.so.preload文件,配置動態(tài)鏈接庫,實(shí)現(xiàn)將其注入到目標(biāo)進(jìn)程中。

內(nèi)核級隱藏

模塊注入的方式是在應(yīng)用層執(zhí)行函數(shù)HOOK,隱藏挖礦進(jìn)程,更進(jìn)一步,可以通過加載驅(qū)動程序的方式在內(nèi)核空間HOOK相應(yīng)的系統(tǒng)調(diào)用來實(shí)現(xiàn)隱藏。不過這對攻擊者的技術(shù)要求也更高,遇到這樣的病毒清理起來挑戰(zhàn)也更大了。

揪出挖礦進(jìn)程

通過上面的進(jìn)程隱藏原理看得住來,都是想盡辦法隱藏/proc目錄下的內(nèi)容,類似于“障眼法”,所以包含ps、top、ls等等在內(nèi)的命令,都沒辦法看到挖礦進(jìn)程的存在。

但蒙上眼不代表不存在,有一個(gè)叫unhide的工具,就能用來查看隱藏進(jìn)程。

我讓這位朋友安裝這個(gè)工具來查找隱藏的進(jìn)程,但奇怪的是,一執(zhí)行yum install安裝,遠(yuǎn)程連接的SSH會話就立刻斷開。

于是退而求其次,選擇通過源碼安裝,又是一直各種報(bào)錯(cuò)···

因?yàn)槲覜]辦法親自操作這臺服務(wù)器,溝通起來比較麻煩,于是我決定研究下這個(gè)unhide工具的源碼,然后編一個(gè)python腳本發(fā)給他執(zhí)行。

源碼地址:https://github.com/YJesus/Unhide-NG/blob/master/unhide-linux.c

在查找隱藏進(jìn)程模塊,其大致使用了如下的方法:

挨個(gè)訪問/proc/pid/目錄,其中,pid從1到到max_pid累加

如果目錄不存在,跳過

如果是unhide自己的進(jìn)程,跳過

如果在ps命令中能看到,跳過

剩下的,既不是自己,也不在ps命令輸出中,則判定為隱藏進(jìn)程

按照這個(gè)思路,我編寫了一個(gè)Python腳本發(fā)給這位朋友,執(zhí)行后果然發(fā)現(xiàn)了隱藏的進(jìn)程:

b7f7daf4-523c-11eb-8b86-12bb97331649.png

別著急,不是真的有這么多進(jìn)程,這里是把所有的線程ID列舉出來了。隨便挑選了一個(gè)看一下:

b83757f6-523c-11eb-8b86-12bb97331649.png

還記得前面通過netstat命令看到挖礦進(jìn)程建立了一個(gè)網(wǎng)絡(luò)連接嗎?Linux一切皆文件,在/proc/pid/fd目錄下有進(jìn)程打開的文件信息:

b874f32c-523c-11eb-8b86-12bb97331649.png

這里發(fā)現(xiàn)這個(gè)進(jìn)程打開了一個(gè)socket,后面的10212是inode id,再通過下面的命令看一下這個(gè)socket到底是什么:

cat /proc/net/tcp | grep 10212

輸出了四元組信息:

b8903a10-523c-11eb-8b86-12bb97331649.png

左邊是源IP地址:源端口,右邊是目的IP地址:目的端口

目的端口1E61就是7777?。?!

b8cb041a-523c-11eb-8b86-12bb97331649.png

找到了,就是這貨!

再次查看cat /proc/pid/environ,定位到進(jìn)程的可執(zhí)行文件:

b8f21154-523c-11eb-8b86-12bb97331649.png

總算把這家伙找到了:

b90706ea-523c-11eb-8b86-12bb97331649.png

網(wǎng)上一搜這家伙,看來是慣犯了:

挖礦病毒分析

把這個(gè)挖礦木馬下載下來,反匯編引擎中查看,發(fā)現(xiàn)加殼了。

脫殼后,在IDA中現(xiàn)出了原形,不禁倒吸了一口涼氣,居然悄悄修改/root/.ssh/authorized_keys文件,添加了RSA密鑰登錄方式,留下這么一個(gè)后門,隨時(shí)都能遠(yuǎn)程登錄進(jìn)來。

b96c91a4-523c-11eb-8b86-12bb97331649.png

b99650fc-523c-11eb-8b86-12bb97331649.png

除此之外,還發(fā)現(xiàn)了病毒嘗試連接的大量域名:

b9c824f6-523c-11eb-8b86-12bb97331649.png

看到這里簡直可怕!自己的服務(wù)器被病毒按在地上摩擦??!

清除建議

開啟SELinux

殺掉挖礦進(jìn)程

刪除病毒程序(注意rm命令是否被替換)

刪除病毒驅(qū)動程序(注意rm命令是否被替換)

刪除病毒添加的登錄憑據(jù)

防火墻封禁IP、端口

責(zé)任編輯:xj

原文標(biāo)題:急死!CPU被挖礦了,卻找不到哪個(gè)進(jìn)程!

文章出處:【微信公眾號:Linux愛好者】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • cpu
    cpu
    +關(guān)注

    關(guān)注

    68

    文章

    10702

    瀏覽量

    209366
  • 挖礦
    +關(guān)注

    關(guān)注

    6

    文章

    448

    瀏覽量

    15946

原文標(biāo)題:急死!CPU被挖礦了,卻找不到哪個(gè)進(jìn)程!

文章出處:【微信號:LinuxHub,微信公眾號:Linux愛好者】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    shell具有的功能和特點(diǎn)

    是執(zhí)行命令。用戶可以在 Shell 提示符下輸入命令,Shell 會解析命令并將其傳遞給操作系統(tǒng)執(zhí)行。S
    的頭像 發(fā)表于 08-30 14:48 ?165次閱讀

    常見的shell命令之其他命令

    1、clear清屏命令命令:clear功能:清除屏幕參數(shù):無 示例:清屏前。執(zhí)行清屏命令后,終端界面顯示信息被清除。2、man幫助命令命令
    發(fā)表于 08-21 09:49

    shell基本介紹及常用命令shell介紹

    一、Shell是什么?我們在剛開始接觸Linux的時(shí)候,經(jīng)常會聽到工程師提到Shell這個(gè)詞,剛開始不知道這是個(gè)干什么的,簡單的說,它是一個(gè)應(yīng)用,接收用戶命令,調(diào)用相應(yīng)的內(nèi)核接口函數(shù)或應(yīng)用程序,并
    發(fā)表于 08-15 09:28

    python shell怎么用

    Python Shell是一種交互式解釋器,可以通過命令行直接運(yùn)行Python代碼。在Shell中,可以輸入一行代碼并立即得到結(jié)果,非常適合于測試、嘗試新代碼或進(jìn)行簡單的任務(wù)。本文將詳細(xì)介紹
    的頭像 發(fā)表于 11-29 14:36 ?863次閱讀

    總結(jié)linux命令行的主要用法

    Linux命令行是一種在Linux操作系統(tǒng)中通過文本界面來執(zhí)行指令和管理系統(tǒng)的方式。它提供了豐富的功能和靈活性,幫助用戶完成各種任務(wù)。本文將詳細(xì)介紹Linux命令行的主要用法,包括常見
    的頭像 發(fā)表于 11-17 10:19 ?545次閱讀

    linux常用命令用法

    Linux是一種開源的操作系統(tǒng),它以穩(wěn)定、高效和安全的特點(diǎn)受到廣大用戶的喜愛。掌握Linux的常用命令及其用法對于操作系統(tǒng)的管理和開發(fā)都至關(guān)重要。本文將詳盡、詳實(shí)、細(xì)致地介紹Linux常用命令及其
    的頭像 發(fā)表于 11-17 09:47 ?545次閱讀

    Shell基本介紹及目錄常用命令

    01、Shell是什么?我們在剛開始接觸Linux的時(shí)候,經(jīng)常會聽到工程師提到Shell這個(gè)詞,那么Shell到底是什么呢?簡單的說,它是一個(gè)應(yīng)用,接收用戶命令,調(diào)用相應(yīng)的內(nèi)核接口函數(shù)
    的頭像 發(fā)表于 11-15 13:06 ?363次閱讀
    <b class='flag-5'>Shell</b>基本介紹及目錄常用<b class='flag-5'>命令</b>

    linux中source命令用法

    在Linux中,source命令通常用于重新執(zhí)行剛修改的初始化文件,使之立即生效,而不必注銷并重新登錄。source命令可以用于讀取并執(zhí)行腳本文件中的命令,通常用于在當(dāng)前shell環(huán)境
    的頭像 發(fā)表于 11-08 14:35 ?1731次閱讀

    linux命令行與shell編程實(shí)戰(zhàn)

    Linux命令行與Shell編程實(shí)戰(zhàn)主要涉及以下內(nèi)容: Linux命令行基礎(chǔ):學(xué)習(xí)Linux命令行的基本操作,如文件管理、進(jìn)程管理、網(wǎng)絡(luò)配置等。熟悉使用
    的頭像 發(fā)表于 11-08 10:57 ?622次閱讀

    linux命令shell編程有什么聯(lián)系

    命令,并提供了許多功能和特性,如變量、控制結(jié)構(gòu)、函數(shù)等,這些功能和特性使得Shell編程成為可能。 其次,Linux命令Shell編程的重要組成部分。通過使用Linux
    的頭像 發(fā)表于 11-08 10:53 ?771次閱讀

    shell命令和linux命令一樣嗎

    Shell命令和Linux命令并不完全一樣。 首先,Shell是一種命令行解釋器,它是用來解釋和執(zhí)行用戶輸入的
    的頭像 發(fā)表于 11-08 10:51 ?2439次閱讀

    shell命令提示符的具體含義

    的主機(jī)名是localhost.localdomain。 當(dāng)前目錄:顯示當(dāng)前用戶所在的目錄,例如~代表用戶的主目錄(home目錄)。 命令提示符:$符號表示普通用戶,#符號表示root用戶。 命令提示符的作用是提示用戶可以輸入
    的頭像 發(fā)表于 11-08 10:37 ?1128次閱讀

    shell腳本基本命令

    Shell腳本是一種可執(zhí)行文件,它包含了一組用某種特定語言編寫的命令,這些命令可以被解釋器(如bash)執(zhí)行。以下是一些常見的shell腳本基本命令
    的頭像 發(fā)表于 11-08 10:08 ?1733次閱讀

    單片機(jī)上如何做shell命令行交互

    做過嵌入式Linux開發(fā)或使用過桌面Linux系統(tǒng)的童鞋們,肯定對shell命令交互印象比較深刻,然而我們大多數(shù)搞嵌入式軟件開發(fā)的碼農(nóng)都是基于單片機(jī),比如51、STM32等進(jìn)行開發(fā)的,在單片機(jī)上能否
    的頭像 發(fā)表于 11-01 15:16 ?1081次閱讀

    BASH shell腳本篇—條件命令

    這篇文章介紹下BASH shell中的條件相關(guān)的命令,包括:if, case, while, until, for, break, continue。
    的頭像 發(fā)表于 10-11 15:21 ?467次閱讀
    BASH <b class='flag-5'>shell</b>腳本篇—條件<b class='flag-5'>命令</b>