0

0

Linux服务暴露风险控制_最小开放原则说明【指导】

舞夢輝影

舞夢輝影

发布时间:2026-01-06 11:03:08

|

520人浏览过

|

来源于php中文网

原创

Linux服务暴露风险的核心在于默认不开放端口、按需显式开启必要服务;盲目监听0.0.0.0等于暴露钥匙;应确认服务绑定127.0.0.1,用ss -tlnp检查,修改bind配置,强化防火墙策略,默认DROP并精确放行,结合systemd依赖控制与socket禁用,落实最小开放原则。

linux服务暴露风险控制_最小开放原则说明【指导】

Linux服务暴露风险的核心在于:默认不开放任何端口,只按需显式开启必要服务。盲目启用 sshdhttpdmysqld 且监听 0.0.0.0,等于把钥匙挂在门口。

确认服务监听地址是否为 127.0.0.1

很多服务(如 redis-serverpostgresql)默认监听 127.0.0.1,这是安全基线。一旦改配成 0.0.0.0 或空绑定,就可能被外部访问。

检查方法:

ss -tlnp | grep ':端口号'

关键看第二列(Local Address:Port)是否含 127.0.0.1;若显示 *:220.0.0.0:3306,说明已全网暴露。

  • 修改 /etc/redis/redis.conf 中的 bind 行为 bind 127.0.0.1(禁用 bind 0.0.0.0
  • PostgreSQL 需同步调整 postgresql.conflisten_addressespg_hba.conf 的访问控制行
  • 某些服务(如 dockerd)默认监听 unix:///var/run/docker.sock,但若配置了 -H tcp://0.0.0.0:2375,则直接暴露容器管理接口

防火墙必须作为第二道防线

即使服务配置为本地监听,内核路由或容器网络可能绕过该限制。因此 iptablesnftables 不是可选项,而是强制兜底手段。

Clay AI
Clay AI

Clay AI 是一款可以将人物照片转换为粘土风格图像的AI工具,Clay AI:利用粘土动画让角色栩栩如生

下载

典型策略:

  • 默认策略设为 DROPiptables -P INPUT DROP
  • 仅放行明确需要的端口,例如仅允许 SSH 从指定 IP 段接入:iptables -A INPUT -s 192.168.10.0/24 -p tcp --dport 22 -j ACCEPT
  • 禁止所有对 3306637927017 等数据库端口的外部连接,除非有反向代理或跳板机场景
  • 使用 ufw 时,避免执行 ufw allow 22 这类无源限制的命令;应写成 ufw allow from 10.0.5.0/24 to any port 22

systemd 服务的 BindTo + BindsTo 容易被忽略

有些服务依赖其他组件(如 nginx 依赖 openssl 或上游 API),但 systemd 默认不校验依赖链是否完整。结果是服务启动了,但实际功能不可用,管理员误以为“开了就行”,反而放松了网络侧防护。

正确做法:

  • /etc/systemd/system/myservice.service 中添加:BindTo=network.targetAfter=network.target,确保网络就绪后再启动
  • 若服务必须配合防火墙规则生效,可增加 ExecStartPre=/usr/bin/iptables -C INPUT -p tcp --dport 80 -j ACCEPT 2>/dev/null || /usr/bin/iptables -I INPUT -p tcp --dport 80 -j ACCEPT
  • 禁用非必要 socket 激活:systemctl disable myservice.socket,防止未预期的 socket 触发服务启动

最小开放原则不是“少开几个端口”,而是每次开放都伴随明确的访问来源、协议版本、TLS 强制要求和日志审计能力。最常被绕过的点是:容器内部服务监听 0.0.0.0docker-compose.yml 中漏写 extra_hosts 导致回环调用走外网、以及云平台安全组与主机防火墙策略冲突。

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

229

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

493

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

498

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

226

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

330

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3505

2024.08.07

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

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

231

2023.09.22

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

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

435

2024.03.01

PPT动态图表制作教程大全
PPT动态图表制作教程大全

本专题整合了PPT动态图表制作相关教程,阅读专题下面的文章了解更多详细内容。

13

2026.01.07

热门下载

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

精品课程

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

共48课时 | 1.6万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 783人学习

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

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