iptables/netfilter基于layer7实现应用层过滤

简介:

前言

做为网络管理员,对P2P、QQ、酷狗等软件是又爱又恨,大多数公司为了提高工作效率,禁止公司员工登陆QQ、看视频等,在市场上买专门的上网行为管理设备,随便一种都是价格不菲,而使用linux来做网关一样可以禁止qq、酷狗等软件,为实现此功能就需要为iptables/netfilter添加layer7模块,而iptables/netfilter是基于内核的,所以需要重新编译内核。

编译过程

环境介绍

系统环境:CentOS6.6

所需源码包:kernel-2.6.32-504.16.2.el6.src.rpm(红帽ftp站点提供)

                   iptables-1.4.20.tar.bz2

                   netfilter-layer7-v2.23.tar.bz2

                   l7-protocols-2009-05-28.tar.gz

编译内核

解决依赖关系

1
[root@Firewall ~] # yum groupinstall "Development Tools" "Server Platform Development" -y

创建所需用户并安装

wKioL1U52AfzOJkxAADQSsSFnOE176.jpg

将源码解压到指定目录

wKiom1U514uTyc6GAASy00zVdms024.jpg

为内核打补丁

wKioL1U52hqyeXliAAKlGLlFB2A206.jpg

开始编译

wKiom1U52kTTr3tXAAErvOlEyC8318.jpg

首先选择此项

wKiom1U52wWwl30xAALeeTd4YNc164.jpg

进入此项设定参数

wKiom1U524XBzK-WAAKUYVVczAQ159.jpg

下拉,选择此项并进入

wKiom1U53ESQJYS8AANJakmApq4669.jpg

进入核心过滤设置

wKioL1U53hizo98YAAKYBFELD90577.jpg

启用layer7支持

wKiom1U53ZaCyB6TAAMjLOn4Z_k732.jpg

返回第一层,进入此项

wKioL1U54NKyBGwRAALankFaruI474.jpg

取消模块签名校验

wKiom1U53_qBE6uqAAJvEO-CawU730.jpg

返回,进入API加密设置

wKioL1U54fqgv2-PAALlnpypgOc714.jpg

取消内核签名校验,否则无法编译安装

wKiom1U54SXjXaHFAANyTMiELDE099.jpg

保存退出

wKiom1U54ZqwI49qAABu0ESNInY799.jpg

编译安装

1
2
3
4
5
[root@Firewall linux] # yum install screen -y #为了防止意外,我们在screen里编译安装
[root@Firewall linux] # screen
[root@Firewall linux] # make
[root@Firewall linux] # make modules_install
[root@Firewall linux] # make install

看一下grub.conf文件,新内核的信息已经写入了

wKiom1U6AP6gyMI8AAJXc0yUey4977.jpg

以新内核启动

wKiom1U6AhqCCh6dAAEARkTxvf0749.jpg

编译iptables

解压并打补丁

wKioL1U6BSrhEq4KAACKrX5JTI4327.jpg

备份脚本文件,卸载旧版本

wKioL1U6Bjyzo-cSAAB-vGIycIo237.jpg

编译安装

1
2
3
[root@Firewall ~] # cd iptables-1.4.20
[root@Firewall iptables-1.4.20] # ./configure --prefix=/usr --with-ksource=/usr/src/linux
[root@Firewall iptables-1.4.20] # make && make install

还原脚本

wKiom1U6BnPCboVOAABvyQ4uOvo058.jpg

修改脚本

将所有/sbin/$IPTABLES替换为/usr/sbin/$IPTABLES

wKioL1U6C1eCMdeIAAG_fK5UNJY204.jpg

查看iptables版本

wKioL1U6C2uTCiFpAAApX7jJakE606.jpg

为layer7模块提供其所识别的协议的特征码

wKiom1U6ChvjGvcIAACl1JUtdkE211.jpg

装载模块

wKioL1U6Dqngff0pAAClcXY0NEk998.jpg

添加内核参数,使之永久有效

1
2
3
4
5
[root@Firewall ~] # vim /etc/sysctl.conf 
 
net.netfilter.nf_conntrack_acct = 1
 
[root@Firewall ~] # sysctl -p

应用层过滤测试

案例要求

假设内网主机由服务器代理上网,为提高工作效率,禁止内网用户登录QQ

代理服务器:192.168.1.254(可访问网络),172.16.10.254

内网客户端:172.16.10.12

网络设置

wKiom1U6EwTRms7mAAJxupa_F5s170.jpg

wKiom1U6E4qCi2m4AAFi_X3_hLY370.jpg

172.16.0.0/16的网段在VMnet1内

开启服务器路由转发功能

1
2
3
4
5
[root@Firewall ~] # vim /etc/sysctl.conf
 
net.ipv4.ip_forward = 1
 
[root@Firewall ~] # sysctl -p

设置防火墙规则,使内网可访问网络

wKioL1U6HEGQ33rWAAFc8XDbEs4142.jpg

查看是否可以访问网络

wKiom1U6HhTSbhBgAAGDzLCcMg0661.jpg

我们找一个小号登录QQ测试

wKiom1U6KRfBRRbCAARy5BNIP-c063.jpg

此时是可以登录的,我们下线,设置防火墙规则,禁用QQ

wKioL1U6KsCyM1OXAAGR2EPq998653.jpg

再次登录试试

wKiom1U6KYGCij8nAAG7eToNPf0225.jpg

登录失败,我们看一下防火墙,有没有匹配到报文

wKioL1U6KyHwZ7MPAAFwhhdDwBM892.jpg

看,已经有报文被拒绝了,至此iptables基于layer7实现应用层过滤以实现,需要禁止其他程序,请自行添加相应规则

The end 

基于layer7的应用层防火墙就说到这里了,除了编译内核时比较费时间外,应该没什么别的麻烦的问题,希望本文可以帮到有需要的小伙伴,配置过程中遇到问题可留言。以上仅为个人学习整理,如有错漏,大神勿喷~~~



本文转自 北城书生  51CTO博客,原文链接:http://blog.51cto.com/scholar/1638149

相关文章
|
项目管理 开发者 Windows
【KiCad镜像】下载与安装
KiCad EDA 是一款用于印刷电路板设计的开源自由软件,基于 GPLv3 开源协议。 软件包含工程项目管理、原理图设计、线路板绘制、符号库设计、封装库设计、线路板 3D 显示、Gerber 查看、线路板实用计算等工具。
1235 121
|
程序员 开发者 Python
Python网络编程基础(Socket编程) 错误处理和异常处理的最佳实践
【4月更文挑战第11天】在网络编程中,错误处理和异常管理不仅是为了程序的健壮性,也是为了提供清晰的用户反馈以及优雅的故障恢复。在前面的章节中,我们讨论了如何使用`try-except`语句来处理网络错误。现在,我们将深入探讨错误处理和异常处理的最佳实践。
|
弹性计算 安全 网络协议
VPC的基本原理|学习笔记
快速学习VPC的基本原理
|
5月前
|
监控 供应链 数据挖掘
京东平台 API:功能解析与典型应用场景
京东开放平台API涵盖商品、订单、库存、物流等核心功能,支持开发者与商家实现系统对接与数据协同。广泛应用于比价监控、多平台库存同步、ERP集成、数据分析等场景,助力企业提升运营效率,构建电商生态应用。
258 0
|
测试技术 开发者 Docker
llama2 70B mindie推理开箱报错问题
遇到问题,先从基本的检查开始,先检查卡有没有被占用,有的话就kill掉(如果是别人的任务,先知会一下哈)!其次,不要自己随意组合版本,否则会因为经验不足卡在莫名其妙的问题上。
274 3
Electron——electron-vue使用webworker
Electron——electron-vue使用webworker
384 4
|
前端开发 Java 测试技术
综合案例【商品管理系统-Java基础版】(附完整源码)
综合案例【商品管理系统-Java基础版】(附完整源码)
750 9
|
数据采集 算法 关系型数据库
在 MySQL 中使用 REVERSE
【8月更文挑战第6天】
641 0
|
安全 数据库
登录访问时获取IP并校验(Springsecurity )
因公司要求,针对项目进行ip限制,以往只是记录登录ip。所以此功能相对简单。
1141 0
|
存储 弹性计算 监控
ecs配置与优化
阿里云ECS优化涉及实例规格选择、磁盘存储、网络配置、OS及软件优化、连接数管理、监控自动化和升级扩展。选择合适实例类型、磁盘类型以满足I/O需求,优化网络带宽与安全组规则,保持操作系统更新并调整软件配置。注意监控关键指标,利用弹性伸缩适应业务变化,适时升级资源,实现性能与成本的最佳平衡。
488 3

热门文章

最新文章