美文网首页
Linux下的防火墙

Linux下的防火墙

作者: 攻城狮_正 | 来源:发表于2021-05-28 21:28 被阅读0次

使用过Linux系统的人对iptables一定不陌生,它是Linux从2.4.x版本内核开始,系统自带的防火墙。如今Linux内核已经更新至5.11.x版本,Linux的防火墙在iptables基础上泛生出UFW和Firewalld,并且在一些发行版中已经替代iptables。

Netfilter/Iptables

Netfilter/Iptables 是Linux系统自带的防火墙,Iptables管理规则,Netfilter是规则的执行者,它们一起组成Linux下包过滤防火墙。

iptables内置4个表,即filter表、nat表、mangle表和raw表,分别用于实现包过滤,网络地址转换、包重构(修改)和数据跟踪处理。每个表都会有相应的链。下图是iptables中的四表五链:

四表五链

链(chains)是数据包传播的路径。每一条链中可以有一条或多条规则,当一个数据包到达一个链时,iptables就会从链中第一条规则开始检查,看该数据包是否满足规则所定义的条件。如果满足,系统就会根据该条规则所定义的方法处理该数据包;否则iptables将继续检查下一条规则。如果该数据包不符合链中任一条规则,iptables就会根据该链预先定义的默认策略来处理数据包。

iptables传输数据包的过程

关于iptables的原理这篇文章讲得很清楚:https://blog.csdn.net/tennysonsky/article/details/44596515

在Linux中,可以使用如下命令启用或关闭iptables

// 启动iptables
systemctl start iptables

// 停止iptables
systemctl stop iptables

以下是常用命令:

// 列出 INPUT 表中规则
iptables -L INPUT

// 允许3306端口TCP协议访问
iptables -I INPUT -p tcp --dport 3306 -j ACCEPT

// 允许IP为xxx.xxx.xxx.xxx通过udp访问本地500端口
iptables -I INPUT -p udp --dport 500 -s xxx.xxx.xxx.xxx -j ACCEPT

// -I参数是将规则插入表开头,-A是把规则添加到表未尾,优先级最低,可做为默认规则
// 当不符合前面规则后拒绝所有请求
iptables -A INPUT -p tcp -j REJECT

// 删除INPUT表中第1条规则
iptables -D INPUT 1

// 清空规则列表
iptables -F

iptables还能做基于内核的包转发。关于iptables用法网上文章太多了,就不多写。

需要注意的是,iptables规则虽然能即时生效,但并未保存。开机后会丢失。

RedHat系执行保存:

service iptables save

Debian系执行 iptables-save 列出所有规则,输出到文件中保存。系统启动时用 iptables-restore 恢复。

// 保存
iptables-save > /etc/iptables.conf

// 恢复
iptables-restore < /etc/iptables.conf

UFW 和 Firewalld

iptables很强大也很复杂,于是便有UFW和Firewalld。它们的命令简单清晰很多,底层都是调用iptables。

  • UFW

UFW是Ubuntu下防火墙:

// 启动ufw
systemctl start ufw

// 停用ufw
systemctl stop ufw

以下是常用命令:

// 查询ufw开启状态,打印规则
ufw status

// 允许80端口访问
ufw allow 80

// 拒绝8000端口访问
ufw deny 9000

// 拒绝ip为xxx.xxx.xxx.xxx访问
ufw deny from xxx.xxx.xxx.xxx

// 允许通过tcp协议,9000-9002访问
ufw allow 9000:9002/tcp

// 删除规则
ufw delete allow http
  • Firewalld

Firewalld是Fedora/CentOS 8之后版本自带的防火墙:

// 启动firewalld
systemctl start firewalld

// 停用firewalld
systemctl stop firewalld

以下是常用命令:

// 允许tcp协议8161端口访问,--zone(作用域),--permanent(永久生效)
firewall-cmd --zone=public --add-port=8161/tcp --permanent

// 重新加载规则
firewall-cmd --reload

// 将80端口的流量转发至8080
firewall-cmd --add-forward-port=port=80:proto=tcp:toport=8080

// 将80端口的流量转发至192.168.0.1
firewall-cmd --add-forward-port=proto=80:proto=tcp:toaddr=192.168.1.0.1

// 将80端口的流量转发至192.168.0.1的8080端口
firewall-cmd --add-forward-port=proto=80:proto=tcp:toaddr=192.168.0.1:toport=8080

Firewalld也有图形界面:

firewalld

除非注明,否则均为"攻城狮·正"原创文章,请注明出处。

本文链接:https://engr-z.com/402.html

相关文章

  • firewalld 与 iptables

    不同Linux内核版本的防火墙软件 在设置 Linux 防火墙规则时,可以先用 uname -r 查看一下 Lin...

  • RHCE.2021.学习笔记.11篇

    Red Hat Enterprise Linux 下 firewalld 防火墙 当下的主流红帽系Linux版本是...

  • Linux防火墙(1)—— 防火墙分类

    文章摘自箫起秦楼的博客——Linux防火墙 Linux防火墙分类: ➢ 从逻辑上讲,防火墙分为:主机防火墙、网络防...

  • iptables

    1. 介绍 防火墙就是实现Linux下访问控制功能的,分为软件防火墙和硬件防火墙两种。我们需要得定义防火墙的规则和...

  • CentOS 防火墙配置与REJECT导致没有生效问题

    在Linux系统中我们一般情况下都会设置防火墙,通过防火墙进行拦截和开放一下端口。基于CentOS进行配置防火墙和...

  • VPS & iptables

    最近搞了个VPS玩,学一下Linux。想着设置一下防火墙,emm……先把本机的防火墙规则清一下。 iptables...

  • SuSE Linux防火墙配置

    SuSE Linux防火墙配置 SuSE Linux防火墙配置文件路径:/etc/sysconfig/SuSEfi...

  • Linux防火墙软件iptables

    本文旨在简单介绍Linux下防火墙软件iptables的使用及相关知识。 1. Netfilter 一般依据防火墙...

  • 防火墙及NAT服务

    一、简介 1. 关于防火墙 防火墙,其实就是用于实现Linux下访问控制的功能的,它分为硬件和软件防火墙两种。无论...

  • iptables 详解

    和window系统的防火墙一样,Linux也是有防火墙的。 如果你搜索【Linux防火墙】: 就会发现,大家都在教...

网友评论

      本文标题:Linux下的防火墙

      本文链接:https://www.haomeiwen.com/subject/ealesltx.html