CNCF xDS 开源项目使用指南
2024-08-07 22:20:30作者:郁楠烈Hubert
1. 项目目录结构及介绍
CNCF(Cloud Native Computing Foundation)的xDS项目位于 GitHub,它在云原生环境下扮演着重要角色,特别是在实现服务发现、负载均衡、网络策略等关键功能方面。以下是项目的基本目录结构概览及其简介:
xds/
├── api # API定义,包括gRPC服务和服务资源类型。
│ ├── protodoc # 用于API规范的文档注释。
│ └── v3 # 版本3的API资源定义。
├── bazel # Bazel构建规则和相关配置。
├── doc # 项目相关的文档资料。
├── envoy-control-plane # 示例或工具代码,可能涉及Envoy控制平面的实现。
├── examples # 示例应用,帮助理解如何集成xDS协议。
├── scripts # 辅助脚本,用于自动化某些任务。
├── tools # 工具集合,用于开发、测试或监控xDS相关组件。
├── CONTRIBUTING.md # 贡献指南。
├── LICENSE # 许可证文件。
└── README.md # 项目介绍和快速入门指南。
2. 项目的启动文件介绍
由于xDS更多地作为一个框架或协议存在,其本身并不直接提供一个“启动文件”以执行某种特定的应用程序。不过,开发人员通常会在自己的服务中集成xDS客户端或服务器逻辑。例如,在使用Envoy作为代理时,Envoy的配置文件往往会被视为“启动”的核心,因为它包含了连接到xDS服务器的设置。因此,虽然没有直接的“启动文件”,但了解如何配置Envoy或开发中的应用来与xDS交互至关重要。
示例配置文件(非直接启动文件)
假设使用Envoy作为示例,一个简化的Envoy配置文件示例会涉及到xDS配置部分:
admin:
address:
socket_address:
protocol: TCP
address: 0.0.0.0
port_value: 9901
static_resources:
listeners:
- name: listener_0
address:
socket_address:
address: 0.0.0.0
port_value: 8080
filter_chains:
- filters:
- name: envoy.http_connection_manager
typed_config:
"@type": type.googleapis.com/envoy.config.filter.network.http_connection_manager.v2.HttpConnectionManager
stat_prefix: ingress_http
route_config:
name: local_route
virtual_hosts:
- name: service
domains: ["*"]
routes:
- match:
prefix: "/"
route:
cluster: service_cluster
dynamic_resources:
ads_config:
api_type: GRPC
transport_api_version: V3
grpc_services:
envoy_grpc:
host: xds-server
port: 8001
这里的动态资源部分(dynamic_resources)介绍了如何通过xDS协议从远程服务器获取配置信息。
3. 项目的配置文件介绍
xDS的配置分散在多个组件中,主要是通过gRPC服务接口进行动态更新。具体到某个应用或服务,比如Envoy,它的主要配置文件(envoy.yaml)包含静态和动态资源的定义。动态资源部分是xDS的核心,它允许Envoy从管理服务器按需接收如集群、监听器、路由和其他资源的更新。
对于开发者而言,了解如何在这些配置文件中指定xDS服务端点(如上文的ADS配置),以及资源类型(如Listener、Cluster、RouteConfiguration等),是非常关键的。实际的配置细节会根据具体的集成场景而有所不同,但都遵循xDS API定义的格式和约定。
请注意,深入了解和实践xDS通常意味着深入学习其API规范和实现细节,这对于正确配置和利用xDS的能力至关重要。
登录后查看全文
热门项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin07
compass-metrics-modelMetrics model project for the OSS CompassPython00
最新内容推荐
Error Correction Coding——mathematical methods and algorithms:深入理解纠错编码的数学精髓 HP DL380 Gen9iLO固件资源下载:提升服务器管理效率的利器 RTD2270CLW/RTD2280DLW VGA转LVDS原理图下载介绍:项目核心功能与场景 JADE软件下载介绍:专业的XRD数据分析工具 常见材料性能参数pdf下载说明:一键获取材料性能参数,助力工程设计与分析 SVPWM的原理及法则推导和控制算法详解第四修改版:让电机控制更高效 Oracle Instant Client for Microsoft Windows x64 10.2.0.5下载资源:高效访问Oracle数据库的利器 鼎捷软件tiptop5.3技术手册:快速掌握4gl语言的利器 源享科技资料大合集介绍:科技学习者的全面资源库 潘通色标薄全系列资源下载说明:设计师的创意助手
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
522
3.71 K
Ascend Extension for PyTorch
Python
327
384
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
875
576
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
335
161
暂无简介
Dart
762
184
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.32 K
745
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
React Native鸿蒙化仓库
JavaScript
302
349
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
112
134