0

0

Linux系统如何加固_深度讲解提升系统稳定性【教学】

舞姬之光

舞姬之光

发布时间:2025-12-15 14:54:07

|

108人浏览过

|

来源于php中文网

原创

Linux系统加固核心是缩小攻击面、限制权限、及时响应异常,重点在配置管理、服务精简、日志审计和更新机制;需关闭非必要服务与端口、启用防火墙、禁用IPv6(若不用)、禁止root远程登录、强制密码复杂度、清理长期未改密账户、启用auditd监控敏感操作。

linux系统如何加固_深度讲解提升系统稳定性【教学】

Linux系统加固不是装几个工具就完事,核心是缩小攻击面、限制权限、及时响应异常。重点在配置管理、服务精简、日志审计和更新机制,而不是堆砌安全软件。

关掉不用的服务和端口

默认安装常开启SSH、FTP、Telnet、HTTP等服务,但多数场景只需SSH。运行ss -tulnnetstat -tuln查看监听端口,对照业务需求逐个确认是否必要。

  • systemctl disable --now servicename彻底停用非必需服务(如cups、avahi-daemon、rpcbind)
  • 防火墙必须启用:推荐ufw(桌面/轻量环境)或firewalld(CentOS/RHEL),仅放行明确需要的端口,例如只允许22/tcp且限定来源IP
  • 禁用IPv6若未使用:在/etc/sysctl.conf中添加net.ipv6.conf.all.disable_ipv6 = 1并执行sysctl -p

严格控制用户与权限

root直接登录、弱密码、共享账户是常见风险点。加固从身份入口开始。

  • 禁止root远程SSH登录:修改/etc/ssh/sshd_configPermitRootLogin no,改用普通用户+sudo
  • 强制密码复杂度:安装libpam-pwquality(Debian/Ubuntu)或pam_pwquality(RHEL/CentOS),配置/etc/pam.d/common-password,要求最小长度、大小写、数字、特殊字符
  • 定期清理无用账户:cut -d: -f1 /etc/passwd | xargs -I{} sh -c 'chage -l {} 2>/dev/null | grep "Password expires" | grep "never" || echo {}'可快速定位长期未改密账户

启用日志审计与实时监控

没记录=没发生;没分析=白记录。关键不是存多少日志,而是能快速定位异常行为。

Frase
Frase

Frase是一款出色的长篇 AI 写作工具,快速创建seo优化的内容。

下载
  • 开启auditd:监控敏感操作,如/etc/shadow读写、sudo命令执行、用户切换。规则示例:-w /etc/shadow -p wa -k shadow_access
  • 集中日志建议用/var/log/secure/var/log/auth.log/var/log/messages保留90天以上
  • faillog查暴力尝试,lastb看失败登录,配合脚本自动封IP(如结合fail2ban

保持内核与软件最小化更新

不更新=留后门;盲目更新=引新坑。关键是建立可控、可回退的更新策略。

  • 禁用自动升级(尤其生产环境):Ubuntu中关闭unattended-upgrades,RHEL中设yum-cron为notify-only模式
  • 只更新安全补丁:Debian/Ubuntu用apt list --upgradable | grep security,RHEL/CentOS用yum update --security
  • 内核保持最新稳定版,但避免频繁切换。升级前备份/boot并验证grub配置,确保旧内核仍可启动

基本上就这些。加固不是一劳永逸,而是形成“检查→收敛→验证→复盘”的闭环。每次上线新服务、新增用户、调整网络策略,都应回到这四个维度再过一遍。不复杂,但容易忽略。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

232

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

436

2024.03.01

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

392

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

572

2023.08.10

http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

368

2023.11.09

http请求415错误怎么解决
http请求415错误怎么解决

解决方法:1、检查请求头中的Content-Type;2、检查请求体中的数据格式;3、使用适当的编码格式;4、使用适当的请求方法;5、检查服务器端的支持情况。更多http请求415错误怎么解决的相关内容,可以阅读下面的文章。

410

2023.11.14

HTTP 503错误解决方法
HTTP 503错误解决方法

HTTP 503错误表示服务器暂时无法处理请求。想了解更多http错误代码的相关内容,可以阅读本专题下面的文章。

1937

2024.03.12

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1996

2024.08.16

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

0

2026.01.20

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.5万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号