一篇文章解决Linux系统安全问题排查,另配实操环境
nanshan 2025-07-28 19:15 4 浏览 0 评论
实操地址:
https://www.skillup.host/1/linux/safe/command.md
# Linux 安全检查排查指南
## 1. 系统账户安全检查
### 1.1 检查异常账户
```bash
# 检查是否存在异常root权限账户
grep ":0:" /etc/passwd
# 查看所有UID为0的账户
awk -F: '($3 == 0) {print}' /etc/passwd
# 查看可登录账户
cat /etc/passwd | grep -v nologin | grep -v false
# 查看空密码账户
awk -F: '($2 == "") {print}' /etc/shadow
# 检查sudo权限
cat /etc/sudoers | grep -v "^#\|^#34; | grep "ALL=(ALL)"
# 检查用户组信息
cat /etc/group | grep -E "(root|wheel|admin)"
```
### 1.2 密码策略检查
```bash
# 检查密码策略配置
cat /etc/login.defs | grep -E "(PASS_MAX_DAYS|PASS_MIN_DAYS|PASS_WARN_AGE)"
# 检查PAM密码复杂度要求
cat /etc/pam.d/common-password | grep pam_pwquality
# 检查账户锁定策略
cat /etc/pam.d/common-auth | grep pam_tally2
```
## 2. 登录安全检查
### 2.1 登录记录分析
```bash
# 查看最近登录记录
last -n 20 # 查看最近20次登录记录
lastb -n 20 # 查看最近失败的登录尝试
# 检查当前登录用户
who
w
# 查看登录历史
last | head -20
lastb | awk '{ print $3}' | sort | uniq -c | sort -n #查找试图非法登录的ip
```
### 2.2 SSH安全检查
```bash
# 检查SSH异常登录
grep "Failed password" /var/log/auth.log # Debian/Ubuntu
grep "Failed password" /var/log/secure # CentOS/RHEL
# 检查SSH配置安全性
cat /etc/ssh/sshd_config | grep -E "(PermitRootLogin|PasswordAuthentication|Port)"
# 查看SSH连接状态
ss -tnlp | grep :22
# 检查SSH密钥
ls -la ~/.ssh/
cat ~/.ssh/authorized_keys
```
### 2.3 暴力破解检测
```bash
# 统计失败登录次数
grep "Failed password" /var/log/auth.log | awk '{print $11}' | sort | uniq -c | sort -nr
# 检查可疑IP
grep "Failed password" /var/log/auth.log | grep -oE "[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}" | sort | uniq -c | sort -nr
```
## 3. 进程和服务检查
### 3.1 进程分析
```bash
# 检查异常进程
ps aux | grep -E "(root|nobody)" # 查看root和nobody运行的进程
top -n 1 -b
# 检查进程树
pstree -p
# 查看系统负载
uptime
# 检查内存使用
free -h
```
### 3.2 网络连接检查
```bash
# 检查异常网络连接
netstat -antlp
ss -antlp
lsof -i
# 检查监听端口
netstat -tulnp
# 检查网络连接状态
netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}'
```
### 3.3 定时任务检查
```bash
# 检查异常定时任务
crontab -l # 当前用户计划任务
ls -la /etc/cron* # 系统计划任务
cat /etc/crontab
# 检查所有用户的定时任务
for user in $(cut -f1 -d: /etc/passwd); do echo "User: $user"; crontab -u $user -l 2>/dev/null; done
# 检查系统定时任务目录
ls -la /var/spool/cron/
```
## 4. 文件系统检查
### 4.1 权限检查
```bash
# 查找SUID/SGID文件
find / -perm -4000 -type f -exec ls -la {} \; 2>/dev/null
find / -perm -2000 -type f -exec ls -la {} \; 2>/dev/null
# 查找可写目录和文件
find / -perm -2 -type d -exec ls -ld {} \; 2>/dev/null # 可写目录
find / -xdev -type d \( -perm -0002 -a ! -perm -1000 \) -print # 全局可写且无粘滞位
# 查找最近修改的文件
find / -mtime -3 -type f -exec ls -la {} \; 2>/dev/null # 3天内修改的文件
find / -ctime -1 -type f -exec ls -la {} \; 2>/dev/null # 1天内状态改变的文件
```
### 4.2 敏感文件检查
```bash
# 检查重要配置文件
ls -la /etc/passwd /etc/shadow /etc/group /etc/sudoers
# 检查系统关键目录权限
ls -ld /etc /bin /sbin /usr/bin /usr/sbin
# 查找隐藏文件
find / -name ".*" -type f 2>/dev/null | head -20
# 检查临时目录
ls -la /tmp /var/tmp
```
### 4.3 文件完整性检查
```bash
# 使用AIDE进行文件完整性检查
aide --check
# 检查系统文件MD5
rpm -Va # CentOS/RHEL
dpkg --verify # Debian/Ubuntu
```
## 5. 日志分析
### 5.1 系统日志
```bash
# 查看系统日志
dmesg | grep -i error
journalctl -p 3 -xb # 查看系统错误日志
# 检查认证日志
tail -f /var/log/auth.log # Debian/Ubuntu
tail -f /var/log/secure # CentOS/RHEL
# 查看系统消息
tail -f /var/log/messages
```
### 5.2 Web服务日志
```bash
# 检查web日志(如有)
tail -n 100 /var/log/apache2/access.log # Apache
tail -n 100 /var/log/nginx/access.log # Nginx
grep -i "php" /var/log/apache2/access.log | grep -v "200"
# 分析访问频率
awk '{print $1}' /var/log/apache2/access.log | sort | uniq -c | sort -nr | head -10
```
### 5.3 日志异常检测
```bash
# 检查日志文件大小异常
ls -lh /var/log/ | awk '$5 > "100M" {print $0}'
# 查找可疑日志条目
grep -i "attack\|hack\|exploit" /var/log/messages
# 检查日志轮转
ls -la /etc/logrotate.d/
```
## 6. 网络和防火墙检查
### 6.1 防火墙状态
```bash
# 检查防火墙规则
iptables -L -n -v
ufw status verbose # Ubuntu
firewall-cmd --list-all # CentOS/RHEL 7+
# 检查开放端口
nmap -sT -O localhost
netstat -tulnp
```
### 6.2 网络配置检查
```bash
# 检查网络接口
ip addr show
ifconfig -a
# 检查路由表
ip route show
route -n
# 检查DNS配置
cat /etc/resolv.conf
# 检查hosts文件
cat /etc/hosts
```
### 6.3 网络安全检查
```bash
# 检查网络连接
netstat -an | grep ESTABLISHED
# 检查ARP表
arp -a
# 检查网络统计
netstat -s
```
## 7. 恶意软件和rootkit检查
### 7.1 Rootkit检测
```bash
# 安装并运行rootkit检测工具
chkrootkit
rkhunter --check
# 更新病毒库
rkhunter --update
freshclam # ClamAV
```
### 7.2 恶意软件扫描
```bash
# 使用ClamAV扫描
clamscan -r /home
clamscan -r /tmp
# 检查可疑进程
ps aux | grep -E "(bitcoin|miner|crypto)"
```
## 8. 系统配置安全检查
### 8.1 内核参数检查
```bash
# 检查内核参数
sysctl -a | grep -E "(net.ipv4.ip_forward|net.ipv4.conf.all.send_redirects)"
# 检查内核模块
lsmod
# 查看内核版本
uname -a
```
### 8.2 服务配置检查
```bash
# 检查运行的服务
systemctl list-units --type=service --state=running
# 检查开机自启服务
systemctl list-unit-files --type=service --state=enabled
# 检查服务配置
systemctl status sshd
systemctl status apache2
```
## 9. 应急响应脚本
### 9.1 快速检查脚本
```bash
#!/bin/bash
# 快速安全检查脚本
echo "=== 系统基本信息 ==="
uname -a
uptime
who
echo "=== 可疑进程检查 ==="
ps aux | awk '$3 > 50.0 || $4 > 50.0 {print $0}'
echo "=== 网络连接检查 ==="
netstat -antlp | grep ESTABLISHED | wc -l
echo "当前建立的连接数"
echo "=== 最近登录检查 ==="
last -n 5
echo "=== 磁盘使用检查 ==="
df -h | awk '$5 > 80 {print $0}'
```
### 9.2 日志收集脚本
```bash
#!/bin/bash
# 安全事件日志收集
LOG_DIR="/tmp/security_logs_$(date +%Y%m%d_%H%M%S)"
mkdir -p $LOG_DIR
# 收集系统信息
uname -a > $LOG_DIR/system_info.txt
ps aux > $LOG_DIR/processes.txt
netstat -antlp > $LOG_DIR/network.txt
last -n 50 > $LOG_DIR/login_history.txt
# 收集日志文件
cp /var/log/auth.log $LOG_DIR/ 2>/dev/null
cp /var/log/secure $LOG_DIR/ 2>/dev/null
cp /var/log/messages $LOG_DIR/ 2>/dev/null
echo "日志收集完成,保存在: $LOG_DIR"
```
## 10. 安全加固建议
### 10.1 基础加固
- 定期更新系统和软件包
- 禁用不必要的服务
- 配置强密码策略
- 启用防火墙
- 配置日志审计
### 10.2 高级加固
- 部署入侵检测系统(IDS)
- 配置文件完整性监控
- 实施网络分段
- 部署安全信息与事件管理(SIEM)
- 定期进行安全评估
**注意**: 在生产环境中运行这些命令时请谨慎,某些命令可能会产生大量输出或消耗系统资源。建议先在测试环境中验证。
相关推荐
- 轻量级分析利器再升级:解读 DuckDB 1.3.0 新特性
-
DuckDB团队近日正式发布了最新版本——DuckDB1.3.0,代号“Ossivalis”。此次版本以金眼鸭的远古祖先BucephalaOssivalis命名,象征项目在演化和成长过...
- C++跨平台编译的终极奥义:用Docker把环境差异按在地上摩擦
-
"代码在本地跑得飞起,一上服务器就coredump?"——每个C++程序员都经历过的《编译器的复仇》事件!大家好,我是Henry,废话少说,今天来简单谈一下跨平台编译的那些事儿,...
- 全网最全-Version Script以及__asm__((".symver xxx"))使用总结
-
首先提醒一点,一切的前提建立在你的名字必须要mangling,不然无论你写的versionscript还是__asm__都不会起任何效果VersionScript简单用法:这是一个典型例子,这个例...
- Ubuntu 25.04 Beta发布:Linux 6.14内核
-
IT之家3月28日消息,Canonical昨日(3月27日)放出了Beta版Ubuntu25.04系统镜像,代号“PluckyPuffin”,稳定版预估将于2025年...
- 不同平台CRT的区别?什么是UCRT?如何看libc源代码?
-
若文章对您有帮助,欢迎关注程序员小迷。助您在编程路上越走越好!CRT运行时库C标准规定例如输入输出函数、字符串函数、内存操作等接口,一般采用C运行时库实现。微软的CRT微软有两套CRT,早期的MS...
- 信创力量,中兴绽放——中兴新支点桌面操作系统安装与使用全攻略
-
原文链接:「链接」Hello,大家好啊,今天给大家带来一篇中兴新支点桌面操作系统安装使用的文章,欢迎大家分享点赞,点个在看和关注吧!中兴新支点桌面操作系统是一款基于Linux内核、面向政企和信创环...
- Linux下安装常用软件都有哪些?做了一个汇总列表,你看还缺啥?
-
1.安装列表MySQL5.7.11Java1.8ApacheMaven3.6+tomcat8.5gitRedisNginxpythondocker2.安装mysql1.拷贝mysql安装文件到...
- 一篇文章解决Linux系统安全问题排查,另配实操环境
-
实操地址:https://www.skillup.host/1/linux/safe/command.md#Linux安全检查排查指南##1.系统账户安全检查###1.1检查异常账户``...
- 程序员必备的学习笔记《TCP/IP详解(一)》
-
为什么会有TCP/IP协议在世界上各地,各种各样的电脑运行着各自不同的操作系统为大家服务,这些电脑在表达同一种信息的时候所使用的方法是千差万别。就好像圣经中上帝打乱了各地人的口音,让他们无法合作一样...
- 《Linux常用命令》(linux的常用命令总结)
-
一、文件与目录操作1.目录导航pwd:显示当前工作目录路径示例:pwd关键词:当前路径、工作目录cd:切换目录示例:cd/home/user#切换到绝对路径cd..#...
- Kubernetes 教程之跟着官方文档从零搭建 K8S
-
前言本文将带领读者一起,参照者Kubernetes官方文档,对其安装部署进行讲解.Kubernetes更新迭代很快,书上、网上等教程可能并不能适用于新版本,但官方文档能.阅读这篇文章你...
- 电脑网卡坏了怎么修复(电脑网卡坏了怎么修复win7系统)
-
当电脑网卡出现故障时,无论是有线网络还是无线网络,都可能无法正常连接。下面从软件、硬件等方面,分步骤为你介绍排查与修复的解决方案。一、初步排查:锁定问题源头检查网络环境将手机、平板等其他设备连接至同一...
- 如何查询电脑/手机的物理地址(如何找手机的物理地址)
-
一、要查询电脑的物理地址(也称为MAC地址),可以按照以下步骤进行操作:1.打开命令提示符(Windows)或终端(Mac):-在Windows上,点击“开始”按钮,搜索“命令提示符”,然后点击打...
- IPv4 无网络访问权限全流程解决方案
-
当设备出现IPv4无网络访问权限问题时,多由网络配置错误、连接故障或服务异常导致。以下提供系统化的排查步骤与解决方案,帮助用户快速定位并修复问题。一、基础故障快速检查1.物理连接确认有线网络:检...
- Python教程(十九):文件操作(python操作文件夹)
-
昨天,我们学习了列表推导式,掌握了Python中最优雅的数据处理方式。今天,我们将学习文件操作—Python中读写文件的基础技能。文件操作是编程中的核心技能,无论是读取配置文件、保存用户数据,还是...
你 发表评论:
欢迎- 一周热门
-
-
UOS服务器操作系统防火墙设置(uos20关闭防火墙)
-
极空间如何无损移机,新Z4 Pro又有哪些升级?极空间Z4 Pro深度体验
-
手机如何设置与显示准确时间的详细指南
-
NAS:DS video/DS file/DS photo等群晖移动端APP远程访问的教程
-
如何在安装前及安装后修改黑群晖的Mac地址和Sn系列号
-
如何修复用户配置文件服务在 WINDOWS 上登录失败的问题
-
一加手机与电脑互传文件的便捷方法FileDash
-
日本海上自卫队的军衔制度(日本海上自卫队的军衔制度是什么)
-
10个免费文件中转服务站,分享文件简单方便,你知道几个?
-
爱折腾的特斯拉车主必看!手把手教你TESLAMATE的备份和恢复
-
- 最近发表
-
- 轻量级分析利器再升级:解读 DuckDB 1.3.0 新特性
- C++跨平台编译的终极奥义:用Docker把环境差异按在地上摩擦
- 全网最全-Version Script以及__asm__((".symver xxx"))使用总结
- Ubuntu 25.04 Beta发布:Linux 6.14内核
- 不同平台CRT的区别?什么是UCRT?如何看libc源代码?
- 信创力量,中兴绽放——中兴新支点桌面操作系统安装与使用全攻略
- Linux下安装常用软件都有哪些?做了一个汇总列表,你看还缺啥?
- 一篇文章解决Linux系统安全问题排查,另配实操环境
- 程序员必备的学习笔记《TCP/IP详解(一)》
- 《Linux常用命令》(linux的常用命令总结)
- 标签列表
-
- linux 查询端口号 (58)
- docker映射容器目录到宿主机 (66)
- 杀端口 (60)
- yum更换阿里源 (62)
- internet explorer 增强的安全配置已启用 (65)
- linux自动挂载 (56)
- 禁用selinux (55)
- sysv-rc-conf (69)
- ubuntu防火墙状态查看 (64)
- windows server 2022激活密钥 (56)
- 无法与服务器建立安全连接是什么意思 (74)
- 443/80端口被占用怎么解决 (56)
- ping无法访问目标主机怎么解决 (58)
- fdatasync (59)
- 405 not allowed (56)
- 免备案虚拟主机zxhost (55)
- linux根据pid查看进程 (60)
- dhcp工具 (62)
- mysql 1045 (57)
- 宝塔远程工具 (56)
- ssh服务器拒绝了密码 请再试一次 (56)
- ubuntu卸载docker (56)
- linux查看nginx状态 (63)
- tomcat 乱码 (76)
- 2008r2激活序列号 (65)