【初探云原生】服务网格基石 -- Envoy 源码探索(一)

本文深入剖析Envoy作为Istio服务网格数据面组件的工作原理,介绍其启动流程、线程模型及线程间通信机制。Envoy是一款高性能L7代理,专为现代SOA设计。

写在前面

Envoy 是 Istio 服务网格的数据面组件,服务网格提供的多种强大的治理能力,在底层均是由 Envoy 做数据面增强实现的。Envoy 是专为大型现代 SOA(面向服务架构)架构设计的 L7 代理和通信总线,体积小,性能高。它的诞生源于以下理念:对应用程序而言,网络应该是透明的。当网络和应用程序出现故障时,应该能够很容易确定问题的根源。
请添加图片描述

启动初始化

本文代码是以 Envoy master 分支 f09ed3646b88fae777a060be37f3224dfa67f428 commit 为基准做的源码分析。Envoy 启动入口是在 source/exe/main.cc,
请添加图片描述
可以看到由 main 进到主程序后,将执行 Envoy::MainCommon::main 方法
请添加图片描述
main 方法中执行的是上面 run 方法,从代码注释可以看出设计的意图是,服务 listener 启动在 try/catch 之外,以便可以在早期诊断中可以生成 core-dump。

请添加图片描述
代码依然很简洁,主要执行的是 server_ -> run() 方法,而 server_ 本身是在 MainCo

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值