首页 游戏 软件 资讯 排行榜 专题
首页
编程语言
centos防火墙如何兼容其他服务

centos防火墙如何兼容其他服务

热心网友
26
转载
2026-05-05

CentOS 7防火墙配置核心思路

在CentOS 7及更高版本的Linux系统中,构建一套安全高效的防火墙策略,通常以firewalld动态防火墙管理器为核心进行部署。其核心在于灵活运用系统提供的五大功能模块:区域(zones)预定义服务端口与协议管理富规则(rich rules)以及ipset集合。通过这套组合策略,可以为SSH远程登录、Web服务器、数据库以及文件共享等常见业务服务,提供既严密可控又便于运维的访问控制方案。当然,系统安全需要纵深防御,建议将firewalld与fail2ban入侵防御、SELinux安全模块以及系统日志审计进行联动,从而初步构建一个覆盖“实时监控”、“自动拦截”和“行为审计”的立体安全防护体系。

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

Firewalld常见服务端口开放配置指南

服务名称 默认端口/协议 安全配置建议 Firewalld命令示例
SSH远程管理 22/tcp 强烈建议使用富规则限制来源IP地址;非必要不长期开放,仅在维护时段临时放通特定管理网段。 firewall-cmd --permanent --zone=public --add-rich-rule='rule family="ipv4" source address="203.0.113.10" port port="22" protocol="tcp" accept' && firewall-cmd --reload
Web服务(HTTP/HTTPS) 80/tcp、443/tcp 直接使用预定义的http和https服务最为便捷安全。 firewall-cmd --permanent --zone=public --add-service=http --add-service=https && firewall-cmd --reload
MySQL/MariaDB数据库 3306/tcp 数据库服务应严格限定在内网或指定的管理网络访问,避免暴露在公网。 firewall-cmd --permanent --zone=internal --add-port=3306/tcp && firewall-cmd --reload
DNS域名解析 53/tcp、53/udp 直接使用预定义的dns服务。 firewall-cmd --permanent --zone=public --add-service=dns && firewall-cmd --reload
FTP文件传输 21/tcp + 被动端口范围 需同时放行控制端口和指定的被动模式端口范围(如30000-31000)。 firewall-cmd --permanent --zone=public --add-service=ftp && firewall-cmd --permanent --add-port=30000-31000/tcp && firewall-cmd --reload
邮件服务(SMTP/POP3/IMAP) 25/tcp、110/tcp、143/tcp 使用对应的预定义服务简化配置。 firewall-cmd --permanent --zone=public --add-service=smtp --add-service=pop3 --add-service=imap && firewall-cmd --reload
NFS网络文件系统 2049/tcp + rpc-bind + mountd 需要同时放行NFS服务及其相关的RPC服务(rpc-bind, mountd)。 firewall-cmd --permanent --zone=public --add-service=nfs --add-service=rpc-bind --add-service=mountd && firewall-cmd --reload
Samba文件共享 137-139/tcp、445/tcp 使用预定义的samba服务。 firewall-cmd --permanent --zone=public --add-service=samba && firewall-cmd --reload
DHCP动态主机配置 67/udp、68/udp 使用预定义的dhcp服务。 firewall-cmd --permanent --zone=public --add-service=dhcp && firewall-cmd --reload
自定义应用(如Tomcat) 8080/tcp 可直接放行端口,或创建自定义服务XML文件以便于复用和管理。 firewall-cmd --permanent --zone=public --add-port=8080/tcp && firewall-cmd --reload
重要说明:系统预定义的服务配置文件位于/usr/lib/firewalld/services/目录。你也可以在/etc/firewalld/services/目录下创建自定义服务文件,实现对复杂规则集的封装与复用,提升配置管理效率。

Firewalld与自动化工具及安全组件联动配置

  • 与Fail2ban联动防御:利用firewalld的ipset功能来承载Fail2ban的封禁动作,效率更高,能有效避免因大量封禁IP导致防火墙规则表膨胀。配置示例(在/etc/fail2ban/jail.d/jail.local中):于[DEFAULT]段设置banaction=firewallcmd-ipset;并启用[sshd]段,设置enabled=true port=22。启动后,若需解封特定IP,可使用命令fail2ban-client set sshd unbanip 1.2.3.4

  • 与SELinux协同工作:建议保持SELinux处于强制(Enforcing)模式。当需要为服务(如Nginx、Apache)新增非标准端口时,务必使用semanage port命令为端口绑定正确的安全上下文(例如:semanage port -a -t http_port_t -p tcp 8080),以免网络流量被SELinux策略拒绝。联合排查网络连接问题时,应同时查看/var/log/audit/audit.log和防火墙日志。

  • 日志记录与安全审计:启用防火墙拒绝连接日志记录是一个好习惯,命令为firewall-cmd --permanent --set-log-denied=all && firewall-cmd --reload。运维中可实时观察防火墙日志:journalctl -u firewalld -f。对于企业生产环境,建议将这些安全日志接入rsyslog、ELK Stack或Splunk等日志管理平台,进行集中分析、存储和告警。

Firewalld运维管理与安全变更最佳实践

  • 理解“运行时”与“持久化”策略:所有带--permanent参数的规则修改,必须执行firewall-cmd --reload命令后才会永久生效并立即应用。进行任何防火墙变更前,务必备份现有规则;变更后,应在测试环境充分验证。整个过程,需始终遵循“最小权限”和“最小暴露面”核心安全原则。

  • 善用原生功能,降低管理复杂度:优先使用firewalld自带的区域划分、富规则条件匹配、ipset批量管理等功能来实现访问控制逻辑。这能最大程度减少直接操作底层iptables或nftables规则的复杂度与出错风险。对于关键业务端口和服务,设置合理的来源IP白名单与连接速率限制,是避免误封、保障业务高可用性的关键措施。

来源:https://www.yisu.com/ask/7432840.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

CentOS中Node.js错误如何调试
编程语言
CentOS中Node.js错误如何调试

在CentOS系统中调试Node js错误,可以采用以下方法 遇到Node js应用报错,别急着重启服务。先稳住,系统性地排查,往往能更快定位问题根源。下面这几种方法,从基础到进阶,总有一款适合你。 1 查看日志文件 这是最直接的第一步。Node js应用运行时,错误信息通常会实时输出到控制台。所

热心网友
05.05
CentOS如何配置Python自动化任务
编程语言
CentOS如何配置Python自动化任务

在CentOS上配置Python自动化任务 你是否需要在CentOS服务器上部署一个稳定、高效的Python自动化任务?无论是数据同步、日志清理还是系统监控,通过Python脚本结合Linux定时任务都能轻松实现。本文将为你提供一份从环境准备到任务部署的完整CentOS Python自动化配置指南,

热心网友
05.05
CentOS如何配置Python依赖管理
编程语言
CentOS如何配置Python依赖管理

在CentOS系统中高效管理Python依赖,构建一个独立、清晰的环境至关重要。这不仅能够有效防止不同项目间的包版本冲突,还能显著简化部署流程与团队协作。本文将详细介绍一套基于pip与virtualenv的标准化操作流程,这是在Linux服务器上进行Python项目依赖管理的成熟方案。 1 安装P

热心网友
05.05
Python在CentOS怎样配置错误处理
编程语言
Python在CentOS怎样配置错误处理

在CentOS上配置Python错误处理:构建稳定应用的完整指南 在CentOS服务器环境中部署Python应用程序时,建立一套完善的错误处理机制至关重要。这不仅是系统稳定运行的“安全网”,更是快速定位和解决问题的“导航仪”。合理的错误配置能够将故障排查时间缩短数倍,避免小问题演变为服务中断。 本文

热心网友
05.05
CentOS如何配置Python内存限制
编程语言
CentOS如何配置Python内存限制

在CentOS系统中为Python应用配置内存限制 在CentOS服务器上运行Python应用时,有效管理内存使用是保障系统稳定性和应用性能的关键。通常需要从操作系统和应用程序两个层面协同配置,才能从根本上预防内存溢出(OOM)问题,实现资源的精细化管控。 操作系统级别的内存限制 首先,从系统层面入

热心网友
05.05

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

怎样用telnet管理网络设备
编程语言
怎样用telnet管理网络设备

使用Telnet管理网络设备:一份实用指南 在网络设备管理的众多工具中,Telnet堪称一位“资深元老”。它以简洁、直接的方式,让管理员能够从远程便捷地登录路由器或交换机的命令行界面。然而,必须首先明确一个关键点:Telnet协议本身缺乏安全保障,其传输的所有数据,包括用户名和密码,均以明文形式进行

热心网友
05.05
如何用telnet调试网络应用
编程语言
如何用telnet调试网络应用

使用Telnet调试网络应用:快速定位连接与协议问题 在网络应用开发与日常运维中,高效排查故障是必备技能。Telnet作为经典的网络协议工具,凭借其简洁的命令行交互方式,至今仍是测试端口连通性、验证服务响应及手动调试文本协议的实用选择。它无需图形界面,直接通过命令行揭示网络层的真实状态,是工程师手中

热心网友
05.05
如何利用cpustat进行系统监控
编程语言
如何利用cpustat进行系统监控

全面掌握系统性能:使用 cpustat 工具进行专业级 CPU 监控 在 Linux 系统性能优化与故障诊断过程中,CPU 使用率是至关重要的核心指标。作为 sysstat 工具集的重要组成部分,cpustat 命令为系统管理员和开发者提供了一种直接、高效且深入的 CPU 监控解决方案。本文将详细介

热心网友
05.05
cpustat如何辅助进行性能调优
编程语言
cpustat如何辅助进行性能调优

掌握cpustat:Linux系统性能监控与CPU调优的必备工具 在Linux服务器性能优化与故障排查过程中,CPU资源的使用状况通常是首要分析目标。除了广为人知的top和htop命令,cpustat是一款同样强大却常被忽略的专业级CPU监控利器。作为sysstat工具集的核心组件之一,它能够实时采

热心网友
05.05
如何用cpustat查看进程CPU使用情况
编程语言
如何用cpustat查看进程CPU使用情况

使用 cpustat 监控进程 CPU 使用情况 在 Linux 系统性能调优与故障排查过程中,精准监控 CPU 使用率是至关重要的基础技能。cpustat 作为 sysstat 工具集的核心组件之一,专门为深入洞察 CPU 资源分配与消耗而设计。它提供了超越常规系统监控命令的、聚焦于处理器性能的详

热心网友
05.05