[安全清单] Linux 服务器安全基线:一份可以照着做的加固 Checklist
更多服务器知识,尽在hostol.com
嘿,各位服务器的“守护者”们!当你拿到一台崭新的Linux服务器,或者接手一台正在运行的服务器时,脑子里是不是会闪过一丝丝关于安全的担忧?“我的服务器安全吗?”“会不会有什么漏洞被人利用?”这些问题可一点都不过分!在网络世界里,安全就像给你的数字城堡装上坚固的门窗和警报系统。今天,Hostol就为你准备了这份详尽的Linux服务器安全基线Checklist,它就像一份装修指南,告诉你哪些地方必须加固,哪些习惯必须养成。让我们一起动手,把安全工作做到位!
一、用户账户与密码策略:守好第一道门
用户账户是进入服务器的第一道关卡,这里的安全措施可不能马虎。
1. 禁用 root 用户直接SSH登录
root
用户权限太高,就像是万能钥匙,一旦被坏人拿到,后果不堪设想。我们应该用普通用户登录,需要时再通过sudo
提权。
操作: 编辑SSH配置文件 /etc/ssh/sshd_config
,找到或添加下面这行:
PermitRootLogin no
然后重启SSH服务:sudo systemctl restart sshd
(或 sudo service ssh restart
)。从此,root
想直接敲门进来?没门!
2. 创建强密码的普通用户并使用sudo
为自己创建一个日常使用的普通账户,密码一定要复杂,包含大小写字母、数字和特殊符号,长度至少12位以上。忘记密码复杂度要求?想想那些让你抓狂的网站注册密码规则就对了!
$ sudo adduser your_username
$ sudo usermod -aG sudo your_username # 将用户添加到sudo组
3. 定期审计用户账户
时不时检查一下服务器上有哪些用户(cat /etc/passwd
),特别是那些你不认识的或者不再需要的账户,及时清理或禁用 (sudo passwd -l username
来锁定账户)。
4. 强制定期更换密码 (可选,但推荐)
虽然SSH密钥更推荐,但如果仍使用密码,可以设置密码过期策略,比如使用chage
命令。这就像银行卡密码,隔段时间换换更安心。
$ sudo chage -M 90 your_username # 设置your_username密码90天后过期
二、SSH 服务加固:远程连接的安全通道
SSH是我们远程管理服务器的主要方式,它的安全至关重要。
5. 更改默认SSH端口 (有争议,但可作为一层模糊)
默认的22端口是攻击者最先扫描的目标。虽然改端口不能从根本上阻止专业攻击,但能挡掉不少脚本小子。就像把贵重物品从客厅显眼位置挪到卧室,小偷不一定第一时间找到。
操作: 编辑 /etc/ssh/sshd_config
,修改 Port 22
为一个不常用的端口 (例如 Port 2222
)。记得在防火墙里放行新端口哦!
6. 禁用SSH密码认证,强制使用密钥认证
SSH密钥对认证远比密码认证安全。密码可能会被暴力破解,而私钥掌握在你手里,没它谁也进不来。
操作: 在 /etc/ssh/sshd_config
中设置:
PasswordAuthentication no
PubkeyAuthentication yes
确保你已经正确配置了SSH密钥对并能成功登录后再禁用密码认证!不然把自己锁在门外就尴尬了。
7. 限制SSH登录用户
只允许特定的用户或用户组通过SSH登录。
操作: 在 /etc/ssh/sshd_config
中添加 (示例):
AllowUsers your_username another_user
# 或者 AllowGroups ssh_allowed_group
8. 使用 Fail2Ban 防止暴力破解
Fail2Ban能监控系统日志,自动封禁那些多次尝试登录失败的IP地址。它就像一个警惕的保安,发现可疑分子就直接拉黑。
$ sudo apt install fail2ban # Debian/Ubuntu
$ sudo systemctl enable --now fail2ban
可以根据需要配置 /etc/fail2ban/jail.local
文件。
三、系统更新与补丁管理:填补已知的漏洞
软件漏洞是黑客入侵的常见途径,及时打补丁非常重要。
9. 定期更新系统和软件包
养成定期检查并安装系统和应用软件更新的好习惯。这就像给你的操作系统和应用打“疫苗”。
$ sudo apt update && sudo apt upgrade # Debian/Ubuntu
$ sudo yum update # CentOS/RHEL (或 dnf upgrade)
10. (可选) 配置自动安全更新
对于某些关键的安全更新,可以考虑配置系统自动安装。比如Ubuntu下的unattended-upgrades
包。
四、防火墙配置:网络边界的守护神
防火墙是控制服务器网络流量进出的第一道防线,默认拒绝所有,按需开放。
11. 启用并配置防火墙 (如UFW或firewalld)
UFW (Uncomplicated Firewall) 是Ubuntu上简单易用的防火墙工具。CentOS/RHEL常用firewalld。
UFW示例:
$ sudo ufw default deny incoming # 默认拒绝所有入站连接
$ sudo ufw default allow outgoing # 默认允许所有出站连接
$ sudo ufw allow ssh # 允许SSH (如果你改了端口,这里也要改,如 ufw allow 2222/tcp)
$ sudo ufw allow http
$ sudo ufw allow https
$ sudo ufw enable # 启用防火墙
只开放你确实需要的服务端口,其他的一律关掉!
五、服务与端口最小化:减少攻击面
运行的服务越少,系统暴露的潜在攻击面就越小。
12. 禁用不必要的服务
检查系统上运行的服务 (sudo systemctl list-units --type=service --state=running
),把那些用不上的服务禁用掉 (sudo systemctl disable --now service_name
)。这就像家里没人时关掉不必要的电器,既安全又省资源。
13. 检查监听的网络端口
使用 ss -tulnp
或 netstat -tulnp
查看哪些端口正在监听,确保都是你预期中的服务。
六、日志审计与监控:洞察异常的眼睛
日志文件记录了系统运行的蛛丝马迹,是排查问题和发现安全事件的重要依据。
14. 确保关键日志正常记录
例如 /var/log/auth.log
(或 /var/log/secure
) 记录认证信息,/var/log/syslog
(或 /var/log/messages
) 记录系统消息。
15. 定期审查日志
虽然枯燥,但定期看看日志,特别是登录尝试、错误信息等,可能会发现异常。
16. (进阶) 文件完整性监控
工具如 AIDE (Advanced Intrusion Detection Environment) 可以创建系统文件的快照,并定期比较,发现未经授权的更改。这就像给重要文件拍了照,有人动过手脚就能看出来。
七、(可选) 内核参数调整:更深层的防御
通过调整sysctl
参数,可以增强系统抵抗某些网络攻击的能力。
17. 例如启用SYN Cookies、禁用IP源路由等
编辑 /etc/sysctl.conf
或在 /etc/sysctl.d/
目录下创建自定义配置文件。例如:
net.ipv4.tcp_syncookies = 1
net.ipv4.conf.all.accept_source_route = 0
net.ipv4.conf.default.accept_source_route = 0
修改后执行 sudo sysctl -p
使其生效。这些参数比较专业,修改前请确保理解其含义。
八、定期备份:灾难恢复的生命线
这虽然不是直接的“防御”措施,但却是安全策略中不可或缺的一环!
18. 制定并执行可靠的备份策略
定期备份你的重要数据和系统配置,并确保备份文件存储在安全的地方(最好是异地)。万一服务器被黑或者发生硬件故障,备份就是你最后的救命稻草。
搞定!这份Checklist是不是让你对服务器安全有了更清晰的认识?记住,安全不是一劳永逸的事情,它是一个持续的过程,需要你定期检查、更新和调整。就像给你的数字城堡定期巡逻、加固城防一样。把这些好习惯融入日常运维中,你的服务器就能更从容地应对网络世界的风风雨雨。在Hostol,我们也非常重视服务器的安全,希望这份指南能助你一臂之力!如果你还有其他安全方面的疑问,欢迎随时交流!
相关文章:
[安全清单] Linux 服务器安全基线:一份可以照着做的加固 Checklist
更多服务器知识,尽在hostol.com 嘿,各位服务器的“守护者”们!当你拿到一台崭新的Linux服务器,或者接手一台正在运行的服务器时,脑子里是不是会闪过一丝丝关于安全的担忧?“我的服务器安全吗?”…...
企业级单元测试流程
企业级的单元测试流程不仅是简单编写测试用例,而是一整套系统化、自动化、可维护、可度量的工程实践,贯穿从代码编写到上线部署的全生命周期。下面是一个尽可能完善的 企业级单元测试流程设计方案,适用于 Java 生态(JUnit Mockit…...

安卓开发用到的设计模式(2)结构型模式
安卓开发用到的设计模式(2)结构型模式 文章目录 安卓开发用到的设计模式(2)结构型模式1. 适配器模式(Adapter Pattern)2. 装饰器模式(Decorator Pattern)3. 代理模式(Pro…...

JavaWeb:SpringBoot配置优先级详解
3种配置 打包插件 命令行 优先级 SpringBoot的配置优先级决定了不同配置源之间的覆盖关系,遵循高优先级配置覆盖低优先级的原则。以下是详细的优先级排序及配置方法说明: 一、配置优先级从高到低排序 1.命令行参数 优先级最高,通过keyvalu…...

故障率预测:基于LSTM的GPU集群硬件健康监测系统(附Prometheus监控模板)
一、GPU集群健康监测的挑战与价值 在大规模深度学习训练场景下,GPU集群的硬件故障率显著高于传统计算设备。根据2023年MLCommons统计,配备8卡A100的服务器平均故障间隔时间(MTBF)仅为1426小时,其中显存故障占比达38%&…...

【b站计算机拓荒者】【2025】微信小程序开发教程 - chapter3 项目实践 -1 项目功能描述
1 项目功能描述 # 智慧社区-小程序-1 欢迎页-加载后端:动态变化-2 首页-轮播图:动态-公共栏:动态-信息采集,社区活动,人脸检测,语音识别,心率检测,积分商城-3 信息采集页面-采集人数…...

FFmpeg 安装包全攻略:gpl、lgpl、shared、master 区别详解
这些 FFmpeg 安装包有很多版本和变种,主要区别在于以下几个方面: ✅ 一、从名称中看出的关键参数: 1. 版本号 master:开发版,最新功能,但可能不稳定。n6.1 / n7.1:正式版本,更稳定…...

AI浪潮下,媒体内容运营的五重变奏
算法驱动的个性化推荐 在信息爆炸的时代,用户面临着海量的内容选择,如何让用户快速找到感兴趣的人工智能内容,成为媒体运营的关键。算法驱动的个性化推荐模式应运而生,它通过分析用户的行为数据,如浏览历史、点赞、评论、搜索关键词等,构建用户兴趣画像 ,再依据画像为用…...

WindTerm 以 SSH 协议的方式通过安恒明御堡垒机间接访问服务器
1. 配置堡垒机秘钥 创建公私钥ssh-keygen -t rsa -b 4096执行完该命令后按照提示一路回车就能够创建出公私钥注意:在创建过程中会让你指定秘钥的存储位置以及对应的密码,最好自行指定一下 id_rsa 是私钥id_rsa.pub 是公钥 在堡垒机中指定创建好的私钥 …...

通过现代数学语言重构《道德经》核心概念体系,形成一个兼具形式化与启发性的理论框架
以下是对《道德经》的数学转述尝试,通过现代数学语言重构其核心概念,形成一个兼具形式化与启发性的理论框架: 0. 基础公理体系 定义: 《道德经》是一个动态宇宙模型 U(D,V,Φ),其中: D 为“道”的无限维…...

邂逅Node.js
首先先要来学习一下nodejs的基础(和后端开发有联系的) 再然后的学习路线是学习npm,yarn,cnpm,npx,pnpm等包管理工具 然后进行模块化的使用,再去学习webpack和git(版本控制工具&…...
计算机视觉(图像算法工程师)学习路线
计算机视觉学习路线 Python基础 常量与变量 列表、元组、字典、集合 运算符 循环 条件控制语句 函数 面向对象与类 包与模块Numpy Pandas Matplotlib numpy机器学习 回归问题 线性回归 Lasso回归 Ridge回归 多项式回归 决策树回归 AdaBoost GBDT 随机森林回归 分类问题 逻辑…...
GITLIbCICD流水线搭建
1,搭建gitLIb服务器,创建gitlibRunner 并且注册, 2. 写dockerfile 包块java程序运行的环境,jdk,参数等 , 2.1ai生成版本, # 基础镜像(JDK 17)FROM eclipse-temurin:1…...
详细介绍Qwen3技术报告中提到的模型架构技术
详细介绍Qwen3技术报告中提到的一些主流模型架构技术,并为核心流程配上相关的LaTeX公式。 这些技术都是当前大型语言模型(LLM)领域为了提升模型性能、训练效率、推理速度或稳定性而采用的关键组件。 1. Grouped Query Attention (GQA) - 分组…...

【慧游鲁博】【8】前后端用户信息管理:用户基本信息在小程序端的持久化与随时获取
文章目录 本次更新整体流程概述1. 用户登录流程前端登录处理 (login.vue)后端登录处理 (AuthServiceImpl.java) 2. 用户信息存储机制前端状态管理 (member.js) 3. 后续请求的身份验证登录拦截器 (LoginInterceptor.java)前端请求携带token 4. 获取用户信息获取用户信息接口 (Us…...
上位机知识篇---keil IDE操作
文章目录 前言文件操作按键新建打开保存保存所有编辑操作按键撤销恢复复制粘贴剪切全选查找书签操作按键添加书签跳转到上一个书签跳转到下一个书签清空所有书签编译操作按键编译当前文件构建目标文件重新构建调试操作按键进入调试模式复位全速运行停止运行单步调试逐行调试跳出…...
Odoo: Owl Hooks 深度解析技术指南
你好!作为一名 Odoo 开发者,深入理解其前端框架 Owl.js,尤其是 Hooks,是提升开发效率和代码质量的关键。这份指南将带你从基础概念到高级应用,全面掌握 Odoo 18 中 Owl Hooks 的所有知识点。 1. Hooks 核心概念介绍 什…...

SpringBoot返回xml
默认情况下引入web依赖后自带了JackJson 返回JSON数据 你也可以引入fastJSON 那么方便使用可以用JSON.xxx 如果希望Boot默认返回xml数据 <dependency><groupId>com.fasterxml.jackson.dataformat</groupId><artifactId>jackson-dataformat-xml<…...

【案例篇】 实现简单SSM工程-后端
简介 本篇文章将带你从0到1的实现一个SSM项目,通过此案例可以让你在项目中对SpringBoot的使用有一个更加详细的认识,希望这个简单的案例能够帮到你。文章内容若存在错误或需改进的地方,欢迎大家指正!若对操作有任何疑问欢迎留言&a…...

零基础学习计算机网络编程----网络基本知识
目录 1. 计算机网络发展 1.1 网络发展 1.2 媒介 2 认识协议 2.1 为什么要有协议 2.2 协议的本质 3 网络协议的初识 3.1 什么是协议分层 3.2 为什么会有 4. OSI七层模型 4.1 定义 5. TCP/IP五层(或四层)模型 5.1 有什么 6. 网络传输基本流程 6.1 网络传输流程图…...

Zynq和Microblaze的区别和优势
Zynq芯片包含了一颗双核ARM Cortex-A9处理器,这是一颗“硬”处理器---它是芯片上专用 而且优化过的硅片原件。 MicroBlaze为“软”处理器,它是由可编程逻辑部分的单元组合而成的, 也就是说,一个 软处理器的实现和部署在FPGA的逻…...

FastAPI 支持文件下载
FastAPI 支持文件下载 FastAPI 支持文件上传 Python 获取文件类型 mimetype 文章目录 1. 服务端处理1.1. 下载小文件1.2. 下载大文件(yield 支持预览的)1.3. 下载大文件(bytes)1.4. 提供静态文件服务 2. 客户端处理2.1. 普通下载2…...

CNN卷积神经网络到底卷了啥?
参考视频:卷积神经网络(CNN)到底卷了啥?8分钟带你快速了解! 我们知道: 图片是由像素点构成,即最终的成像效果是由背后像素的颜色数值所决定 在Excel中:有这样一个由数值0和1组成的66…...
vue中v-clock指令
基础 v-cloak 是 Vue 中的一个非常实用的指令,用于防止在 Vue 实例尚未挂载完成前,用户看到模板中的插值语法(如 {{ message }})一闪而过。 ✅ 场景举例 你在页面还没加载完前,可能会看到这样一瞬间的内容ÿ…...

MIT 6.S081 2020Lab5 lazy page allocation 个人全流程
文章目录 零、写在前面一、Eliminate allocation from sbrk()1.1 说明1.2 实现 二、Lazy allocation2.1 说明2.2 实现 三、Lazytests and Usertests3.1 说明3.2 实现3.2.1 lazytests3.2.2 usertests 零、写在前面 可以阅读下4.6页面错误异常 像应用程序申请内存,内…...

C++初阶-list的使用2
目录 1.std::list::splice的使用 2.std::list::remove和std::list::remove_if的使用 2.1remove_if函数的简单介绍 基本用法 函数原型 使用函数对象作为谓词 使用普通函数作为谓词 注意事项 复杂对象示例 2.2remove与remove_if的简单使用 3.std::list::unique的使用 …...
PHP序列化数据格式详解
PHP序列化数据格式详解 概述 PHP序列化是将PHP变量(包括对象)转换为可存储或传输的字符串表示形式的过程。了解这些序列化格式对于数据处理、调试和安全性分析非常重要。本文将详细介绍PHP中各种数据类型的序列化表示方式。 基本数据类型序列化格式 …...

如何优化 MySQL 存储过程的性能?
文章目录 1. 优化 SQL 语句避免全表扫描减少子查询,改用 JOIN避免 SELECT 2. 合理使用索引3. 优化存储过程结构减少循环和临时变量避免重复计算 4. 使用临时表和缓存5. 优化事务处理6. 分析和监控性能7. 优化数据库配置8. 避免用户自定义函数(UDF&#…...
深度学习:损失函数与激活函数全解析
目录 深度学习中常见的损失函数和激活函数详解引言一、损失函数详解1.1 损失函数的作用与分类1.2 回归任务损失函数1.2.1 均方误差(MSE)1.2.2 平均绝对误差(MAE) 1.3 分类任务损失函数1.3.1 交叉熵损失(Cross-Entropy&…...
【大前端】Node Js下载文件
NodeJs 获取远程文件有很多方式,常见的方式有以下两种: - fetch(原生) - axios(插件) 通过 Fetch 下载文件,代码如下: import fs from node:fsfunction main(){fetch(http://xxx.x…...