防火墙----iptables

devtools/2024/11/17 18:11:47/

防火墙是位于内部网和外部网之间的屏障,他按照系统管理员预先定义好的规则来控制数据包的进出

一、iptables简介

防火墙会从以上至下的顺序来读取配置的策略规则,在找到匹配项后就立即结束匹配工作并去执行匹配项中定义的行为(即放行或阻止)。如果在读取完所有的策略规则之后没有匹配项,就去执行默认的策略。
iptables 服务把用于处理或过滤流量的策略条目称之为规则,多条规则可以组成一个规则链,而规则链则依据数据包处理位置的不同进行分类。
1、规则链
  • 规则的作用:对数据包进行过滤或处理
  • 链的作用:容纳各种防火墙规则
  • 链的分类依据:处理数据包的不同时机

5种规则链

  • INPUT:处理进入本机的数据包
  • OUTPUT:处理从本机出去的数据包
  • FORWARD:处理转发数据包
  • POSTROUTING链:在进行路由选择后处理数据包
  • PREROUTING链:在进行路由选择前处理数据包
2、规则表
  • 表的作用:容纳各种规则链
  • 表的划分依据:防火墙规则的作用相似

4个规则表

  • raw表:确定是否对该数据包进行状态跟踪
  • mangle表:为数据包设置标记(修改数据包的头部信,拆解报文,做出修改,并重新封装)
  • nat:用于网络地址转换,修改数据包中的源、目标IP地址或端口
  • filter表:确定是否放行该数据包(过滤),iptables的默认表

 

四表五链总结:最终定义防火墙规则,都会添加规则到其中一张表,所以实际操作是对表的操作 

 规则表的作用∶容纳各种规则链

规则链的作用∶容纳各种防火墙规则

表里有链,链里有规则

 

 3、规则链之间的匹配顺序:
  • 入站数据(来自外界的数据包,且目标地址是防火墙本机)∶ PREROUTING --> INPUT --> 本机的应用程序
  • 出站数据(从防火墙本机向外部地址发送的数据包)∶ 本机的应用程序 --> OUTPUT --> POSTROUTING网络型防火墙∶
  • 转发数据(需要经过防火墙转发的数据包)∶ PREROUTING --> FORWARD --> POSTROUTING
4、规则链内的匹配顺序
  • 自上向下按顺序依次进行检查,找到相匹配的规则即停 止 (LoG策略例外, 表示记录相关日志)
  • 若在该链内找不到相匹配的规则,则按该链的默认策略处理(未修改的状况下,默认策略为允许)

 

 

5.iptables的处理动作 
  • 当规则链匹配后应采用以下几种动作来处理匹配流量:
  • ACCEPT:允许流量通过
  • REJECT:拒绝流量通过,拒绝后回复拒绝信息
  • LOG:记录日志信息
  • DROP:拒绝流量通过,流量丢弃不响应

二、iptables的配置 

rhel默认使用firewalld防火墙,没有安装iptables, 若想使用iptables防火墙。必须先关闭firewalld防火墙,再安装iptables。

1.准备工作
[root@server ~]# systemctl disable firewalld.service 
[root@server ~]# systemctl mask firewalld.service [root@server ~]# yum install iptables  iptables-services -y
[root@client ~]# systemctl start iptables.service
2.iptables格式
iptables -t 表名 <-A/I/D/R> 规则链名 [ 规则号 ] <-i/o 网卡名 > -p 协议名 <-s IP/ 源子网 >
--sport 源端口 <-d 目标 IP/ 目标子网 > --dport 目标端口 -j 控制动作
-t    对指定的表进行操作, table 必须是 raw nat filter mangle 中的一个,默认是 filter
-A  在规则链的末尾加入新规则
-I  在规则链的 头部 加入新规则
-D  删除指定规则
-R  替换/ 修改第几条规则
-F   清空所有规则(F:flush 冲洗、冲掉 的意思 )
-p   指定要匹配的数据包协议类型,例如TCP、UDP、ICMP等,参看: /etc/protocols
-s   匹配源地址IP/MASK ,若有!表示取反
-d   匹配目的地址IP/MASK
3.控制动作: 
选项用法
ACCEPT允许数据包通过
DROP直接丢弃数据包,不给出任何回 应信息
REJECT拒绝数据包通过,必要时会给数据发送端一个响应信息
4. 示例:
查看已有的防火墙规则链:
[root@server ~] # iptables -nvxL --line
# -n 显示源 -v 详细信息 -x 自动转换为 KB\MB 等单位 -L 写在最后列出所有规则 --line 增加行
# num :规则的编号(行号)
# pkts :数据包的数量
# bytes :数据包的字节数
# target :动作(放行、拒绝)
# port :端口
# in :入站的网卡
# out :出站网卡
清空规则:
[root@server ~] # iptables -F # 清空规则
[root@server ~] # iptables -nL # 查看规则链
[root@server ~] # systemctl restart iptables
[root@server ~] # iptables -nL # 由于未保存,则恢复原状
[root@server ~] # iptables -F # 再次尝试清空规则链
[root@server ~] # service iptables save # 保存服务状态
iptables: Saving firewall rules to /etc/sysconfig/iptables: [ OK ]
[root@server ~] # systemctl restart iptables # 重启服务
[root@server ~] # iptables -nL # 查看

三、iptables实验 

1.搭建web服务器,设置任何人都能通过80端口访问http

2.禁止所有人使用ssh进行远程登录

3.禁止某主机(192.168.48.131 ssh远程登录,允许访问web服务

测试: 允许访问web页面: 

4.禁止192.168.48.131 网段的地址进行ping


http://www.ppmy.cn/devtools/134754.html

相关文章

POI和easyExcel的讲解和使用

目录 应用场景&#xff1a; Apache POI&#xff1a; EasyExcel&#xff1a; POI具体实现&#xff1a; POI-Excel 写&#xff1a; POI-Excel 读&#xff1a; 大文件写HSSF&#xff1a; 大文件写XSSF&#xff1a; 大文件写SXSSF&#xff1a; EasyExcel&#xff1a; 导…

Python练习19

Python日常练习 题目&#xff1a; 打印如下九九乘法表 1*11 2*12 2*24 3*13 3*26 3*39 4*14 4*28 4*312 4*416 5*15 5*210 5*315 5*420 5*525 6*16 6*212 6*318 6*424 6*530 6*636 7*17 7*214 7*321 7*428 7*535 7*642 7*749 8*18 8*216 8*324 8*432 8*540 8*648 8*756 8*86…

c# 调用c++ 的dll 出现找不到函数入口点

今天在调用一个设备的dll文件时遇到了一点波折&#xff0c;因为多c 不熟悉&#xff0c;调用过程张出现了找不到函数入口点&#xff0c;一般我们使用c# 调用c 文件&#xff0c;还是比较简单。 [DllImport("AtnDll2.dll",CharSet CharSet.Ansi)]public static extern …

k8s更新

k8s更新 1.30 升级了 Metrics Server 到 v0.7.0 kubectl get cronjob命令增加了时区列显示 kubectl describe命令在描述VolumeAttributesClass、作业、Pod 模板等时提供了更多信息&#xff0c;有助于深入排查问题。 改进了kubectl logs命令&#xff0c;当 Pod 未找到时会显示所…

【HarmonyOS NEXT】实战——登录页面

【HarmonyOS NEXT】实战——登录页面 在本文中&#xff0c;我们将深入探讨如何使用HarmonyOS NEXT来实现一个功能完备的登录页面。通过这个实战案例&#xff0c;你将结合页面布局、数据本地化存储、网络请求等多方面了解到HarmonyOS NEXT在构建现代应用时的强大能力和灵活性。…

蓝桥杯备考——算法

一、排序 冒泡排序、选择排序、插入排序、 快速排序、归并排序、桶排序 二、枚举 三、二分查找与二分答案 四、搜索&#xff08;DFS&#xff09; DFS&#xff08;DFS基础、回溯、剪枝、记忆化&#xff09; 1.DFS算法&#xff08;深度优先搜索算法&#xff09; 深度优先搜…

Go语言数组初始化:默认、全部、部分

在Go语言中&#xff0c;数组是一种固定长度的序列&#xff0c;一旦声明&#xff0c;其长度不能改变。数组的初始化是编程中常见的操作&#xff0c;Go提供了多种方式来初始化数组&#xff0c;包括默认初始化、全部初始化和部分初始化。本文将详细介绍这三种初始化方式&#xff0…

【计网不挂科】计算机网络第三章< 数据链路层 >习题库(含答案)

前言 大家好吖&#xff0c;欢迎来到 YY 滴计算机网络 系列 &#xff0c;热烈欢迎&#xff01; 本章主要内容面向接触过C的老铁 本博客主要内容&#xff0c;收纳了一部门基本的计算机网络题目&#xff0c;供yy应对期中考试复习。大家可以参考 本章为分章节的习题内容题库&#x…