网络安全 | F5 WAF 黑白名单配置实践指南
关注:CodingTechWork
引言
在现代网络安全架构中,F5 Web Application Firewall (WAF) 是保护 Web 应用免受攻击的重要工具。F5 WAF 提供了强大的黑白名单功能,结合 Data Group 和 iRules,可以实现更灵活、更高效的流量控制策略。本文将详细介绍如何利用 F5 官方功能,结合 Data Group 和 iRules 配置黑白名单。
F5 WAF 黑白名单功能概述
F5 WAF 的黑白名单功能允许管理员根据 IP 地址、URL 或其他条件对流量进行分类和控制。通过将特定的 IP 地址或子网添加到白名单中,可以确保这些流量不会被误拦截;而将已知的恶意 IP 地址添加到黑名单中,则可以有效阻止这些流量。
Data Group 的创建与管理
Data Group 是 F5 提供的一种数据管理工具,用于存储一组相关的数据元素(如 IP 地址、字符串等)。通过 Data Group,可以方便地在 iRules 中引用这些数据,从而简化规则的编写。
iRules 的编写与应用
iRules 是 F5 提供的一种基于 TCL 语言的脚本工具,用于自定义流量处理逻辑。通过 iRules,可以实现复杂的流量控制策略。
白名单配置
创建 Data Group
- 登录 F5 BIG-IP 设备:使用管理员账户登录到 F5 BIG-IP 设备的管理界面。
- 导航到 Data Group:
- 在 Web 界面中,依次点击 Local Traffic > iRules > Data Group Lists。
- 创建 Data Group:
- 点击 Create 按钮,创建一个新的 Data Group。
- 名称:为 Data Group 设置一个易于识别的名称,例如
whitelist_ips。 - 类型:选择
address类型(用于存储 IP 地址)。 - 添加条目:输入需要加入白名单的 IP 地址或子网,例如
192.168.1.0/24。
创建 iRules
- 登录 F5 BIG-IP 设备:使用管理员账户登录到 F5 BIG-IP 设备的管理界面。
- 导航到 iRules:
- 在 Web 界面中,依次点击 Local Traffic > iRules。
- 创建 iRules:
- 点击 Create 按钮,创建一个新的 iRule。
- 名称:为 iRule 设置一个易于识别的名称,例如
whitelist_rule。 - 内容:编写 iRule 脚本,使用
class match命令引用 Data Group。
以下是一个简单的 iRule 示例,用于检查客户端 IP 是否在白名单中:
when CLIENT_ACCEPTED {if { [class match [IP::remote_addr] equals whitelist_ips] } {# 如果 IP 在白名单中,允许访问pool whitelist_pool} else {# 如果 IP 不在白名单中,拒绝访问drop}
}
应用 iRules 到虚拟服务器
-
导航到虚拟服务器:
- 在 F5 管理界面中,导航到 Local Traffic > Virtual Servers > Virtual Server List。
- 选择需要应用黑名单规则的虚拟服务器。
-
添加 iRules:
- 在虚拟服务器的 Resources > iRules 部分,点击 Manage。
- 在弹出的窗口中,选择刚刚创建的
whitelist_rule,然后点击 Add。
白名单配置流程
- 创建 Data Group:
- 创建一个名为
whitelist_ips的 Data Group,类型为address,并添加需要白名单的 IP 地址或子网。
- 创建一个名为
- 创建 iRule:
- 编写 iRule 脚本,使用
class match命令检查客户端 IP 是否在whitelist_ips中。 - 如果客户端 IP 在白名单中,允许访问;否则,拒绝访问。
- 编写 iRule 脚本,使用
- 应用 iRule:
- 将创建的 iRule 应用到相应的虚拟服务器(Virtual Server)上。
黑名单配置
创建 Data Group
Data Group 是 F5 BIG-IP 中用于存储一组数据(如 IP 地址、字符串等)的工具,可以在 iRules 中方便地引用这些数据。
-
登录 F5 BIG-IP 设备:
- 使用管理员账户登录到 F5 BIG-IP 设备的管理界面。
-
创建 Data Group:
- 导航到 Local Traffic > iRules > Data Group Lists。
- 点击 Create 按钮,创建一个新的 Data Group。
- 名称:输入一个易于识别的名称,例如
blacklist_ips。 - 类型:选择
address类型(用于存储 IP 地址)。 - 添加条目:输入需要加入黑名单的 IP 地址或子网,例如
192.168.1.0/24。
创建 iRules
-
登录 F5 BIG-IP 设备:
- 使用管理员账户登录到 F5 BIG-IP 设备的管理界面。
-
创建 iRules:
- 导航到 Local Traffic > iRules。
- 点击 Create 按钮,创建一个新的 iRule。
- 名称:输入一个易于识别的名称,例如
blacklist_rule。 - 内容:编写 iRule 脚本,使用
class match命令引用 Data Group。
以下是一个简单的 iRule 示例,用于检查客户端 IP 是否在黑名单中:
when CLIENT_ACCEPTED {if { [class match [IP::client_addr] equals blacklist_ips] } {# 如果 IP 在黑名单中,拒绝访问log local0. "Dropped connection from [IP::client_addr]: IP is blacklisted."drop}
}
应用 iRules 到虚拟服务器
-
导航到虚拟服务器:
- 在 F5 管理界面中,导航到 Local Traffic > Virtual Servers > Virtual Server List。
- 选择需要应用黑名单规则的虚拟服务器。
-
添加 iRules:
- 在虚拟服务器的 Resources > iRules 部分,点击 Manage。
- 在弹出的窗口中,选择刚刚创建的
blacklist_rule,然后点击 Add。
黑名单配置流程
- 创建 Data Group:
- 创建一个名为
blacklist_ips的 Data Group,类型为address,并添加需要白名单的 IP 地址或子网。
- 创建一个名为
- 创建 iRule:
- 编写 iRule 脚本,使用
class match命令检查客户端 IP 是否在blacklist_ips中。 - 如果客户端 IP 在白名单中,允许访问;否则,拒绝访问。
- 编写 iRule 脚本,使用
- 应用 iRule:
- 将创建的 iRule 应用到相应的虚拟服务器(Virtual Server)上。
注意事项
- 性能优化:合理配置 Data Group 和 iRules,避免过多的匹配操作影响性能。
- 定期更新:根据实际情况定期更新 Data Group 中的 IP 地址,确保黑白名单的有效性。
- 测试验证:在生产环境中应用新的规则之前,建议在测试环境中进行充分的测试,以确保规则的正确性和稳定性。
总结
通过结合 Data Group 和 iRules,F5 WAF 的黑白名单功能可以实现更灵活、更高效的流量控制策略。合理使用这些工具,不仅可以提高系统的安全性,还可以优化性能,确保业务的平稳运行。
相关文章:
网络安全 | F5 WAF 黑白名单配置实践指南
关注:CodingTechWork 引言 在现代网络安全架构中,F5 Web Application Firewall (WAF) 是保护 Web 应用免受攻击的重要工具。F5 WAF 提供了强大的黑白名单功能,结合 Data Group 和 iRules,可以实现更灵活、更高效的流量控制策略。…...
焊接机排错
焊接机 一、前定位后焊接 两个机台,①极柱定位,相机定位所有极柱点和mark点;②焊接机,相机定位mark点原理:极柱定位在成功定位到所有极柱点和mark点后,可以建立mark点和极柱点的关系。焊接机定位到mark点…...
【AI提示词】艺人顾问
提示说明 专业艺人顾问,专注于为客户提供全面的艺术、娱乐和商业咨询服务,帮助他们在竞争激烈的行业中树立品牌影响力,提升市场竞争力 提示词 # Role: 艺人顾问## Profile - language: 中文 - description: 专业艺人顾问,专注于…...
MyBatis操作数据库---从入门到理解
文章目录 关于MyBatis操作数据库MyBatis⼊⻔(使用)Mybatis操作数据库的步骤:配置数据库连接字符串使⽤MyBatis完成简单的增删改查操作注解xml 单元测试开启驼峰命名(推荐) 打印日志 关于MyBatis操作数据库 在之前的学习,我们了解到web应⽤程…...
本地缓存大杀器-Caffeine
本地缓存大杀器-Caffeine 一、 背景二、 应用三、 实现原理四、 核心设计五、 总结 一、 背景 1、 本地缓存作为一种高效的缓存方式,能够显著减少对远程数据源的访问,从而快速响应请求。而在众多本地缓存工具中,Caffine 凭借其卓越的性能和丰…...
【HFP】蓝牙语音通话控制深度解析:来电拒接与通话终止协议
目录 一、来电拒接的核心流程与信令交互 1.1 拒接场景的分类与触发条件 1.2 HF 端拒接流程 1.3 AG 端拒接流程 二、通话终止流程:主动断开与异常中断 2.1 终止场景的界定 2.2 HF 端终止流程 2.3 AG 端终止流程 三、信令协议的核心要素:AT 命令与…...
使用QML Tumbler 实现时间日期选择器
目录 引言相关阅读项目结构示例实现与代码解析示例一:时间选择器(TimePicker)示例二:日期时间选择器(DateTimePicker) 主窗口整合运行效果总结下载链接 引言 在现代应用程序开发中,时间与日期选…...
智能吸顶灯/摄影补光灯专用!FP7195双通道LED驱动,高效节能省空间 !
一、双路调光技术背景与市场需求 随着LED照明技术的快速发展和智能照明需求的激增,双路调光技术正成为照明行业的重要发展方向。传统单路调光方案只能实现整体亮度的统一调节,而双路调光则能够实现对两个独立通道的精确控制。今天,由我来为大…...
如何解决PyQt从主窗口打开新窗口时出现闪退的问题
在PyQt5中,当从主窗口打开新窗口时,经常会出现闪退现象,这通常是由于对象生命周期管理不当或事件循环错误等所导致。 1. 确保新窗口实例被正确引用 新窗口的实例若未被主窗口引用,可能会被Python的垃圾回收机制销毁。 错误示例&…...
分布式微服务架构,数据库连接池设计策略
在分布式微服务架构中,数据库连接池的设计远比单体应用复杂,涉及资源隔离、连接管理、性能调优和高可用等问题。下面是面向专业软件架构师的系统化分析与策略建议: 一、核心挑战 每个服务独立运行,连接池分散 每个微服务维护自己的…...
YOLOv11改进-双Backbone架构:利用双backbone提高yolo11目标检测的精度
一、引言:为什么我们需要双Backbone? 在目标检测任务中,YOLO系列模型因其高效的端到端检测能力而备受青睐。然而,传统YOLO模型大多采用单一Backbone结构,即利用一个卷积神经网络(CNN)作为特征提…...
redis经典问题
1.缓存雪崩 指缓存同一时间大面积的失效,所以,后面的请求都会落到数据库上,造成数据库短时间内承受大量请求而崩掉。 解决方案: 1)Redis 高可用,主从哨兵,Redis cluster,避免全盘崩…...
《逃离云端束缚,拥抱GPT本地部署》
《逃离云端束缚,拥抱GPT本地部署》 一、GPT 热潮与本地部署的兴起 自 OpenAI 推出 ChatGPT 以来,全球范围内掀起了一股人工智能的热潮,其强大的自然语言处理能力和广泛的应用场景,让人们对人工智能的未来充满了想象。GPT(Generative Pretrained Transformer)作为一种基于…...
头歌之动手学人工智能-机器学习 --- PCA
目录 第1关:维数灾难与降维 第2关:PCA算法流程 任务描述 编程要求 测试说明 第3关:sklearn中的PCA 任务描述 编程要求 测试说明 第1关:维数灾难与降维 第2关:PCA算法流程 任务描述 本关任务:补充…...
研0调研入门
一、Web of Science 使用教程 1. 访问与注册 访问入口:通过高校图书馆官网进入(需IP权限),或直接访问 Web of Science官网。注册/登录:若机构已订阅,用学校账号登录;个人用户可申请试用或付费…...
神经网络基础[ANN网络的搭建]
神经网络 人工神经网络( Artificial Neural Network, 简写为ANN)也简称为神经网络(NN),是一种模仿生物神经网络结构和功能的计算模型。各个神经元传递复杂的电信号,树突接收到输入信号…...
五、web自动化测试01
目录 一、HTML基础1、HTML介绍2、常用标签3、基础案例3.1 前端代码3.2 自动化测试 二、CSS定位1、css介绍2、案例3、代码优化 三、表单自动化1、案例2、元素属性定位 四、后台基础数据自动化1、登录1.1 id与class定位1.2 定位一组元素 2、商品新增 一、HTML基础 可参考学习 链…...
数据库监控 | MongoDB监控全解析
PART 01 MongoDB:灵活、可扩展的文档数据库 MongoDB作为一款开源的NoSQL数据库,凭借其灵活的数据模型(基于BSON的文档存储)、水平扩展能力(分片集群)和高可用性(副本集架构)&#x…...
STM32F407使用ESP8266实现阿里云OTA(中)
文章目录 前言一、程序分析二、程序讲解1. main函数2. Get_Version()函数3. esp_Init()函数4. Check_Updata()函数结语前言 从上一章STM32F407使用ESP8266实现阿里云OTA(上)中我们已经对连接阿里云和从阿里云获取升级包的流程非常的熟悉了。所以本章我们进行STM32的程序开发…...
sql server 与navicat测试后,连接qt
先用Navicat测试和sql的连通性,Navicat和sql连通之后,qt也能和sql连通了。 Navicat和Sqlserver Management 能连上,项目无法连接本地 Navicat 连接SQLServer 数据库 QT国内镜像网站 Navicat连接SqlServer的问题点 Sql Server的基本配置以及使…...
Django 入门实战:从环境搭建到构建你的第一个 Web 应用
Django 入门实战:从环境搭建到构建你的第一个 Web 应用 恭喜你选择 Django 作为你学习 Python Web 开发的起点!Django 是一个强大、成熟且功能齐全的框架,非常适合构建中大型的 Web 应用程序。本篇将通过一个简单的例子,带你走完…...
ROS2---时间戳对齐
一、ROS2时间系统架构 时间模型 仿真时间(Simulation Time):由/clock话题驱动,适用于离线仿真与调试。真实时间(Real Time):基于系统硬件时钟,支持PTP协议(IEEE 1588&…...
Sublime Text相关设置
一直知道Sublime Text的自由度很高,但是之前使用从未更改过配置,有一天突然想改改设置试一下,感觉打开了新大陆,特此记录一下 设置默认语法 单击 Tools→Developer→New Snippet 弹出一个窗口,把下面这段代码粘贴进去…...
微信小程序 tabbar底部导航栏
官方文档:https://developers.weixin.qq.com/miniprogram/dev/reference/configuration/app.html#tabBar 一、常规菜单格式 在app.json 文件中配置,其他关键点详见官方文档,后续更新不规则图标的写法...
【Maven】项目管理工具
Maven:一个项目管理工具 前言 传统项目管理存在的问题: 依赖管理混乱 需要自己去网上搜 jar 包,找对版本很痛苦(还容易找错)某个库依赖另一个库(传递依赖),你得自己挨个找齐不小心…...
多线程事务?拿捏!
场景:有一批1万或者10万数据,插入数据库,怎么做 事务中进行批量提交 publList<List<OrderPo>> partition Lists.partition(list, 450);StopWatch stopWatch new StopWatch();stopWatch.start();// 顺序插入for (List<OrderPo> sub…...
Unity InputSystem触摸屏问题
最近把Unity打包后的windows软件放到windows触摸屏一体机上测试,发现部分屏幕触摸点击不了按钮,测试了其他应用程序都正常。 这个一体机是这样的,一个电脑机箱,外接一个可以触摸的显示屏,然后UGUI的按钮就间歇性点不了…...
Linux Awk 深度解析:10个生产级自动化与云原生场景
看图猜诗,你有任何想法都可以在评论区留言哦~ 摘要 Awk 作为 Linux 文本处理三剑客中的“数据工程师”,凭借字段分割、模式匹配和数学运算三位一体的能力,成为处理结构化文本(日志、CSV、配置文件)的终极工具。本文聚…...
免费版还是专业版?Dynadot 域名邮箱服务选择指南
关于Dynadot Dynadot是通过ICANN认证的域名注册商,自2002年成立以来,服务于全球108个国家和地区的客户,为数以万计的客户提供简洁,优惠,安全的域名注册以及管理服务。 Dynadot平台操作教程索引(包括域名邮…...
旋转磁体产生的场-对导航姿态的影响
pitch、yaw、roll是描述物体在空间中旋转的术语,通常用于计算机图形学或航空航天领域中。这些术语描述了物体绕不同轴旋转的方式: Pitch(俯仰):绕横轴旋转,使物体向前或向后倾斜。俯仰角度通常用来描述物体…...
