记一次树莓派(Raspbetty)系统ssh被爆破攻击日志分析
- 前面的文章有过提及,这个博客的载体是一块树莓派,就像下面图片的这样
data:image/s3,"s3://crabby-images/274fb/274fbbf9cad200668602b6d93e6df2d03c60e176" alt=""
今天在家无聊,所以想看下系统的登录日志,真应的那一句话,不看不知道,一看吓一跳
,我TMD居然被爆破攻击了,想起来了前几天需要有个东西测试下,远程到服务器上开放了一个ssh端口没有关闭,才隔两三天居然被爆破
攻击了,不过我当时应该是没有慌乱,因为之前在ssh服务上有过加固,爆破成功可能性不大,所以就开启了树莓派分析日志的过程,在此留一个记录。
- 第一步分析日志查看系统是否被成功登录
- 第二步查找IP归属地及攻击次数
树莓派里面有三个文件需要我们进行分析:(下面三个文件都在/var/log/
目录下)
auth. log 可以看到登陆的情况
btmp 中可以查看到登陆失败的记录(可通过lastb命令进行检查)
lastlog 中可以查看最近登陆的记录(可通过last命令进行检查)
看下系统最近登录失败的记录:
grep "Failed password" /var/log/auth.log | wc -l
data:image/s3,"s3://crabby-images/a6687/a66879246d64bbb0dabbf32821857d94e9331f20" alt=""
看下系统最近登录成功的记录:
grep "password" /var/log/auth.log| grep -v Failed | grep -v Invalid
data:image/s3,"s3://crabby-images/56be3/56be38dcdf97abaf3923e0e32b4ac2bdc818af19" alt=""
简单看了下,问题不大,因为都是自己的IP地址,最近也就自己登录了进来,大家应该发现了,这个应该是最近的登录记录,说明对方并没有成功登录过,我们还需要继续分析
我们查询下恶意攻击的IP及他们攻击的次数
cat /var/log/auth.log | awk '/Failed/{print $(NF-3)}' | sort | uniq -c | awk '{print $2" = "$1;}'
data:image/s3,"s3://crabby-images/af935/af9352f6f702b4c97282fe21918d14cd3c8e796b" alt=""
可以看到,这个攻击数量是比较大的,特别是60.191.11.242这个IP地址,居然爆破了14657次,实在是服~
先看下所有的auth 文件
ls /var/log/auth.log* -lht
data:image/s3,"s3://crabby-images/85ccc/85ccc968de3e1f794acc4fd59c207b2c3ecdae0c" alt=""
可以看到系统目前产生了 5 个日志文件了。刚刚看的 auth.log 文件只是最近的日志,我们将日志全部放在一个目录里面进行分析
awk '{if($6=="Failed"&&$7=="password"){if($9=="invalid"){ips[$13]++;users[$11]++}else{users[$9]++;ips[$11]++}}}END{for(ip in ips){print ip, ips[ip]}}' auth.* | wc -l
data:image/s3,"s3://crabby-images/32fbc/32fbcf07be351e8b33c1ee8e8370f93ca60ead95" alt=""
看情况还好,只有36个IP地址扫描过我这一台服务器,不算多也不算少,按照攻击我们排一个序看下
awk '{if($6=="Failed"&&$7=="password"){if($9=="invalid"){ips[$13]++;users[$11]++}else{users[$9]++;ips[$11]++}}}END{for(ip in ips){print ip, ips[ip]}}' auth.* | sort -k2 -rn | head
data:image/s3,"s3://crabby-images/8fab9/8fab9dac504a0f57cd0ee3c93b17db4219928530" alt=""
可以通过上图发现,攻击排名第一的总共攻击了16万多次,牛批~
我们可以将上述IP保存到文件,以便后续查证
awk '{if($6=="Failed"&&$7=="password"){if($9=="invalid"){ips[$13]++;users[$11]++}else{users[$9]++;ips[$11]++}}}END{for(ip in ips){print ip, ips[ip]}}' auth.* | sort -k2 -rn > ip.log
查看下IP地址他们的具体分布情况,只查文件top10的
head -10 ip.log | awk '{print $1" ";system("curl //freeapi.ipip.net/"$1);print("\n")}'
data:image/s3,"s3://crabby-images/c8639/c863995cee5e0c15360ffce457db97f6628c3c34" alt=""
查看攻击所使用的用户名及尝试次数
awk '{if($6=="Failed"&&$7=="password"){if($9=="invalid"){ips[$13]++;users[$11]++}else{users[$9]++;ips[$11]++}}}END{for(user in users){print user, users[user]}}' auth.* | sort -k2 -rn |wc -l
#查询总爆破次数
awk '{if($6=="Failed"&&$7=="password"){if($9=="invalid"){ips[$13]++;users[$11]++}else{users[$9]++;ips[$11]++}}}END{for(user in users){print user, users[user]}}' auth.* | sort -k2 -rn | head
#查询爆破使用用户名及次数
data:image/s3,"s3://crabby-images/17048/1704837a634071b7724d00b7208e81e723320a5e" alt=""
可以看得出来,root绝对不是什么安全密码,我这里被爆破38682次,不过我这里有安全策略,你密码错两次就锁定了,锁定后输入正确的密码也无法登录成功,所以更别说其他系统不存在的用户名了,所以此次攻击者并没有爆破成功,不过还是建议将不必要的端口封闭,不要留下安全隐患~
将查询的保存到文件
awk '{if($6=="Failed"&&$7=="password"){if($9=="invalid"){ips[$13]++;users[$11]++}else{users[$9]++;ips[$11]++}}}END{for(user in users){print user, users[user]}}' auth.* | sort -k2 -rn > username.log
其他细节;
查看日志位置
一般来说 ubuntu 在 /var/log/auth.log
centos 在 /var/log/secure
这两者格式不一样。
具体在什么位置是在 rsyslog 的配置文件里:/etc/rsyslog.conf
或者 /etc/rsyslog.d
(当然你的系统必须是用 rsyslog 的才行,如果不是用这个就不在这里,使用命令 ps aux | grep "rsyslog" | grep -v "grep"
看系统里有没有 rsyslog 进程可以判断系统是否使用 rsyslog)
ubuntu 18.04
auth,authpriv.* /var/log/auth.log
具体位置是 /etc/rsyslog.d/50-default.conf
CentOS 7.6
# The authpriv file has restricted access.
authpriv.* /var/log/secure
具体位置是 /etc/rsyslog.conf
命令:
查看成功登录
grep "Accepted password for" /var/log/secure
查看每个用户名失败的次数
grep "Failed password" /var/log/secure | awk '{if (NF==16){c[$11]++}else{c[$9]++}}END{for(u in c)print u,c[u]}' | sort -k 2 -nr | head
查看每个 IP 地址失败的次数
grep "Failed password" /var/log/secure | awk '{if (NF==16){c[$13]++}else{c[$11]++}}END{for(u in c)print u,c[u]}' | sort -k 1 -n | head
data:image/s3,"s3://crabby-images/544cf/544cf1ca2b66a61a7f4f02f65cbaf56936f1ced1" alt=""
data:image/s3,"s3://crabby-images/2507f/2507f47f63f2f24341c0b8d977f117d5fc06e9bf" alt=""
data:image/s3,"s3://crabby-images/46125/46125cb6b34f899e1a9a79390d7d69f4e0c53da4" alt=""
data:image/s3,"s3://crabby-images/17c8d/17c8d8be8d03bf479637f8b231422fe1fa975139" alt=""
data:image/s3,"s3://crabby-images/d1709/d1709a5199cb0897cb87e484b4e34e3a51b6425d" alt=""
data:image/s3,"s3://crabby-images/0f0f9/0f0f963e1ef48241e82525c62a2efabc315f0745" alt=""
data:image/s3,"s3://crabby-images/da352/da352c7a6074fbe4029de3f8196282332da4e77c" alt=""
data:image/s3,"s3://crabby-images/c50a2/c50a2fab1d2939a9fc8bf5efa058b8d672b6b0cd" alt=""
data:image/s3,"s3://crabby-images/e4b6a/e4b6aedade26ad69219e0a923f87e8e75c36016c" alt=""
data:image/s3,"s3://crabby-images/489d1/489d1da4b2447bb443bf89d1e413aca04cdc1dd5" alt=""
data:image/s3,"s3://crabby-images/879fd/879fd67198dbce1fff029fd4f1b60e20248fb5aa" alt=""
data:image/s3,"s3://crabby-images/108ca/108ca2fbfc709293f20862a6580bf6a2ca93f4ca" alt=""
data:image/s3,"s3://crabby-images/e4a86/e4a866449b78d372b673b207177e8c106257bd8d" alt=""
data:image/s3,"s3://crabby-images/7996d/7996d71c9e73b2f5b759d893da4382694a0224e7" alt=""
data:image/s3,"s3://crabby-images/16b12/16b125b80d208c5c3c242f4e55c7b2e1fdbdc39e" alt=""
data:image/s3,"s3://crabby-images/97adc/97adc979707f28db31b273e71be00e3f60a2006f" alt=""
data:image/s3,"s3://crabby-images/aeff0/aeff057bf3c71ef47588781766222dce37f4373b" alt=""
data:image/s3,"s3://crabby-images/6ea56/6ea5633d37e55ccc2f2b4964aa3a97cf24cc5048" alt=""
data:image/s3,"s3://crabby-images/c0c79/c0c795d8742db3acf18cbe18091a968009370c4d" alt=""
data:image/s3,"s3://crabby-images/b346d/b346d45e1abf41c368ca343a1b7e8f426164deea" alt=""
data:image/s3,"s3://crabby-images/c58a3/c58a3c14b7978fa970376e3f0a176f78bfdac3df" alt=""
data:image/s3,"s3://crabby-images/04f8c/04f8c763d9fb9e061fc5b7cafd89906a64450645" alt=""
data:image/s3,"s3://crabby-images/2bcfe/2bcfe33dbb7a257dc45ba44e746882fce3c6f3a8" alt=""
data:image/s3,"s3://crabby-images/d4336/d433657433d7d1aa2b23eafbccab16cdae39e674" alt=""
data:image/s3,"s3://crabby-images/c5d8e/c5d8e35418374f1fa9c9f51fe149b17ca4b0196a" alt=""
data:image/s3,"s3://crabby-images/a36eb/a36eb12d78a111610da647c3f1c87287f12323fa" alt=""
data:image/s3,"s3://crabby-images/296ae/296aef4f2d30011521b2fabad1bf40e8b36765e7" alt=""
data:image/s3,"s3://crabby-images/5a77a/5a77aa381cc65d30db0ec31ad1d2764652c78da6" alt=""
data:image/s3,"s3://crabby-images/bd982/bd9827d633093d65c602934706d3b1ea007188c6" alt=""
data:image/s3,"s3://crabby-images/6d15a/6d15a72cbace766cf3bbd1c313472a1e79e6e3fe" alt=""
data:image/s3,"s3://crabby-images/c0c34/c0c34f20e9643f78f299d69b3d22abde4c3f6f1b" alt=""
data:image/s3,"s3://crabby-images/a6e8a/a6e8a0c11158b3870c94b4c6c465200eedc41055" alt=""
data:image/s3,"s3://crabby-images/28d79/28d7961ad1de0ef848aa7b2907a7b7fd18a755c2" alt=""
data:image/s3,"s3://crabby-images/e9425/e94255a27ebfe760fb402942388efa84ebcdbbc9" alt=""