哈克k1
发布于 IP属地北京

应急响应-入侵排查(Linux篇)

第二篇关于应急响应当中的入侵排查手册,希望大家喜欢

Linux

账号安全

1、用户信息文件/etc/passwd

root:x:0:0:root:/root:/bin/bash 


#用户名:密码:用户ID:组ID:用户说明:家目录:登陆之后shell 
#注:无密码只允许本机登陆,远程不允许登陆

2、影子文件/etc/shadow

root:$6$oGs1PqhL2p3ZetrE$X7o7bzoouHQVSEmSgsYN5UD4.kMHx6qgbTqwNVC5oOAouXvcjQSt.Ft7ql1WpkopY0UV9ajBwUt1DpYxTCVvI/:16809:0:99999:7::: 
#用户名:加密密码:密码最后一次修改日期:两次密码的修改时间间隔:密码有效期:密码修改到期到的 
#警告天数:密码过期之后的宽限天数:账号失效时间:保留

账号安全设置:
1、查询特权用户特权用户(uid 为0)
[root@localhost ~]# awk -F: '$3==0{print $1}' /etc/passwd
2、查询可以远程登录的帐号信息
[root@localhost ~]# awk '/\$1|\$6/{print $1}' /etc/shadow
3、除root帐号外,其他帐号是否存在sudo权限。如非管理需要,普通帐号应删除sudo权限
[root@localhost ~]# more /etc/sudoers | grep -v "^#\|^$" | grep "ALL=(ALL)"
4、禁用或删除多余及可疑的帐号
usermod -L user 禁用帐号,帐号无法登录,/etc/shadow第二栏为!开头
userdel user 删除user用户
userdel -r user 将删除user用户,并且将/home目录下的user目录一并删除
5、who 查看当前登录用户(tty本地登陆 pts远程登录)
w 查看系统信息,想知道某一时刻用户的行为
uptime 查看登陆多久、多少用户,负载

历史命令

通过.bash_history查看帐号执行过的系统命令

1、root的历史命令

histroy 

2、打开/home各帐号目录下的.bash_history,查看普通帐号的历史命令

检查异常端口

netstat -antlp|more

查看下pid所对应的进程文件路径, 运行

ls -l /proc/$PID/exe或file /proc/$PID/exe  ($PID 为对应的pid 号)

检查异常进程

使用ps命令,分析进程

ps aux | grep pid

top命令类似于Windows的任务管理器,能够实时显示系统中各个进程的资源占用状况默认top是根据cpu的占用情况进行排序的

可通过b键进行切换,可切换到按照内存使用情况进行排序

监听指定进程

top  -p pid  监控指定进程

free   #查看当前系统内存使用情况

有些挖矿的会修改hosts文件

cat /etc/hosts

检查开机启动项

/etc/init.d:init.d是目录名,目录内放的是各个服务的启动脚本,比如sshd、httpd等

/etc/rc.local:/etc/rc.local是/etc/rc.d/rc.local的软连接,该脚本是在系统初始化级别脚本运行之后再执行的,想要/etc/rc.local起作用必须chmod +x /etc/rc.d/rc.local

/etc/profile.d/*.sh:/etc/profile.d/*.sh是bash的全局配置文件,/etc/profile.d/下有许多shell脚本,可以在开机时启动。

/etc/rc.d/rcX.d:rcX.d是目录名,后面的X代表着每个运行级别。

系统运行级别示意:

运行级别 含义
0 关机
1 单用户模式,可以想象为windows的安全模式,主要用于系统修复
2 不完全的命令行模式,不含NFS服务
3 完全的命令行模式,就是标准字符界面
4 系统保留
5 图形模式
6 重启动

查看运行级别命令

runlevel

检查定时任务

1、利用crontab创建计划任务

基本命令 crontab -l   列出某个用户cron服务的详细内容 
Tips:默认编写的crontab文件会保存在 (/var/spool/cron/用户名 例如: /var/spool/cron/root 
crontab -r 删除每个用户cront任务(谨慎:删除所有的计划任务) 
crontab -e 使用编辑器编辑当前的crontab文件 
如:*/1 * * * * echo "hello world" >> /tmp/test.txt 每分钟写入文件

2、利用anacron实现异步定时任务调度

使用案例 每天运行 /home/backup.sh脚本: vi /etc/anacrontab @daily 10 example.daily /bin/bash /home/backup.sh 
当机器在 backup.sh 期望被运行时是关机的,anacron会在机器开机十分钟之后运行它,而 不用再等待 7天

3、重点关注以下目录中是否存在恶意脚本

/var/spool/cron/*  
/etc/crontab 
/etc/cron.d/* 
/etc/cron.daily/*  
/etc/cron.hourly/*  
/etc/cron.monthly/* 
/etc/cron.weekly/ 
/etc/anacrontab 
/var/spool/anacron/* 
小技巧: more /etc/cron.daily/* 查看目录下所有文件

检查服务

第一种修改方法: 
chkconfig [--level 运行级别] [独立服务名] [on|off] 
chkconfig –level 2345 httpd on 开启自启动 
chkconfig httpd on (默认level是2345) 
第二种修改方法: 
修改/etc/re.d/rc.local 文件 
加入 /etc/init.d/httpd start 
第三种修改方法: 使用ntsysv命令管理自启动,可以管理独立服务和xinetd服务

查询已安装的服务:

RPM包安装的服务 
chkconfig --list 查看服务自启动状态,可以看到所有的RPM包安装的服务 
ps aux | grep crond 查看当前服务 
系统在3与5级别下的启动项 
中文环境 chkconfig --list | grep "3:启用\|5:启用" 
英文环境 chkconfig --list | grep "3:on\|5:on" 
源码包安装的服务 
查看服务安装位置 ,一般是在/user/local/ 
service httpd start 
搜索/etc/rc.d/init.d/ 查看是否存在

检查异常文件

1、查看敏感目录,如/tmp目录下的文件,同时注意隐藏文件夹,以“..”为名的文件夹具有隐藏属性 2、得到发现WEBSHELL、远控木马的创建时间,如何找出同一时间范围内创建的文件?

可以使用find命令来查找,如 :

find /opt -iname "*" -atime 1 -type f 找出 /opt 下一天前访问过的文件 

3、针对可疑文件可以使用stat查看修改时间

检查系统日志

日志默认存放位置:/var/log/

查看日志配置情况:more /etc/rsyslog.conf

可使用命令 last 进行查看最近登录的信息

日志文件 说明
/var/log/cron 记录了系统定时任务相关的日志
/var/log/cups 记录打印信息的日志
/var/log/dmesg 记录了系统在开机时内核自检的信息,也可以使用dmesg命令直接查看内核自检信息
/var/log/mailog 记录邮件信息
/var/log/message 记录系统重要信息的日志。这个日志文件中会记录Linux系统的绝大多数重要信息,如果系统出现问题时,首先要检查的 就应该是这个日志文件
/var/log/btmp 记录错误登录日志,这个文件是二进制文件,不能直接v查看,而要使用lastb命令查看
/var/log/lastlog 记录系统中所有用户最后一次登录时间的日志,这个文件是二进制文件,不能直接vi,而要使用lastlog命令查看
/var/log/wtmp 永久记录所有用户的登录、注销信息,同时记录系统的启动、重启、关机事件。同样这个文件也是一个二进制文件,不 能直接vi,而需要使用last命令来查看
/var/log/utmp 记录当前已经登录的用户信息,这个文件会随着用户的登录和注销不断变化,只记录当前登录用户的信息。同样这个文 件不能直接vi,而要使用w,who,users等命令来查询
/var/log/secure 记录验证和授权方面的信息,只要涉及账号和密码的程序都会记录,比如SSH登录,su切换用户,sudo授权,甚至添加 用户和修改用户密码都会记录在这个日志文件中

比较重要的几个日志:

登录失败记录:/var/log/btmp /---lastb  
最后一次登录:/var/log/lastlog /----lastlog 
登录成功记录: /var/log/wtmp /---last  
登录日志记录:/var/log/secure 
目前登录用户信息:/var/run/utmp /---w、who、users 
历史命令记录:history  仅清理当前用户: history -c

日志分析技巧

Linux下常用的文本审查工具如:find、grep 、egrep、awk、sed 
1、grep显示前后几行信息: 
	标准unix/linux下的grep通过下面參数控制上下文: 
	grep -C 5 foo file 显示file文件里匹配foo字串那行以及上下5行 
	grep -B 5 foo file 显示foo及前5行 
	grep -A 5 foo file 显示foo及后5行 

	
2、如何显示一个文件的某几行:
cat input_file | tail -n +1000 | head -n 2000
#从第1000行开始,显示2000行。即显示1000~2999行

3、find /etc -name init
#在目录/etc中查找文件init

5、只是显示/etc/passwd的账户
`cat /etc/passwd |awk -F ':' '{print $1}'` 
#awk -F指定域分隔符为':',将记录按指定的域分隔符划分域,填充域,$0则表示所有域,$1表示第一个域,$n表示第n个域。

6、sed -i '153,$d' .bash_history
#删除历史操作记录,只保留前153行
定位有多少IP在爆破主机的root帐号:
grep "Failed password for root" /var/log/secure | awk '{print $11}' | sort | uniq -c | sort -nr | more
定位有哪些IP在爆破:
grep "Failed password" /var/log/secure|grep -E -o "(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-
9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)"|uniq -c
爆破用户名字典是什么?
grep "Failed password" /var/log/secure|perl -e 'while($_=<>){ /for(.*?) from/; print "$1\n";}'|uniq -c|sort -nr
2、登录成功的IP有哪些:
grep "Accepted " /var/log/secure | awk '{print $11}' | sort | uniq -c | sort -nr | more
登录成功的日期、用户名、IP:
grep "Accepted " /var/log/secure | awk '{print $1,$2,$3,$9,$11}' 
3、增加一个用户kali日志:
Jul 10 00:12:15 localhost useradd[2382]: new group: name=kali, GID=1001
Jul 10 00:12:15 localhost useradd[2382]: new user: name=kali, UID=1001, GID=1001, home=/home/kali
, shell=/bin/bash
Jul 10 00:12:58 localhost passwd: pam_unix(passwd:chauthtok): password changed for kali
#grep "useradd" /var/log/secure 
4、删除用户kali日志:
Jul 10 00:14:17 localhost userdel[2393]: delete user 'kali'
Jul 10 00:14:17 localhost userdel[2393]: removed group 'kali' owned by 'kali'
Jul 10 00:14:17 localhost userdel[2393]: removed shadow group 'kali' owned by 'kali'
# grep "userdel" /var/log/secure
5、su切换用户:
Jul 10 00:38:13 localhost su: pam_unix(su-l:session): session opened for user good by root(uid=0)
sudo授权执行:
sudo -l
Jul 10 00:43:09 localhost sudo: good : TTY=pts/4 ; PWD=/home/good ; USER=root ; 
COMMAND=/sbin/shutdown -r now
浏览 (267)
点赞 (1)
收藏
打赏
评论