未分类

Linux 入侵排查

Linux 入侵排查

0x00 前言

当企业发生黑客入侵、系统崩溃或其它影响业务正常运行的安全事件时,急需第一时间进行处理,使企业的网络信息系统在最短时间内恢复正常工作,进一步查找入侵来源,还原入侵事故过程,同时给出解决方案与防范措施,为企业挽回或减少经济损失。

针对常见的攻击事件,结合工作中应急响应事件分析和解决的方法,总结了一些 Linux 服务器入侵排查的思路。

0x01 入侵排查思路

1.1 账号安全

基本使用:

1、用户信息文件 /etc/passwd
root:x:0:0:root:/root:/bin/bash
pwn:x:1000:1000:pwn,,,:/home/pwn:/bin/bash
account:password:UID:GID:GECOS:directory:shell
用户名:密码:用户ID:组ID:用户说明:家目录:登陆之后的 shell
      x:真正口令在/etc/shadow;*:表已被查封,不再允许登录
注意:无密码只允许本机登陆,远程不允许登陆

2、影子文件 /etc/shadow
root:$6$oGs1PqhL2p3ZetrE$X7o7bzoouHQVSEmSgsYN5UD4.kMHx6qgbTqwNVC5oOAouXvcjQSt.Ft7ql1WpkopY0UV9ajBwUt1DpYxTCVvI/:16809:0:99999:7:::
pwn:$1$6Yemie/y$1mXW8aLfZZ5qGtqvK1Awo0:18780:0:99999:7:::
用户名:加密密码:密码最后一次修改日期:两次密码的修改时间间隔:密码有效期:密码修改到期到的警告天数:密码过期之后的宽限天数:账号失效时间:保留
date -d "1970-01-01 15775 days" #换算日期
who     查看当前登录用户(tty 本地登陆 pts 远程登录)
w       查看系统信息,想知道某一时刻用户的行为
uptime 查看登陆多久、多少用户,负载状态

入侵排查:

1、查询特权用户;特权用户(uid 为0)
[root@localhost ~]# awk -F: '$3==0{print $1}' /etc/passwd
  -F:指定 冒 号为分隔符 。 当第三个变量为0时,输出第一个信息。
2、查询可以远程登录的帐号信息
[root@localhost ~]# awk '/\$1|\$6/{print $1}' /etc/shadow
  匹配$1或$6的字符;$1存在与Ubuntu;$6存在于kali。
3、禁用或删除多余及可疑的帐号
  usermod -L kali   禁用user帐号,帐号无法登录,/etc/shadow 第二栏为 ! 开头
      cat /etc/shadow
userdel user       删除 user 用户
userdel -r user   将删除 user 用户,并且将 /home 目录下的 user 目录一并删除

1.2 历史命令

基本使用:

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

1、root 用户的历史命令
histroy
2、历史操作命令的清除:history -c
但此命令并不会清除保存在文件中的记录,因此需要手动删除 .bash_profile 文件中的记录。

入侵排查:

进入用户目录下,导出历史命令。
cat .bash_history >> history.txt

1.3 检查异常端口

使用 netstat 网络连接命令,分析可疑端口、IP、PID

netstat -antlp | more
  -a:显示所有选项
  -n:不显示别名,以数字代替
  -t:tcp连接
  -l:仅列出监听状态
  -p:显示建立相关链接的程序名
查看下 pid 所对应的进程文件路径,
运行 ls -l /proc/$PID/exe 或 file /proc/$PID/exe($PID 为对应的 pid 号)

1.4 检查异常进程

使用 ps 命令,分析进程

ps aux | grep pid 
  -aux:显示进程信息;包括无终端的(x);用户端(u)

1.5 检查开机启动项

开机自启动目录

在 /etc/init.d 目录下
ls -alt | head -n 10 //显示最近添加的前10个服务
  -a:显示所有文件目录。
  -l:除名称外,将文件形态。权限,拥有者,文件大小列出。
  -t:将文件依靠建立时间先后次序列出
stat xxx//查看程序的启动状态

基本使用:

查看运行级别命令 runlevel

系统运行级别示意图:

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

系统默认允许级别

vi  /etc/inittab
id=3:initdefault #系统开机后直接进入哪个运行级别

入侵排查:

启动项文件:

more /etc/rc.local
/etc/rc.d/rc[0~6].d
ls -l /etc/rc.d/rc3.d/

1.6 检查定时任务

基本使用

利用 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 表每分钟写入文件

入侵排查

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

/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/*  查看目录下所有文件

1.7 检查异常文件

1、查看敏感目录,如/tmp目录下的文件,同时注意隐藏文件夹,以“..”为名的文件夹具有隐藏属性

ls -alt   //-t以修改时间排序;-l列出长字串,包含文件的权限,属性等信息。

2、得到发现WEBSHELL、远控木马的创建时间,如何找出同一时间范围内创建的文件?

简名全名中文名含义
atimeaccess time访问时间文件中的数据库最后被访问的时间
mtimemodify time修改时间文件内容被修改的最后时间
ctimechange time变化时间文件的元数据发生变化。比如权限,所有者等

find参数:-name表根据文件名称查找;-iname 表根据文件名称查找,并不区分大小写。

-type: -d表目录;-f表文件

可以使用find命令来查找

find /opt -iname "*" -atime 1 -type f 找出 /opt 下 一天前访问过的文件in
find ./ -mtime 0 -name "*.php" //找到24小时之内被修改的文件   时间计算   (n-1)*24
find ./ -ctime -2 -name "*.php" //找到72小时之内新增的文件
find ./ -iname "*.php" -perm 777// -perm指定筛选权限
find /opt -iname "*" -atime 1 -type f // -type 指定问点类型 f为普通文件

1.9 检查系统日志

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

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

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

0x02 工具篇

2.1 Rootkit查杀//木马、程序

  • chkrootkit 网址:http://www.chkrootkit.org 使用方法:
    wget ftp://ftp.pangeia.com.br/pub/seg/pac/chkrootkit.tar.gz
    tar zxvf chkrootkit.tar.gz
    cd chkrootkit-0.55
    make sense
    #编译完成没有报错的话执行检查
    ./chkrootkit
  • rkhunter网址:http://rkhunter.sourceforge.net使用方法:
    wget https://nchc.dl.sourceforge.net/project/rkhunter/rkhunter/1.4.4/rkhunter-1.4.4.tar.gz
    tar -zxvf rkhunter-1.4.4.tar.gz
    cd rkhunter-1.4.4
    ./installer.sh –install
    rkhunter -c

2.2 Linux安全检查脚本

Github 项目地址:

https://github.com/grayddq/GScan

https://github.com/ppabc/security_check

https://github.com/T0xst/linux

留言

您的邮箱地址不会被公开。 必填项已用 * 标注