体系结构
私有分发网络(PDN)是边缘(edge)、PDN节点(node)及其组的集合,它们形成了一个分散的网络,用于分发内容。PDN架构基于位于JFrog Artifactory或Edge服务器和客户端(Docker或HTTP)之间的互连节点网络。PDN节点充当客户端和Artifactory/Edge之间的缓存代理。
JFrog PDN架构由以下主要组件组成:
- PDN (Private Distribution Network)服务器:负责发布和跟踪PDN节点上可用工件的专用服务,PDN服务器充当初始工件播种器。
- 生产节点:一个独立的应用程序(或Docker镜像),与其他PDN节点连接以解析文件,该应用程序被客户端用于下载内容,并部署在专用的主机或客户端机器上。PDN节点与其父节点和兄弟节点通信以解析文件(Pull)并分发发布包(Push)。它还从缓存工件和按需(Pull)向外部客户端提供文件。
- PDN节点组:相互连接的节点集合组成PDN节点组。组可以以分层方式排列,形成PDN组树,根为PDN服务器。PDN节点只能从自己组内的节点或直接父组中使用点对点下载文件。每个组可以有几个子组,但只有一个父组。PDN节点自己的组被称为SelfGroup,而父组被称为ParentGroup.
- 客户:用于与节点交互的软件客户端,例如Docker或HTTP客户端。
负载均衡器支持
虽然不是PDN体系结构的一部分,但您也可以向此设置添加负载均衡器。负载均衡器是一种配置,可以在PDN节点之间实现传入请求的负载均衡,允许在同一组内的PDN节点之间分配负载,同时还确保它们之间的持续缓存同步。
在上面的例子中,PDN Node1和PDN Node2都有SelfGroup属性“East”,因此属于同一个组。PDN Node3具有SelfGroup属性“West”,因此属于组“West”。所有PDN节点都没有配置ParentGroup,因此在默认情况下,它们直接放在PDN服务器下面,PDN服务器充当它们的ParentGroup。PDN Node1只能从PDN Node2或PDN Server下载文件,而PDN Node3只能从PDN Server下载文件。
PDN服务器可以连接到Artifactory的Source或Edge实例。在上面的例子中,它连接到一个Source Artifactory。
在上面的例子中,PDN Node4到PDN Node7属于同一个组“NY”,并且在ParentGroup“East”下,可以解析它们自己和它们的ParentGroup之间的文件。
拓扑结构
您定义的拓扑和层次结构取决于您的组织的需要。因此,在继续设置PDN之前,我们建议您绘制出您的拓扑需求。下面是使用PDN可以实现的几个拓扑场景示例。
场景1—多组+单PDN服务器+单源JPD
在这个拓扑中,有m个多个(5)PDN组,每个组包含1000个PDN节点(组A, B, C, D, E),连接到A单PDN服务器直接连接到源JPD。
场景2 -多组+单PDN服务器+分布边缘+源JPD
在此拓扑中,有多个(5)PDN组,每个PDN组包含1000个PDN节点(组A、B、C、D和E),连接到单个PDN服务器,该PDN服务器连接到单个分发边缘,该分发边缘连接到单个源JPD。
场景3—高可用配置:多组2级(边缘到PDN节点)
高可用性(HA)是通过将源JPD或分布边缘连接到多个PDN服务器来实现的。每个服务器连接到多个组或一个PDN组,然后连接到子组。
在下面的例子中,我们有以下内容:
- 一个源JPD和两个分布边,彼此连接。
- 每个分发边缘连接到两个PDN服务器。
- 每个PDN服务器连接到自己的PDN组。
- PDN组A同时接入另一个包含500个PDN节点的PDN组(1)。
工作流
设置和注册
- 安装PDN服务器使用安装选项。
- 将服务器连接到Artifactory或Edge。
连接一个或多个PDN节点,创建一个PDN组。
您需要将PDN节点安装在与JFrog PDN服务器或PDN中的任何其他节点有网络连接的主机上。
PDN节点连接到PDN服务器,并根据ParentGroup属性检索PDN节点父候选。
- 验证连接。
分布
PDN支持按需拉动和基于推的分发,如下所述。
按客户端下载工件(按需拉取)
客户端可以主动从PDN节点请求工件。
所有下载通信都使用Artifactory创建的证书链进行ssl加密
- 然后,PDN节点监听客户端下载请求或来自其他PDN节点的请求。
- 当PDN节点代表客户端下载文件时,它们定期向PDN服务器发布关于其存储文件片段的信息。这些信息随后由PDN服务器存储。
- 一旦PDN节点从客户端获得下载请求,它就会向PDN服务器查询其他注册的PDN节点可能拥有该文件。PDN服务器响应,PDN节点开始从相关PDN节点下载文件的可用部分。
- 当文件缓存在PDN节点上时,它们被发布到PDN服务器,其他PDN节点可以根据Artifactory中定义的用户权限并发下载。下载文件过程从多个PDN节点并行执行,从而在多个PDN节点之间分配网络负载,以从Artifactory执行快速高效的下载。
发布发布包(基于推送的发布)
PDN可以主动填充内容,以预热PDN节点上的本地缓存。
验证您具有发布包分发权限或已被分配到项目/平台管理角色,并且已经安装了JFrog分发版。
分配现有的发布包到PDN节点。你可以分发:
- 到指定PDN节点组。
- 从源Artifactory,直接分发到PDN节点组,这些PDN节点组连接到发布包版本的源Artifactory或分发边缘。
规则及指引
- Docker支持开放货柜计划(OCI)和通用包。
- 所有PDN节点都应该被路由到访问根PDN服务器。
- PDN同一组中的节点应该能够相互访问。