前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >雷池防火墙安装及配置

雷池防火墙安装及配置

作者头像
云端之上
发布2024-03-12 11:27:21
3860
发布2024-03-12 11:27:21
举报
文章被收录于专栏:云端之上云端之上

安装理由

因考虑到网站安全需要,故记录一下安装雷池WAF的经过。

安装环境

操作系统:Linux CentOS 8.0 数据库:mysql 8.0

CPU:1核

内存:2G

安装前:服务器物理内存剩余556M,虚拟内存占用0M。

安装后:服务器物理内存剩余600M,虚拟内存占用520M,雷池WAF占用约500M。

使用后:服务器物理内存剩余600M,虚拟内存占用729M,雷池WAF占用约730M。

雷池WAF介绍

雷池WAF(Web Application Firewall,即网络应用防火墙)是一款由长亭科技开发的开源、免费的网站安全防护工具。它设计用于保护Web应用程序免受常见网络安全威胁,如SQL注入、跨站脚本攻击(XSS)、命令注入、文件包含漏洞等各种应用层攻击。具备以下特点:

1. 开源免费:适用于个人和小型企业用户,降低了部署专业级WAF的成本门槛。

2. 轻量高效:底层基于Nginx等高性能Web服务器,可作为反向代理部署在Web应用前端,实现对HTTP/HTTPS流量的有效监控与过滤。

3. 语义引擎检测技术:采用业界先进的检测算法和技术,能够精准识别并阻止恶意请求,同时尽可能减少误报率。

4. 易于安装配置:提供友好的安装部署教程,帮助用户快速将WAF集成到现有架构中。

5. 持续更新升级:作为活跃的社区项目,会不断优化功能和添加新的防护规则,以应对最新的安全威胁。

安装步骤

一、下载雷池Docker镜像压缩包,上传至服务器

二、安装docker

1.CentOS 8默认使用podman代替docker,所以需要将podman卸载

代码语言:javascript
复制
yum erase podman buildah -y

2.刷新配置及安装依赖

代码语言:javascript
复制
systemctl daemon-reload
yum install -y yum-utils

3.卸载旧版本docker

代码语言:javascript
复制
sudo yum remove docker docker-common docker-selinux dockesr-engine

4.安装需要的软件包

代码语言:javascript
复制
sudo yum install -y yum-utils device-mapper-persistent-data lvm2

5.设置镜仓库

代码语言:javascript
复制
sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

6.安装docker

代码语言:javascript
复制
sudo yum install docker-ce

7.启动 Docker 服务并设置为开机启动

代码语言:javascript
复制
sudo systemctl start docker
sudo systemctl enable docker

8.验证是否安装成功

代码语言:javascript
复制
docker --version

三、安装Docker Compose

1.下载Docker Compose并将其上传至服务器/usr/local/bin/目录下

2.赋予执行权限

代码语言:javascript
复制
sudo chmod +x /usr/local/bin/docker-compose

3.验证安装

代码语言:javascript
复制
docker-compose --version

四、安装雷池WAF

1.创建WAF安装目录并进入该目录(该指令会在当前所在目录创建safeline文件夹)

代码语言:javascript
复制
mkdir -p safeline && cd safeline

2.CD进入雷池Docker镜像压缩包所在目录,执行以下指令。该指令会将雷池Docker镜像压缩包进行解压,并将解压后的 文件直接加载至Docker

代码语言:javascript
复制
cat image.tar.gz | gzip -d | docker load

注:image.tar.gz为雷池Docker镜像压缩包.文件名

3.compose.yaml文件上传至服务器/safeline/文件夹下

4.复制执行以下命令,生成WAF运行所需的相关环境变量(不要一行一行复制,一次性复制全部命令后回车执行)

代码语言:javascript
复制
cat >> .env <<EOF
SAFELINE_DIR=$(pwd)
IMAGE_TAG=latest
MGT_PORT=9443
POSTGRES_PASSWORD=$(LC_ALL=C tr -dc A-Za-z0-9 </dev/urandom | head -c 32)
SUBNET_PREFIX=172.22.222
IMAGE_PREFIX=chaitin
EOF

5.运行雷池WAF

代码语言:javascript
复制
docker compose up -d

五、配置雷池WAF

原来的部署架构:

雷池-waf-原部署架构.webp
雷池-waf-原部署架构.webp

配置雷池WAF后的部署架构:

雷池-waf-现部署架构.webp
雷池-waf-现部署架构.webp

总体配置思路:

注:除80/443端口外所有端口设置外网禁止访问,新建自定义端口,用户访问自定义端口时,waf对自定义端口进行监听,外网统一通过自定义端口进行访问,waf检测自定义端口无问题后转发(该操作全程是内网转发)至项目监听端口。

项目方案示例1(引导页):

如果你同一个端口下部署有多个项目,可自定义一个端口,然后用户访问该自定义端口的请求在WAF设置转发给nginx------>nginx再根据正则筛选分别指定要访问的项目

项目方案示例2:

用户点击前端网页中的网址入口(地址为http://你的ip:端口,此端口为WAF后台自行配置的一个自定义端口,WAF会持续监听该端口)------>雷池WAF监听到该访问请求------>雷池WAF放行后转发至内网环境下项目运行所监听的端口

注:

A.如果你将80端口设置外网拒绝访问,为了cdn省流量你想通过ip直接访问,则可以在雷池WAF后台编辑站点,填写域名为ip,勾选ssl证书随便选一个即可生效。

B.同一个域名有且仅能监听1个相同的端口,所以一个域名只能监听1个80/443端口,如果要实现多个项目各自分别监听各自的80/443端口,建议注册多个二级域名。也可以尝试自定义端口转发至项目端口的方式,但非80/443端口转发至项目端口CDN可能会出现无法访问页面的问题。例http://156.156.156.156:7001/XM/index.html如果用7001自定义端口代替80/443端口,则可能出现CDN无法访问的问题。

具体操作步骤:

1.浏览器打开后台管理页面: https://你的ip:9443

2.下载腾讯身份验证器,完成动态口令绑定。

3.将除80/443端口以外的其它端口全部设置禁止外部网络访问(如果你有ssl证书,可禁用80端口外网访问)。

禁止所有网络访问:

代码语言:javascript
复制
firewall-cmd --permanent --add-rich-rule='rule family="ipv4" source address="0.0.0.0/0" port protocol="tcp" port="要禁止的端口号" reject'

允许内网访问:

代码语言:javascript
复制
firewall-cmd --permanent --add-rich-rule='rule family="ipv4" source address="192.168.0.0/16" port port="要设置的端口号" protocol="tcp" accept'

取消禁止所有网络访问:

代码语言:javascript
复制
firewall-cmd --permanent --remove-rich-rule='rule family="ipv4" source address="0.0.0.0/0" port protocol="tcp" port="要取消禁止的端口号" reject'

取消允许内网访问:

代码语言:javascript
复制
firewall-cmd --permanent --remove-rich-rule='rule family="ipv4" source address="192.168.0.0/16" port port="要取消允许的端口号" protocol="tcp" accept'

4.WAF添加并配置防护站点,配置完成后如下图。

域名:你的服务器域名(直接输入域名或ip即可,不带http/https前缀)。

端口:WAF监听的端口,例如填80端口,则当用户通过域名+此端口方式访问网站时,WAF会监听该端口,端口无问题后WAF进行放行,放行后WAF会转发此请求至上游服务器。

上游服务器:WAF监听访问请求无问题后,你期望转发的访问地址(例http://192.168.2.30:81

5.测试防护功能,将以下连接copy至浏览器访问,手动模拟攻击。如下图为WAF拦截提示图。

模拟 SQL 注入:

代码语言:javascript
复制
http://<IP或域名>:<端口>/?id=1%20AND%201=1

模拟 XSS:

代码语言:javascript
复制
http://<IP或域名>:<端口>/?html=<script>alert(1)</script>

升级雷池WAF

1.下载雷池Docker镜像压缩包,上传至服务器。

2.CD进入镜像压缩包目录,加载镜像:

代码语言:javascript
复制
docker load -i image.tar.gz

3.替换 Docker 容器

代码语言:javascript
复制
docker compose down --remove-orphans
docker compose up -d
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2024-02-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 安装理由
  • 安装环境
  • 雷池WAF介绍
  • 安装步骤
    • 一、下载雷池Docker镜像压缩包,上传至服务器
      • 二、安装docker
        • 三、安装Docker Compose
          • 四、安装雷池WAF
            • 五、配置雷池WAF
              • 总体配置思路:
              • 具体操作步骤:
          • 升级雷池WAF
          相关产品与服务
          容器服务
          腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档