【DevOps】什么是 pfSense?免费构建SDWAN
目录
一、详细介绍pfSense
1、 什么是 pfSense?
2、原理
3、 特点
4、 优点
5、 缺点
6、应用场景
7、 典型部署
二、pfSense实战:免费构建企业SD-WAN
1、拓扑图
2、准备工作
3、安装和基本配置pfSense
4、配置VPN
配置IPsec VPN
配置OpenVPN(可选)
5、配置动态路由(可选)
6:测试和优化
一、详细介绍pfSense
1、 什么是 pfSense?
pfSense 是一个基于 FreeBSD 的开源防火墙和路由平台。它被设计用于提供企业级防火墙、路由、VPN、流量管理和很多其他网络功能。pfSense 是由 Netgate 维护和开发的,并且有社区版本和商业支持版本。
2、原理
pfSense 使用 FreeBSD 操作系统作为基础,并利用其强大的网络功能。它通过 Web 界面进行管理,用户可以通过浏览器进行配置和管理。pfSense 支持多种网络协议和服务,能够通过插件(Package)扩展其功能。
3、 特点
- 开源和免费:pfSense 的社区版本是完全免费的,源代码开放。
- 丰富的功能集:包括防火墙、路由、VPN、流量整形、负载均衡、入侵检测和防御(IDS/IPS)等。
- 灵活的配置:通过 Web 界面进行配置,支持命令行访问。
- 高度可扩展:支持安装许多插件,如 Snort(入侵检测系统)、Squid(代理服务器)、pfBlockerNG(广告拦截和地理封锁)等。
- 多种VPN支持:包括 IPsec、OpenVPN、L2TP、PPTP 等,便于构建安全的远程访问和站点间连接。
- 多WAN支持:可以配置多个WAN连接,实现负载均衡和故障切换。
4、 优点
- 高性能:由于基于 FreeBSD,pfSense 的网络性能非常强大,能够处理高流量。
- 高度可定制化:用户可以根据需要安装和配置各种插件和服务。
- 社区支持:有一个活跃的社区,提供丰富的文档和支持。
- 安全性:定期更新和补丁,且支持多种安全功能,如IDS/IPS、VPN等。
- 易用性:Web 界面简洁直观,配置相对简单。
5、 缺点
- 学习曲线:对于初学者来说,全面掌握pfSense的所有功能可能需要一些时间。
- 硬件依赖:虽然pfSense可以在虚拟机上运行,但为了获得最佳性能,通常需要专用硬件。
- 复杂配置:对于一些高级功能,如动态路由协议,配置可能较为复杂。
6、应用场景
- 企业网络防火墙:提供防火墙、NAT、VPN等功能,保护企业网络安全。
- 中小企业路由器:作为企业的主要路由设备,提供多WAN支持、负载均衡和故障切换。
- 远程办公:通过VPN实现安全的远程访问。
- 数据中心:用于数据中心之间的安全连接和流量管理。
- 家庭网络安全:高级用户可以在家庭网络中使用pfSense,以获得更高的安全性和控制。
7、 典型部署
- 边缘防火墙:部署在企业网络的边缘,提供防火墙和VPN服务。
- 内部网络分段:通过 VLAN 和防火墙规则,将不同部门或服务分隔开,提升内部安全。
- VPN 集中器:用于集中管理多个站点间的VPN连接,确保安全通信。
- 负载均衡和高可用性:配置多WAN连接,实现网络负载均衡和高可用性。
pfSense 是一个功能强大且灵活的网络安全解决方案,适用于各种规模的网络环境。从家庭用户到大型企业,pfSense 都能提供可靠的网络安全和管理功能。
二、pfSense实战:免费构建企业SD-WAN
1、拓扑图
互联网|------------------| VyOS (阿里云) | 10.10.10.0/24------------------| IPsec VPN (隧道1)|------------------| VyOS (办公室) | 10.10.20.0/24------------------| IPsec VPN (隧道2)|------------------| VyOS (亚马逊云) | 10.10.30.0/24------------------
要使用pfSense构建SD-WAN(软件定义广域网)以连接三个不同区域的子网络(本地办公室、阿里云和亚马逊云),你可以按照以下步骤进行:
2、准备工作
-
硬件和软件准备:
- 确保每个子网络都有一台pfSense设备或虚拟机。
- 确保每个子网络都有稳定的互联网连接。
-
网络配置:
- 每个子网络应该有唯一的子网范围,以避免IP冲突,请参考上面拓朴中列出的IP地址范围 。
3、安装和基本配置pfSense
-
安装pfSense:
- 下载pfSense ISO并在每个子网络的设备上安装。
-
基本配置:
- 配置每个pfSense设备的WAN接口,使其能够访问互联网。
- 配置LAN接口,使其能够与本地网络设备通信。
- 配置基本的防火墙规则,允许必要的流量。
4、配置VPN
为了建立安全的连接,可以使用VPN(如IPsec或OpenVPN)来连接不同的子网络。
配置IPsec VPN
-
在本地办公室的pfSense上配置IPsec:
- 导航到
VPN > IPsec。 - 添加一个新的Phase 1条目,配置Remote Gateway为阿里云的公共IP地址。
- 配置Phase 1的身份验证方法(例如预共享密钥)。
- 添加一个Phase 2条目,配置本地网络和远程网络。
- 导航到
-
在阿里云的pfSense上配置IPsec:
- 类似步骤,配置Remote Gateway为本地办公室的公共IP地址。
- 确保Phase 1和Phase 2的配置与本地办公室的配置匹配。
-
在本地办公室的pfSense上添加另一个IPsec配置:
- Remote Gateway为亚马逊云的公共IP地址。
- 配置Phase 1和Phase 2。
-
在亚马逊云的pfSense上配置IPsec:
- 配置类似的Remote Gateway为本地办公室的公共IP地址。
- 确保Phase 1和Phase 2的配置匹配。
-
在阿里云和亚马逊云之间配置IPsec:
- 重复上述步骤,确保阿里云和亚马逊云之间也有VPN连接。
配置OpenVPN(可选)
-
在本地办公室的pfSense上配置OpenVPN服务器:
- 导航到
VPN > OpenVPN,选择添加服务器。 - 配置服务器模式、证书、加密设置等。
- 配置客户端网络范围。
- 导航到
-
在阿里云和亚马逊云的pfSense上配置OpenVPN客户端:
- 导航到
VPN > OpenVPN,选择添加客户端。 - 配置服务器地址为本地办公室的公共IP。
- 导入客户端证书,匹配服务器的加密设置。
- 导航到
5、配置动态路由(可选)
为了实现更复杂的路由和冗余,可以使用动态路由协议如BGP或OSPF。
-
安装FRR路由包:
- 导航到
System > Package Manager,安装FRR(一个支持BGP、OSPF等协议的路由软件包)。
- 导航到
-
配置FRR:
- 导航到
Services > FRR,根据需要配置BGP或OSPF协议。 - 配置网络和邻居关系,以便不同子网络之间可以动态路由。
- 导航到
6:测试和优化
-
测试连接:
-
使用ping、traceroute等工具测试不同子网络之间的连接。
-
确保所有子网络之间的流量都能够正常通过VPN传输。
-
-
优化配置:
-
根据实际需求调整防火墙规则。
-
优化VPN和路由配置以提高性能和可靠性。
-
通过上述步骤,你可以使用pfSense构建一个连接本地办公室、阿里云和亚马逊云的SD-WAN网络。根据实际需求,你可以进一步调整和优化配置。
相关文章:
【DevOps】什么是 pfSense?免费构建SDWAN
目录 一、详细介绍pfSense 1、 什么是 pfSense? 2、原理 3、 特点 4、 优点 5、 缺点 6、应用场景 7、 典型部署 二、pfSense实战:免费构建企业SD-WAN 1、拓扑图 2、准备工作 3、安装和基本配置pfSense 4、配置VPN 配置IPsec VPN 配置OpenV…...
elementui table超出两行显示...鼠标已入tip显示
elementui el-table超出两行显示…鼠标已入tip显示 方式一 <el-table-column label"描述"prop"note"class-name"myNoteBox"><template slot-scope"scope"><!-- tips悬浮提示 --><el-tooltip placement"to…...
空白服务器安装系统
一、准备工作 确定服务器的硬件配置,包括处理器、内存、硬盘等信息。选择合适的操作系统镜像文件,可以从官方网站或者第三方网站下载。 二、制作启动盘或镜像 如果服务器支持从光盘启动,可以使用光盘制作软件(如UltraISO&#…...
【车载音视频电脑】嵌入式AI分析车载DVR,支持8路1080P
产品特点 采用H.265 & H.264编解码,节约存储空间、传输流量; 高分辨率:支持8路1080P*15FPS/4路1080P*30FPS、720P、D1等编解码; 支持1张SATA硬盘,取用方便,满足大容量存储要求; 支持1个…...
Java实现Mysql批量插入与更新
第一、批量插入语句 Insert({"<script>","INSERT INTO TABLE_NAME (" "ID," "IS_DELETE," "GMT_CREATE," "GMT_MODIFIED" ")VALUES","<foreach collection list item item separator …...
李沐团队发布Higgs-Llama-3-70B,角色扮演专用模型
前言 近年来,大语言模型(LLM)在各个领域都展现出强大的能力,尤其是其在对话、写作、代码生成等方面的应用越来越广泛。然而,想要让 LLM 真正地融入人类社会,扮演各种角色,还需要具备更强大的角…...
2024年护网行动全国各地面试题汇总(4)作者:————LJS
面试过程及回答 自我介绍这里就如实回答的工作经历,参与的项目,尽量简短的把你参与的项目和成果说出来就行 使用过哪些设备,出现误报怎么办 天眼、EDR、全流量告警、态势感知、APT、蜜罐设备先去查看设备的完整流量日志等信息确认是否为误报&…...
秋招突击——6/11——复习{(树形DP)树的最长路径、电话号码的字母组合}——新作{重复序列中前最小的数字}
文章目录 引言复习树形DP——树的最长路径电话号码的字母组合 新作重复序列中前最小的数字个人实现参考实现 总结 引言 这两天可能有点波动,但是算法题还是尽量保证复习和新作一块弄,数量上可能有所差别。 复习 树形DP——树的最长路径 这道题是没有…...
Lua与C交互API接口总结
Lua与C交互 1. 常见Lua相关的C API压入元素查询元素获取元素检查元素栈的相关数据操作 2. C调用Lua核心调用函数示例 3. Lua调用C1. C函数注册到Lua(lua_register)示例2. 批量注册(luaL_Reg)示例 1. 常见Lua相关的C API 压入元素…...
DT浏览器很好用
简单的浏览器,又是强大的浏览器,界面简洁大方,操作起来非常流畅😎,几乎不会有卡顿的情况。 搜索功能也十分强大👍,能够快速精准地找到想要的信息。 而且还有出色的兼容性,各种网页都…...
RabbitMQ实践——在管理后台测试消息收发功能
在《RabbitMQ实践——在Ubuntu上安装并启用管理后台》中,我们搭建完RabbitMQ服务以及管理后台。本文我们将管理后台,进行一次简单的消息收发实验。 赋予admin账户权限 登录到管理后台,进入到用户admin的管理页面 点击“set permission”&a…...
vscode卡顿问题处理(vue-official插件)
vue官方扩展由volar升级为vue-official,部分人的ide会变得非常卡顿,这是由于vscode本身一些问题导致,如下图作者解释: 解决方式: 通过禁用Hybrid模式,不使用tsserver来接管语言支持,卡顿会缓解…...
使用Kube-Bench对Kubernetes进行安全检测
使用Kube-Bench对Kubernetes进行安全检测 1. 工具介绍 Kube-Bench是一个开源的Go语言工具,用于自动化检查Kubernetes集群是否符合CIS Kubernetes基准。这些基准包括一系列关于Kubernetes配置和部署安全性的建议和最佳实践。 Kube-Bench执行了一系列针对Kubernete…...
STM32开发过程中碰到的问题总结 - 1
文章目录 前言1. 怎么生成keil下可以使用的文件和gcc下编译使用的makefile2. STM32的时钟树3.怎么查看keil5下的编译工具链用的是哪个4. Arm编译工具链和GCC编译工具链有什么区别吗?5. 怎么查看Linux虚拟机是x86的还是aarch646. 怎么下载gcc-arm的编译工具链7.怎么修…...
hiberfil.sys文件在Windows系统作用
hiberfil.sys文件在Windows系统中起着关键的作用,主要涉及到计算机的休眠功能。以下是关于hiberfil.sys的详细解释: 定义与功能: hiberfil.sys是Windows休眠功能(Windows Hibernation)将内存数据与会话保存至硬盘所需…...
智能制造前沿:ARMxy工控机在机器人控制中
机器人控制系统正逐步成为现代制造业的核心引擎。在这个过程中,ARMxy工业计算机以其独特的优势,成为了驱动这一变革的关键力量。本文将以自动化装配线机器人为例,探讨ARMxy如何通过其低功耗、高性能特性,以及高度灵活性的设计&…...
【CS.AI】AI引领编程新时代:深度探索GitHub Copilot
文章目录 引言0. TOP TAKEAWAYS 重要要点1. Copilot的基本功能2. 技术原理3. 优势与局限优势局限 4. 使用体验4.1 初次使用4.2 在 JetBrains 全家桶中使用 GitHub Copilot1. 安装插件2. 配置插件3. 使用 GitHub Copilot 4.3 日常开发4.4 体验与反馈 5. 对开发者生态系统的影响5…...
Java:爬虫htmlunit抓取a标签
如果对htmlunit还不了解的话可以参考Java:爬虫htmlunit-CSDN博客 了解了htmlunit之后,我们再来学习如何在页面中抓取我们想要的数据,我们在学习初期可以找一些结构比较清晰的网站来做测试爬取,首先我们随意找个网站如下ÿ…...
电池包断路单元DBU的预充电电阻应用案例
当电池组接触器闭合到电机和逆变器上时,逆变器电容器中会有电流涌入。这种非常高的电流至少可能会使接触器老化,并可能永久损坏接触器。 因此,当我们关闭电池组上的接触器时,我们分三个步骤执行此操作: 1.关闭主负极…...
车载网络安全指南 系统层面开发阶段(六)
返回总目录->返回总目录<- 目录 前言 一、统层面产品开发启动 二、系统层面漏洞分析 三、网络安全策略具体化 四、确定网络安全技术需求 五、系统设计 六、系统集成与测试 七、网络安全验证 八、系统层面网络安全评估 九、系统层面产品开发阶段检查 十、产品发…...
XCTF-web-easyupload
试了试php,php7,pht,phtml等,都没有用 尝试.user.ini 抓包修改将.user.ini修改为jpg图片 在上传一个123.jpg 用蚁剑连接,得到flag...
剑指offer20_链表中环的入口节点
链表中环的入口节点 给定一个链表,若其中包含环,则输出环的入口节点。 若其中不包含环,则输出null。 数据范围 节点 val 值取值范围 [ 1 , 1000 ] [1,1000] [1,1000]。 节点 val 值各不相同。 链表长度 [ 0 , 500 ] [0,500] [0,500]。 …...
ESP32 I2S音频总线学习笔记(四): INMP441采集音频并实时播放
简介 前面两期文章我们介绍了I2S的读取和写入,一个是通过INMP441麦克风模块采集音频,一个是通过PCM5102A模块播放音频,那如果我们将两者结合起来,将麦克风采集到的音频通过PCM5102A播放,是不是就可以做一个扩音器了呢…...
高等数学(下)题型笔记(八)空间解析几何与向量代数
目录 0 前言 1 向量的点乘 1.1 基本公式 1.2 例题 2 向量的叉乘 2.1 基础知识 2.2 例题 3 空间平面方程 3.1 基础知识 3.2 例题 4 空间直线方程 4.1 基础知识 4.2 例题 5 旋转曲面及其方程 5.1 基础知识 5.2 例题 6 空间曲面的法线与切平面 6.1 基础知识 6.2…...
wpf在image控件上快速显示内存图像
wpf在image控件上快速显示内存图像https://www.cnblogs.com/haodafeng/p/10431387.html 如果你在寻找能够快速在image控件刷新大图像(比如分辨率3000*3000的图像)的办法,尤其是想把内存中的裸数据(只有图像的数据,不包…...
AI语音助手的Python实现
引言 语音助手(如小爱同学、Siri)通过语音识别、自然语言处理(NLP)和语音合成技术,为用户提供直观、高效的交互体验。随着人工智能的普及,Python开发者可以利用开源库和AI模型,快速构建自定义语音助手。本文由浅入深,详细介绍如何使用Python开发AI语音助手,涵盖基础功…...
深入浅出Diffusion模型:从原理到实践的全方位教程
I. 引言:生成式AI的黎明 – Diffusion模型是什么? 近年来,生成式人工智能(Generative AI)领域取得了爆炸性的进展,模型能够根据简单的文本提示创作出逼真的图像、连贯的文本,乃至更多令人惊叹的…...
springboot 日志类切面,接口成功记录日志,失败不记录
springboot 日志类切面,接口成功记录日志,失败不记录 自定义一个注解方法 import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target;/***…...
Python网页自动化Selenium中文文档
1. 安装 1.1. 安装 Selenium Python bindings 提供了一个简单的API,让你使用Selenium WebDriver来编写功能/校验测试。 通过Selenium Python的API,你可以非常直观的使用Selenium WebDriver的所有功能。 Selenium Python bindings 使用非常简洁方便的A…...
Python训练营-Day26-函数专题1:函数定义与参数
题目1:计算圆的面积 任务: 编写一个名为 calculate_circle_area 的函数,该函数接收圆的半径 radius 作为参数,并返回圆的面积。圆的面积 π * radius (可以使用 math.pi 作为 π 的值)要求:函数接收一个位置参数 radi…...
