首页 > 系统相关 >linux排查

linux排查

时间:2023-04-27 18:34:58浏览次数:42  
标签:log etc -- clamav cron 排查 linux root

应急响应

一:网络连接排查(重点关注高危端口的链接)
netstat -pantu

二:获取异常进程pid
占用CPU空间
top -c -o %CPU
ps -eo pid,ppid,%cpu,%mem,cmd --sort=-%cpu | head -5
占用内存空间
top -c -o %MEM
ps -eo pid,ppid,%mem,%cpu,cmd --sort=-%mem | head -5

更具PID查看由进程起的线程>>其中spid就是线程ID
ps H -T -p pid

 

根据进程PID定位程序的实际路径
ls -al /proc/[pid]
ls -al /proc/[pid]exe
file /proc/[PID]/exe
查看文件列出的进程
lsof /var/log/message

根据PID获取程序的详细信息
lsof [pid]
获取进程PID启动时的目录,并不一定是恶意文件所在的目录,只是启动恶意文件的路径
pwdx [pid]
获取进程状态信息
systemctl status [pid]

三:结束进程并清除文件
如果无子进程(会直接杀死指定进程,但是进程产生的子进程并不会杀死)
kill -9 [pid]
如果有子进程(杀掉进程组)
kill -9 -[pid]
用于终止某个指定名称的服务所对应的全部进程
例如:killall httpd

有时WINDOWS和LINUX传输文件或攻击者制造的文件,文件名是乱码的,无法直接通过乱码的文件名删除,
可以通过inode确定文件名然后删除
例如:查看inode
ls -li eval.sh
删除文件
find ./* -inum 12327526 -delete
find ./* -inum 12327526 -exec rm -rf {} \;
find ./* -inum 12327526 |xargs rm -rf

四:文件维度
经常存在可疑现象的目录,一般时间最近的最可疑 ls -alt 按照时间排序查看
用户目录:/root、/home/xx
临时目录:/tmp、/var/tmp
网站目录
放命令的目录:/bin、/sbin、/usr/bin、/usr/sbin

查找可疑文件
1:按时间查找,比如webshell
find / -name *.php -o -name *.jsp -type f -atime -5 (查找5天内的访问过的以php,jsp为后缀的文件) mtime ctime区别是ctime权限变了
2:按用户查找 (入侵者创建账号后,可能会创建文件)
find / -user hack
3:按权限查找
find / -perm 777 -type f
find / ! -perm 755 -type f

五:计划任务排查
crontab -l -u user >> -u参数可以指定用户
查看/etc下计划任务文件
/etc/cron.d/
/etc/cron.d/0hourly 系统每小时第一分钟需要执行的任务
/etc/cron.deny 用户拒绝列表(在该文件中的用户不能使用cron服务)
/etc/crontab 该文件的作用相当于/etc/cron.d/下面的某一个文件,可以定义系统计划任务
/etc/cron.monthly/ 存放系统每个月需要执行的脚本
/etc/cron.weekly/ 存放系统每周需要执行的脚本
/etc/cron.daily/ 存放系统每天需要执行的脚本
/etc/cron.hourly/ 存放系统每小时需要执行的脚本
/var/spool/cron 这个目录用来存放各个用户自己设定的定时任务,普通用户没有权限直接访问
#cron执行时,也就是要读取三个地方的配置文件:一是/etc/crontab,二是/etc/cron.d目录下的所有文件,三是每个用户的配置文件
tail /var/log/cron 查看计划任务的日志

六:启动项排查
ls -alt /etc/rc.local
ls -alt /etc/rc.d/rc[0~6].d
ls -alt /etc/init.d/
各个执行等级的启动脚本是透过ls -alt /etc/rc.d/rc[0~6].d/SXXXdaemon链接到/etc/init.d/daemon
daemon守护进程相当于WINDOWS的service

Centos7不再使用init启动服务
修改某个启动服务的设定
cd /usr/lib/systemd/system/
查看某个服务开机是否执行
cd /etc/systemd/system/
查看服务运行状态信息,可以看到是否自启
systemctl status [daemon]
systemctl is-enable [daemon]
Linux 系统中所有的自启动服务都会在/etc/systemd/system/multi-user.target.wants/目录下生成相应的【自启动配置文件】
ls -l /etc/systemd/system/multi-user.target.wants/
查看linux服务器开机自启动服务
systemctl list-unit-files | grep enabled

 

七:账户信息
查看UID为0的用户
awk -F: '$3==0 {print $1}' /etc/passwd
查看UID相同的用户,防止克隆的用户
awk -F: '{a[$3]++}END{for(i in a)if(a[i]>1)print i}' /etc/passwd
排查root用户外,查看root组下的用户,其实就是GID为0的用户
more /etc/group | grep -v '^#' | gawk -F: '{if ($1!="root"&&$3==0) print $1}'
查找可登录的用户
cat /etc/passwd | grep -E "/bin/bash$" | awk -F: '{print $1}'
可远程登录的账户信息
awk '/\$1|\$6/{print $1}' /etc/shadow
除root帐号外,其他帐号是否存在sudo权限。如非管理需要,普通帐号应删除sudo权限
more /etc/sudoers | grep -v "^#\|^$" | grep "ALL=(ALL)"
空口令用户
gawk -F: '($2=="") {print $1}' /etc/shadow
cat /etc/shadow

查找公钥文件
cat /root/.ssh/*.pub
cat /root/.ssh/authorized_keys

八:历史命令排查
通过.bash_history查看帐号执行过的系统命令
1、root的历史命令
histroy
2、打开/home各帐号目录下的.bash_history,查看普通帐号的历史命令
为历史的命令增加登录的IP地址、执行命令时间等信息:
1)保存1万条命令
sed -i 's/^HISTSIZE=1000/HISTSIZE=10000/g' /etc/profile
2)在/etc/profile的文件尾部添加如下行数配置信息:
######jiagu history xianshi#########
USER_IP=`who -u am i 2>/dev/null | awk '{print $NF}' | sed -e 's/[()]//g'`
if [ "$USER_IP" = "" ]
then
USER_IP=`hostname`
fi
export HISTTIMEFORMAT="%F %T $USER_IP `whoami` "
shopt -s histappend
export PROMPT_COMMAND="history -a"
######### jiagu history xianshi ##########
3)source /etc/profile让配置生效
生成效果: 1 2018-07-10 19:45:39 192.168.204.1 root source /etc/profile
3、历史操作命令的清除:history -c
但此命令并不会清除保存在文件中的记录,因此需要手动删除.bash_profile文件中的记录。

九:系统日志排查
登录成功
more /var/log/secure* | grep "Accepted password"
登录成功的源IP 次数
grep "Accepted" /var/log/secure | awk '{print $11}' | sort | uniq -c | sort -n
登录失败
more /var/log/secure* | grep "Failed password"
登录失败的源IP 次数
grep "Failed" /var/log/secure | awk '{print $11}' | sort | uniq -c | sort -n
空口令登录
more /var/log/secure* | grep "Accepted none"
新增用户
more /var/log/secure* | grep "new user"


十:工具
WEBSHELL
河马webshell查杀:http://www.shellpub.com
深信服Webshell网站后门检测工具:http://edr.sangfor.com.cn/backdoor_detection.html

病毒查杀 clamav ClamAV的官方下载地址为:http://www.clamav.net/download.html
#安装方式一
yum install -y clamav
#更新病毒库
freshclam
#扫描方法
clamscan -r /etc --max-dir-recursion=5 -l /root/etcclamav.log
clamscan -r /bin --max-dir-recursion=5 -l /root/binclamav.log
clamscan -r /usr --max-dir-recursion=5 -l /root/usrclamav.log
#扫描并杀毒
clamscan -r --remove /usr/bin/bsd-port
clamscan -r --remove /usr/bin/
clamscan -r --remove /usr/local/zabbix/sbin
#查看日志发现
cat /root/usrclamav.log |grep FOUND

#安装方式二
1、安装zlib:
wget http://nchc.dl.sourceforge.net/project/libpng/zlib/1.2.7/zlib-1.2.7.tar.gz
tar -zxvf zlib-1.2.7.tar.gz
cd zlib-1.2.7
#安装一下gcc编译环境: yum install gcc
CFLAGS="-O3 -fPIC" ./configure --prefix= /usr/local/zlib/
make && make install
2、添加用户组clamav和组成员clamav:
groupadd clamav
useradd -g clamav -s /bin/false -c "Clam AntiVirus" clamav
3、安装Clamav
tar –zxvf clamav-0.97.6.tar.gz
cd clamav-0.97.6
./configure --prefix=/opt/clamav --disable-clamav -with-zlib=/usr/local/zlib
make
make install
4、配置Clamav
mkdir /opt/clamav/logs
mkdir /opt/clamav/updata
touch /opt/clamav/logs/freshclam.log
touch /opt/clamav/logs/clamd.log
cd /opt/clamav/logs
chown clamav:clamav clamd.log
chown clamav:clamav freshclam.log
5、ClamAV 使用:
/opt/clamav/bin/freshclam 升级病毒库
./clamscan –h 查看相应的帮助信息
./clamscan -r /home 扫描所有用户的主目录就使用
./clamscan -r --bell -i /bin 扫描bin目录并且显示有问题的文件的扫描结果

 

标签:log,etc,--,clamav,cron,排查,linux,root
From: https://www.cnblogs.com/beikenxiong/p/17359914.html

相关文章

  • Linux 内存管理 pt.1
    哈喽大家好,我是咸鱼 今天我们来学习一下Linux操作系统核心之一:内存 跟CPU一样,内存也是操作系统最核心的功能之一,内存主要用来存储系统和程序的指令、数据、缓存等 关于内存的学习,我会尽量以通俗易懂的方式且分成多篇文章去讲解 那么今天在pt.1文章中,我们来学习......
  • Linux-Centos 用crontab定时运行python脚本详细步骤
    服务器总是要定时运行某个程序,而我在解决这个问题的时候遇到很多困难,特此记录下来。1.编辑crontab配置crontab-e服务器一般会安装好crontab,若没有安装请按命令安装yuminstallcrontabs2.编写配置文件当打开配置文件的时候,我们可以看到类似的配置代码。每一行都代表一个......
  • Linux安装Mysql5.7
    前言:还是和以前一样,linux安装软件的目录都是data目录1.进入data目录,创建mysql目录并进入该目录cd/datamkdirmysqlcdmysql 2.删除默认配置,不推荐rm-rf rm/etc/my.cnfy 3.上传"mysql-5.7.23-linux-glibc2.12-x86_64.tar.gz"文件到当前目录(/data/mysql)"m......
  • Linux grep命令详细教程
    [本文出自天外归云的博客园]简介Linuxgrep命令是一种非常常用的文本搜索工具,它可以在给定的文件中搜索匹配的字符串,并输出匹配的行。grep是全称“globalsearchregularexpressionprint”,可以识别正则表达式,并使用正则表达式进行搜索。选项以下是 grep 的所有选项:grep......
  • 线上问题排查回答(转载)
    面试官:「你是怎么定位线上问题的?」这个面试题我在两年社招的时候遇到过,前几天面试也遇到了。我觉得我每一次都答得中规中矩,今天来梳理复盘下,下次又被问到的时候希望可以答得更好。下一次我应该会按照这个思路去答:1、如果线上出现了问题,我们更多的是希望由监控告警发现我们出了......
  • Linux安装配置达梦数据库教程
    1.安装规范:为方便之后统一运维管理,现规定以下信息:安装包和密钥存放目录:/boban安装目录:/home/dmdba/dmdbms数据目录:/dbdata/dmdata挂载目录:/mnt2.数据安装工作:数据库安装准备工作:创建组:[root@localhost/]#groupadddinstall创建用户:[root@localhost/]#useradd-gdinst......
  • 基于Linux系统的PXE搭建方法
    本文分享自天翼云开发者社区《基于Linux系统的PXE搭建方法》,作者:t***n 一、底层环境准备1、安装RedHat7.6系统2、关闭防火墙和Selinuxsystemctlstopfirewalldchkconfigfirewalldoffvim/etc/sysconfig/selinux    修改SELINUX=disabled3、配置本地yum源vim/e......
  • 在linux系统里将图片通过代码打出来
    打开终端1,访问https://sourceforge.net/projects/aa-project/files打开后选择aa-lib和aview分别下载最新版本2,将这两个安装包上传到linux系统里,并解压。3,这两个包,分别./configure&&make&&makeinstall4,完成后,yuminstallImageMagick5,上传一张图片,使用asciiview......
  • Linux命令(二)
    一.su命令(切换账户)su命令可以用于切换账户//语法:su-[用户名]不写用户名默认切换到root管理员root账户切换到普通账户不需要密码普通账户切换到管理员账户需要密码二.sudo命令(暂时使用管理员权限)sudo命令可以为一条命令暂时赋予管理员权限语法:sudo其他命令但是并......
  • Grid/RAC 11.2.0.4 与 Linux 7 的一些兼容性问题
    1、在LINUX6上安装11.2.0.4的RAC,基本上不会遇到什么问题,但如果在LINUX7上安装11.2.0.4的RAC,经常性地会遇到问题。为了很好地解决这个问题,ORACLE官方在MOS上给了一篇文档《Installationwalk-through-OracleGrid/RAC11.2.0.4onOracleLinux7(DocID1951613.1)》,这篇文档......