百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

Linux故障排查思路及常用命令(收藏)

liuian 2024-12-14 13:33 33 浏览

Liunx应急一直都是安全行业中的重点,

由于是全命令行界面,排查起来也没那么方便,

也一直想做这方面的笔记,今天抽空来总结一下。

目录:

现场环境

如果是Linux系统的话,见过最多的是CentOS ,Linux是全命令界面的,

如果是Windows系统的话,一般是Windows server

常见应急问题

大多数应急常见的问题都是挖矿,或者是被植入菠菜

小部分是中了勒索病毒,如果是勒索病毒的话,看看360、腾讯有没有什么

解密工具,

如果没有的话就重装系统吧,自求多福 (逃。。

排查思路及方法

本节将讲解一些基本的流程,以及一些常用的命令。

基本流程

  1. 接到应急指令后,一般都需要到客户现场去处理的,最好带上电脑和笔记本。
  2. 到达现场后,跟客户沟通,我方需要确认一些信息(我在Windows安全应急的第三篇有讲解一些),
    方便定(shuai)位(guo)问题,后面客户可能会让你上机操作,或者是使用你自己电脑登录目标机器查找问题。
  3. 无论是挖矿还是菠菜,流程都差不多,

找出问题 –> 解决问题 –> 编写报告

有句传言道是:扫描一分钟,报告一个钟,

如果是菠菜的话,那要多注意注意是不是修改了网站配置文件还是直接在网页上植入入的链接。

进程排查命令

整理一些基本的命令,使用不分先后顺序

这里只简单说明,

服务器被入侵后,攻击者难免会利用恶意程序来达到自己的目的。

1. 查看当前系统状态(top)

top命令:可以持续的监视进程的信息。

挖矿应急通常优先使用top命令来查看系统进程,

一般挖矿病毒站用CPU比较大

2. 查看当前系统进程信息(ps)

ps命令:可以查看进程的瞬间信息。
常用参数:

  1. -a:显示现行终端机下的所有程序,包括其他用户的程序。
  2. -e:列出程序时,显示每个程序所使用的环境变量。
  3. -f:显示UID,PPIP,C与STIME栏位。

3. 查看非root运行的进程(ps)

命令:

ps -U root -u root -N

4. 查看用户root运行的进程(ps)

命令:

ps -u root

5. 查看有没有奇怪进程(ps)

命令:

ps -aef | grep inetd

grep 是搜索命令

inetd 程序是一个Linux守护进程.

6. 检测隐藏进程(ps)

命令:

ps -ef | awk '{print}' | sort -n |uniq >1

命令:

ls /proc | sort -n |uniq >2

sort 命令将文本文件内容加以排序,可针对文本文件的内容,以行为单位来排序。-n 参数依照数值的大小排序。

uniq 命令用于检查及删除文本文件中重复出现的行列,一般与 sort 命令结合使用。

7. 检测系统守护进程(ls)

命令:

ls /etc/crontab

任务及用户活动排查命令

说明:机器使用过程中难免会留下一些痕迹

1. 查看当前有谁登陆在服务器上(who)

who 命令查看当前登录用户(tty本地登陆 pts远程登录)

命令:

who

w 命令查看系统信息,想知道某一时刻用户的行为

2. 查看当前登陆用户的IP信息(who)

命令:

who -m

3. 查看近期用户登陆情况(last)

命令:

last -n 5 ## -n 5 表示输出5条

4. 查看历史命令(history)

命令:

history 5 ## 5 表示输出最近使用的5条命令

5. 查看空口令账号(awk)

awk是一种编程语言,用于对文本和数据进行处理的

语法:awk [options] ‘pattern{action}’ file

命令:

awk -F: '($2=="")' /etc/shadow

没有的话啥都不输出

在没有options和pattern的情况下,可以使用cat命令

6. 查看uid为0的账号(awk)

命令:

awk -F: '($3==0)' /etc/passwd

7. 查看uid为0的账号(grep)

命令:

grep -v -E "^#" /etc/passwd | awk -F: '$3==0{print $1}'

8. 查看进程树是否所有异常进程存在一个父进程、判断进程的父子关系(pstree)

命令:

pstree -p

网络排查命令

说明:挖矿病毒避免不了要跟主机通信

1. 列出本机所有的连接和监听的端口,查看有没有非法连接(netstat)

netstat 命令用来打印Linux中网络系统的状态信息。
常用参数:

  1. -a或–all:显示所有连线中的Socket。
  2. -c或–continuous:持续列出网络状态。
  3. -i或–interfaces:显示网络界面信息表单。
  4. l或–listening:显示监控中的服务器的Socket。
  5. -n或–numeric:直接使用ip地址,而不通过域名服务器。
  6. -t或–tcp:显示TCP传输协议的连线状况。
  7. -u或–udp:显示UDP传输协议的连线状况。

命令:

netstat -lntp

2. 查看谁在使用某个端口(lsof)

lsof 命令用于查看你进程开打的文件,打开文件的进程,进程打开的端口(TCP、UDP)。
常用参数:

  1. -g:列出GID号进程详情;
  2. -d<文件号>:列出占用该文件号的进程;
  3. -i<条件>:列出符合条件的进程。(4、6、协议、:端口、 @ip )
  4. -p<进程号>:列出指定进程号所打开的文件;
  5. -u:列出UID号进程详情;

命令:

lsof -i :22 # 看看谁在使用22端口

3. 查看多个进程号对应的文件信息(lsof)

命令:

lsof -p 2,3 # 使用逗号分隔

4. 查看所有tcp网络连接信息(lsof)

命令:

lsof -i tcp

5. 查看所有udp网络连接信息(lsof)

命令:

lsof -i udp

文件排查命令

说明:服务器被入侵后,攻击者基本上都需要修改一些文件来维持脚本的

运行

1. 查看所有文件,包括隐藏的文件(ls)

ls 命令用来显示目标列表,不同类型的文件颜色也不同
常用参数:

  1. -a:显示所有文件及目录,包括隐藏文件
  2. -l:以长格式显示目录下的内容列表。
  3. -t:用文件和目录的更改时间排序

命令:

ls -la

2. 查看文件路径(whereis)

命令:

whereis filename

3. 查看文件创建时间(ls)

命令:

ls -al filname

4. 查找最近24小时内修改过的文件(find)

命令:

find ./ -mtime 0

find 命令用来在指定目录下查找文件。

参数 -mtime n 按照文件的更改时间来找文件,n为整数。

例:

  1. -mtime 0 表示文件修改时间距离当前为0天的文件,即距离当前时间不到1天(24小时)以内的文件。
  2. -mtime 1 表示文件修改时间距离当前为1天的文件,即距离当前时间1天(24小时-48小时)的文件。
  3. -mtime+1 表示文件修改时间为大于1天的文件,即距离当前时间2天(48小时)之外的文件
  4. -mtime -1 表示文件修改时间为小于1天的文件,即距离当前时间1天(24小时)之内的文件

5. 查找以.txt结尾的文件名(find)

命令:

find / -name "*.txt"

忽略大小写,命令:

find / -iname "*.txt"

6. 查找不是以.txt结尾的文件(find)

命令:

find / ! -name "*.txt"

总结

参考了很多的文章,

但是这些命令实在是太多了,

看着网上写的很乱,本想自己总结整理一下,

没想到越总结越觉得乱,hhh,不知道您乱了没。

相关推荐

教你把多个视频合并成一个视频的方法

一.情况介绍当你有一个m3u8文件和一个目录,目录中有连续的视频片段,这些片段可以连成一段完整的视频。m3u8文件打开后像这样:m3u8文件,可以理解为播放列表,里面是播放视频片段的顺序。视频片段像这...

零代码编程:用kimichat合并一个文件夹下的多个文件

一个文件夹里面有很多个srt字幕文件,如何借助kimichat来自动批量合并呢?在kimichat对话框中输入提示词:你是一个Python编程专家,完成如下的编程任务:这个文件夹:D:\downloa...

Java APT_java APT 生成代码

JavaAPT(AnnotationProcessingTool)是一种在Java编译阶段处理注解的工具。APT会在编译阶段扫描源代码中的注解,并根据这些注解生成代码、资源文件或其他输出,...

Unit Runtime:一键运行 AI 生成的代码,或许将成为你的复制 + 粘贴神器

在我们构建了UnitMesh架构之后,以及对应的demo之后,便着手于实现UnitMesh架构。于是,我们就继续开始UnitRuntime,以用于直接运行AI生成的代码。PS:...

挣脱臃肿的枷锁:为什么说Vert.x是Java开发者手中的一柄利剑?

如果你是一名Java开发者,那么你的职业生涯几乎无法避开Spring。它如同一位德高望重的老国王,统治着企业级应用开发的大片疆土。SpringBoot的约定大于配置、SpringCloud的微服务...

五年后,谷歌还在全力以赴发展 Kotlin

作者|FredericLardinois译者|Sambodhi策划|Tina自2017年谷歌I/O全球开发者大会上,谷歌首次宣布将Kotlin(JetBrains开发的Ja...

kotlin和java开发哪个好,优缺点对比

Kotlin和Java都是常见的编程语言,它们有各自的优缺点。Kotlin的优点:简洁:Kotlin程序相对于Java程序更简洁,可以减少代码量。安全:Kotlin在类型系统和空值安全...

移动端架构模式全景解析:从MVC到MVVM,如何选择最佳设计方案?

掌握不同架构模式的精髓,是构建可维护、可测试且高效移动应用的关键。在移动应用开发中,选择合适的软件架构模式对项目的可维护性、可测试性和团队协作效率至关重要。随着应用复杂度的增加,一个良好的架构能够帮助...

颜值非常高的XShell替代工具Termora,不一样的使用体验!

Termora是一款面向开发者和运维人员的跨平台SSH终端与文件管理工具,支持Windows、macOS及Linux系统,通过一体化界面简化远程服务器管理流程。其核心定位是解决多平台环境下远程连接、文...

预处理的底层原理和预处理编译运行异常的解决方案

若文章对您有帮助,欢迎关注程序员小迷。助您在编程路上越走越好![Mac-10.7.1LionIntel-based]Q:预处理到底干了什么事情?A:预处理,顾名思义,预先做的处理。源代码中...

为“架构”再建个模:如何用代码描述软件架构?

在架构治理平台ArchGuard中,为了实现对架构的治理,我们需要代码+模型描述所要处理的内容和数据。所以,在ArchGuard中,我们有了代码的模型、依赖的模型、变更的模型等,剩下的两个...

深度解析:Google Gemma 3n —— 移动优先的轻量多模态大模型

2025年6月,Google正式发布了Gemma3n,这是一款能够在2GB内存环境下运行的轻量级多模态大模型。它延续了Gemma家族的开源基因,同时在架构设计上大幅优化,目标是让...

比分网开发技术栈与功能详解_比分网有哪些

一、核心功能模块一个基本的比分网通常包含以下模块:首页/总览实时比分看板:滚动展示所有正在进行的比赛,包含比分、比赛时间、红黄牌等关键信息。热门赛事/焦点战:突出显示重要的、关注度高的比赛。赛事导航...

设计模式之-生成器_一键生成设计

一、【概念定义】——“分步构建复杂对象,隐藏创建细节”生成器模式(BuilderPattern):一种“分步构建型”创建型设计模式,它将一个复杂对象的构建与其表示分离,使得同样的构建过程可以创建...

构建第一个 Kotlin Android 应用_kotlin简介

第一步:安装AndroidStudio(推荐IDE)AndroidStudio是官方推荐的Android开发集成开发环境(IDE),内置对Kotlin的完整支持。1.下载And...