【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.关闭主负极…...
车载网络安全指南 系统层面开发阶段(六)
返回总目录->返回总目录<- 目录 前言 一、统层面产品开发启动 二、系统层面漏洞分析 三、网络安全策略具体化 四、确定网络安全技术需求 五、系统设计 六、系统集成与测试 七、网络安全验证 八、系统层面网络安全评估 九、系统层面产品开发阶段检查 十、产品发…...
CVPR 2025 MIMO: 支持视觉指代和像素grounding 的医学视觉语言模型
CVPR 2025 | MIMO:支持视觉指代和像素对齐的医学视觉语言模型 论文信息 标题:MIMO: A medical vision language model with visual referring multimodal input and pixel grounding multimodal output作者:Yanyuan Chen, Dexuan Xu, Yu Hu…...
51c自动驾驶~合集58
我自己的原文哦~ https://blog.51cto.com/whaosoft/13967107 #CCA-Attention 全局池化局部保留,CCA-Attention为LLM长文本建模带来突破性进展 琶洲实验室、华南理工大学联合推出关键上下文感知注意力机制(CCA-Attention),…...
python/java环境配置
环境变量放一起 python: 1.首先下载Python Python下载地址:Download Python | Python.org downloads ---windows -- 64 2.安装Python 下面两个,然后自定义,全选 可以把前4个选上 3.环境配置 1)搜高级系统设置 2…...
ssc377d修改flash分区大小
1、flash的分区默认分配16M、 / # df -h Filesystem Size Used Available Use% Mounted on /dev/root 1.9M 1.9M 0 100% / /dev/mtdblock4 3.0M...
大数据零基础学习day1之环境准备和大数据初步理解
学习大数据会使用到多台Linux服务器。 一、环境准备 1、VMware 基于VMware构建Linux虚拟机 是大数据从业者或者IT从业者的必备技能之一也是成本低廉的方案 所以VMware虚拟机方案是必须要学习的。 (1)设置网关 打开VMware虚拟机,点击编辑…...
抖音增长新引擎:品融电商,一站式全案代运营领跑者
抖音增长新引擎:品融电商,一站式全案代运营领跑者 在抖音这个日活超7亿的流量汪洋中,品牌如何破浪前行?自建团队成本高、效果难控;碎片化运营又难成合力——这正是许多企业面临的增长困局。品融电商以「抖音全案代运营…...
cf2117E
原题链接:https://codeforces.com/contest/2117/problem/E 题目背景: 给定两个数组a,b,可以执行多次以下操作:选择 i (1 < i < n - 1),并设置 或,也可以在执行上述操作前执行一次删除任意 和 。求…...
跨链模式:多链互操作架构与性能扩展方案
跨链模式:多链互操作架构与性能扩展方案 ——构建下一代区块链互联网的技术基石 一、跨链架构的核心范式演进 1. 分层协议栈:模块化解耦设计 现代跨链系统采用分层协议栈实现灵活扩展(H2Cross架构): 适配层…...
python执行测试用例,allure报乱码且未成功生成报告
allure执行测试用例时显示乱码:‘allure’ �����ڲ����ⲿ���Ҳ���ǿ�&am…...
【7色560页】职场可视化逻辑图高级数据分析PPT模版
7种色调职场工作汇报PPT,橙蓝、黑红、红蓝、蓝橙灰、浅蓝、浅绿、深蓝七种色调模版 【7色560页】职场可视化逻辑图高级数据分析PPT模版:职场可视化逻辑图分析PPT模版https://pan.quark.cn/s/78aeabbd92d1...
