Linux服务器安全基础 - 查看入侵痕迹

1. 常见系统日志

/var/log/cron 记录了系统定时任务相关的日志

/var/log/dmesg 记录了系统在开机时内核自检的信息,也可以使用dmesg命令直接查看内核自检信息

/var/log/secure:记录登录系统存取数据的文件;例如:pop3,ssh,telnet,ftp等都会记录在此.

/var/log/btmp:记录登录这的信息记录,被编码过,所以必须以last解析;

例如:lastb | awk '{ print $3}' | sort | uniq -c | sort -nr

/var/log/message:几乎所有的开机系统发生的错误都会在此记录;

/var/log/boot.log:记录一些开机或者关机启动的

/var/log/lastlog 记录每一个用户最后的登陆信息

2. 常用脚本

  1. 查询特权用户特权用户(uid 为0)

    awk -F: '3==0{print 1}' /etc/passwd

如果发现除了 root 外还有别的账号,就要小心了。

  1. 查询可以远程登录的帐号信息

    awk '/$1|$6/{print $1}' /etc/shadow

  2. 除root帐号外,其他帐号是否存在sudo权限。

    more /etc/sudoers | grep -v "#|$" | grep "ALL=(ALL)"

  3. 查询登录账号的历史命令

    cat ~用户名/.bash_history | more

此命令可看到操作命令和操作时间

  1. 检查异常端口和unix sockets

    netstat -ln

  1. 使用 ps 命令,分析进程

    ps aux

  1. 检查开机启动配置文件

    cat /etc/rc.local

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

/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/*

  1. 列出某个用户cron服务的详细内容

    crontab -l

  2. 禁用或删除多余及可疑的帐号

usermod -L user # 禁用帐号,帐号无法登录,/etc/shadow 第二栏为 ! 开头

userdel user # 删除 user 用户

userdel -r user # 将删除 user 用户,并且将 /home 目录下的 user 目录一并删除

  1. 查看可疑IP登录记录

    last -f /var/log/wtmp

该日志文件永久记录每个用户登录、注销及系统的启动、停机的事件。因此随着系统正常运行时间的增加,该文件的大小也会越来越大,

增加的速度取决于系统用户登录的次数。该日志文件可以用来查看用户的登录记录,last命令就通过访问这个文件获得这些信息,并以反序从后向前显示用户的登录记录,last也能根据用户、终端tty或时间显示相应的记录。

  1. 查看连接失败次数并按次数排序,显示前20行

    cat /var/log/secure | awk '/Failed/{print (NF-3)}' | sort | uniq -c | sort -nr | awk '{print 2" = "$1;}' | more

  1. 定位有多少IP在爆破主机的root帐号

    grep "Failed password for root" /var/log/secure | awk '{print 11}' | sort | uniq -c | sort -nr | awk '{print 2" = "$1;}'

  2. 爆破用户名字典

    grep "Failed password" /var/log/secure|perl -e 'while(_=<>){ /for(.*?) from/; print "1\n";}'|uniq -c|sort -nr

  3. 登录成功的IP有哪些

    grep "Accepted " /var/log/secure | awk '{print $11}' | sort | uniq -c | sort -nr | more

  4. 登录成功的日期、用户名、IP

    grep "Accepted " /var/log/secure | awk '{print 1,2,3,9,$11}'

相关推荐
yuanmenghao2 分钟前
Linux 性能实战 | 第 7 篇 CPU 核心负载与调度器概念
linux·网络·性能优化·unix
qq_2975746715 分钟前
Linux 服务器 Java 开发环境搭建保姆级教程
java·linux·服务器
70asunflower40 分钟前
Emulation,Simulation,Virtualization,Imitation 的区别?
linux·docker
聆风吟º1 小时前
CANN开源项目实战指南:使用oam-tools构建自动化故障诊断与运维可观测性体系
运维·开源·自动化·cann
神梦流1 小时前
ops-math 算子库的扩展能力:高精度与复数运算的硬件映射策略
服务器·数据库
NPE~1 小时前
自动化工具Drissonpage 保姆级教程(含xpath语法)
运维·后端·爬虫·自动化·网络爬虫·xpath·浏览器自动化
神梦流1 小时前
GE 引擎的内存优化终局:静态生命周期分析指导下的内存分配与复用策略
linux·运维·服务器
凡人叶枫1 小时前
C++中输入、输出和文件操作详解(Linux实战版)| 从基础到项目落地,避坑指南
linux·服务器·c语言·开发语言·c++
wdfk_prog2 小时前
[Linux]学习笔记系列 -- [drivers][input]serio
linux·笔记·学习
xuhe22 小时前
[全流程详细教程]Docker部署ClawBot, 使用GLM4.7, 接入TG Bot实现私人助理. 解决Docker Openclaw Permission Denied问题
linux·docker·ai·github·tldr