首页 > 运维 > linux运维 > 正文

Linux如何限制指定IP的访问

P粉602998670
发布: 2025-09-02 11:04:02
原创
737人浏览过
答案:Linux中限制IP访问主要通过iptables、firewalld和tcpwrappers实现;iptables使用DROP或REJECT规则禁止或允许IP访问,需注意规则顺序并保存配置;firewalld利用rich规则动态控制IP和服务访问,需重载生效;tcpwrappers通过/etc/hosts.allow和/etc/hosts.deny文件限制支持的服务;选择方法应根据系统环境和服务类型决定。

linux如何限制指定ip的访问

在Linux系统中限制指定IP的访问,主要通过防火墙工具实现,最常用的是iptablesfirewalld。下面介绍几种常用方法,帮助你快速配置IP访问限制。

使用 iptables 限制IP访问

iptables 是Linux内核自带的防火墙工具,功能强大且广泛支持。

禁止某个IP访问本机:

iptables -A INPUT -s 192.168.1.100 -j DROP

这条命令会阻止来自 192.168.1.100 的所有连接。

允许某个IP访问,拒绝其他所有:

iptables -A INPUT -s 192.168.1.100 -j ACCEPT
iptables -A INPUT -j DROP

注意规则顺序:允许的规则必须在拒绝规则之前。

限制特定端口的访问:

iptables -A INPUT -s 192.168.1.100 -p tcp --dport 22 -j DROP

这条命令阻止指定IP访问SSH服务(端口22)。

配置完成后,保存规则防止重启失效:

service iptables save

(部分系统需安装 iptables-services 包)

使用 firewalld 限制IP访问(CentOS/RHEL/Fedora)

firewalld 是现代Red Hat系列默认的防火墙管理工具,支持动态配置。

拒绝某个IP:

firewall-cmd --permanent --add-rich-rule='rule family="ipv4" source address="192.168.1.100" reject'

使用 reject 会返回拒绝信息,也可用 drop 表示静默丢包。

问问小宇宙
问问小宇宙

问问小宇宙是小宇宙团队出品的播客AI检索工具

问问小宇宙 77
查看详情 问问小宇宙

仅允许某个IP访问特定服务:

firewall-cmd --permanent --add-rich-rule='rule family="ipv4" source address="192.168.1.100" service name="ssh" accept'
firewall-cmd --permanent --remove-service=ssh

先移除全局SSH服务,再为特定IP单独开放。

重新加载配置:

firewall-cmd --reload

使用 /etc/hosts.deny 和 /etc/hosts.allow(仅适用于支持tcpwrappers的服务)

某些服务(如sshd、vsftpd)支持tcpwrappers机制,可通过配置文件控制访问。

编辑 /etc/hosts.deny 文件,禁止某个IP:

sshd: 192.168.1.100

编辑 /etc/hosts.allow 文件,白名单优先:

sshd: 192.168.1.50

allow 文件中的规则优先于 deny。

验证与管理

查看当前iptables规则:

iptables -L -n -v

查看firewalld富规则:

firewall-cmd --list-rich-rules

测试限制是否生效,可从目标IP使用ping、telnet或ssh尝试连接。

基本上就这些。选择哪种方式取决于你的系统环境和服务类型。iptables最通用,firewalld更适合现代Red Hat系,tcpwrappers适合特定服务。配置时注意规则顺序和保存,避免被锁在服务器外。

以上就是Linux如何限制指定IP的访问的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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