First Try Meshery
Created: January 6, 2022 11:02 AM
零、总结
SMP 是用来进行 Service Mesh 的性能测试而生的,并非实际的应用或集群的遥测。它定义了一致的性能测试标准,便于多 Service Mesh 进行统一横向性能比较(apples to apples performance comparisons)。
在 Mesh 和 Application 的遥测方面,Meshery 是通过接入 Grafana 或 Promethues 的方式来满足需求。
0.1 SMP(Service Mesh Performance)—— Service Mesh 性能测试(详情见 2.5 章节)
SMP 是用来测试 Service Mesh 的性能表现的统一协议(数据格式)。通过一致的 protobuf 数据格式(在 Meshery 的源码中,就是 import 了 service-mesh-performance 的 go sdk),来完成不同 Service Mesh 的性能横向比较。
协议
data:image/s3,"s3://crabby-images/f63cc/f63cc238c2cc454ee295f8de0640ade20ba2229b" alt=""
按照定义的 metadata 数据接入新 Service Mesh
data:image/s3,"s3://crabby-images/07e22/07e224d7697e21523c26db95d108082854b4060e" alt=""
运行性能测试(图中的 11 是倒计时,点击 run test 后,就会产生一个大大的倒计时数字)
data:image/s3,"s3://crabby-images/d39f5/d39f545ad36c99843931147c82da3c9a5c4f684a" alt=""
不同 Service Mesh 性能横向比较
data:image/s3,"s3://crabby-images/72d9f/72d9fcad56647aeef0456c01c7489dd46ef556c1" alt=""
0.2 SMI(Service Mesh Interface)
这一块在平台上的体现是 SMI 协议合规度检测,从协议定义的 Traffic Spec、Traffic Split、Traffic Access 三个方向进行检测(由于暂未找到应用相关的数据,尚不知晓关于流量方便的具体平台展现形式)。
data:image/s3,"s3://crabby-images/4004d/4004d05672b196559c5cffe84f2798cbe2640030" alt=""
0.3 文档导读
由于 Meshery 是 Layer5 的官方标准实现,此次调研以 Meshery 的平台为主要切入点,看其标准在平台上的具体落实情况来进一步了解,其调研的数据主要来源以下三个地方
- 官方文档(含 Github)
- 官方 YouTube 频道
- 官方提供的在线实验
一、环境准备
使用 layer5 官方提供的在线 lab 来运行。
data:image/s3,"s3://crabby-images/ccf47/ccf47410909caf63d81b898b15cd2da5b3b73efe" alt=""
有以下两点需要注意:
- 按照步骤进行运行即可,需要注意的是,当我们正常安装 Meshery 后,添加 Provider 一般是不生效的,我们需要点击 terminal 的 + 号,选择 “Select port to view on Host1”,并且输入端口后 9081 才能访问系统。
另外,当我们正常安装完成后,可查看 meshery 状态都是 ready 后,方可打开 web
1
2
3
4
5
6
7
8$ mesheryctl system status
NAME READY STATUS RESTARTS AGE
meshery 1/1 Running 0 2m30s
meshery-broker 1/1 Running 0 1m7s
meshery-linkerd 1/1 Running 0 2m30s
meshery-operator 2/2 Running 0 2m30s
Meshery endpoint is http://localhost:9081
通过体验 Meshery 的安装流程,我们发现其安装及其简单,通过一条指令即可完成,这是我们需要思考的,如何让用户以最小的心智来试用。
除了安装友好,在进入系统后,我们安装对应的 service mesh,或者安装示例程序,都是直接在平台上点击操作,无疑大大简化了用户的上手负担。
二、平台模块速览
说明:由于实验环境很多数据缺失,所以部分页面从 YouTube 或其他地方截图所得,来源见附录。
2.1 平台初始化配置
平台初始化配置主要完成以下工作:1、添加 Provider;2、登录
Choose a provider ↓
data:image/s3,"s3://crabby-images/62f94/62f9446d555b71763d4464dc38dc0b6a07997d28" alt=""
data:image/s3,"s3://crabby-images/fce6d/fce6d758364da632e15389571638a9727d7294f9" alt=""
Login ↓
data:image/s3,"s3://crabby-images/a3630/a363089484ce434b1549a9fba190c827ec70745c" alt=""
2.2 平台菜单一览
菜单分为以下几个部分
- Performance(SMP). 用来对 Service Mesh 进行性能测试。
- Conformance(SMI). 用来测试 Service Mesh 的协议合规度检测。
- Lifecycle. 用来管理不同的 Service Mesh。
SMP&SMI ↓
data:image/s3,"s3://crabby-images/e94b9/e94b9baaa676ab68032ad55234e980860bac9580" alt=""
Configuration ↓
data:image/s3,"s3://crabby-images/4fd0f/4fd0f77723ea343141390eda78e73808585d97dd" alt=""
Lifecycle&Service Meshes ↓
data:image/s3,"s3://crabby-images/86610/866108a7bc0f9f18de58d18cef6d746409bc09eb" alt=""
2.3 Dashboard
Dashboard without data
data:image/s3,"s3://crabby-images/029b2/029b2ba69e4d9f00f8a494668db6bc098b7bf819" alt=""
Dashboard with data
- Service Mesh 看板显示了当前接入的 mesh 和组件
- Metrics 直接嵌入的 Grafana 或 Promethues 面板
data:image/s3,"s3://crabby-images/896cd/896cdb1b66a37d6915d332bb49b23bfb85f724f1" alt=""
2.4 Install Service Mesh
通过 Meshery 可以管理多种 Service Mesh,我们可以在 meshery 中直接添加 service mesh 和示例程序。
Linkerd Adapter
data:image/s3,"s3://crabby-images/bf715/bf715892f9e6324a8e916cf2c8c38a98634f5da9" alt=""
点击加号,添加 Linkerd Service Mesh
data:image/s3,"s3://crabby-images/7cd5b/7cd5b129789403a46461d5a947fb04be8718e8f1" alt=""
点击加号,添加示例程序
data:image/s3,"s3://crabby-images/d8571/d857165a7311e3fd83e29b520d844aec17a3d9b7" alt=""
2.5 Performance
2.5.1 Performance Dashboard
Performance Dashboard without data
data:image/s3,"s3://crabby-images/a50a5/a50a57530fe4a85958f13e7ee54237a36cf96d45" alt=""
Performance Dashboard with data
data:image/s3,"s3://crabby-images/2f37d/2f37d3f7bd183b070d8818336ac92746a21de5c8" alt=""
2.5.2 Profiles
SMP Profiles without data
data:image/s3,"s3://crabby-images/666dc/666dc403c5fc5887eb93314307bcb97a5a425566" alt=""
SMP Profiles 列表
data:image/s3,"s3://crabby-images/b42de/b42de70dcd8ee879028f57aa61e800b3da9882cb" alt=""
查看 SMP Profile 详情以及具体测试数据结果
![Meshery - The Service Mesh Manager 35-47 screenshot.png]
2.5.1 Add Profile
Profile 表单
data:image/s3,"s3://crabby-images/07e22/07e224d7697e21523c26db95d108082854b4060e" alt=""
SMP Profile Service Mesh Options,选择具体的 Service Mesh
data:image/s3,"s3://crabby-images/de79d/de79d7cbf55a513fe978aa34c4ad5a370f822e8f" alt=""
SMP Profile Service Mesh Load Generator,选择负载产生器
data:image/s3,"s3://crabby-images/c69ec/c69ec7bbe3356a6e144d55f1a7ed1970d26927bc" alt=""
data:image/s3,"s3://crabby-images/03fdd/03fddcc3d7f4fcff02c5484853fc58c9ab2816c0" alt=""
SMP Profile Advanced Options,进一步定制压测的请求信息
data:image/s3,"s3://crabby-images/63756/637560cd3a71f6f07f11ac590844d699b8ccbee0" alt=""
2.5.4 Run Test
Run test 运行测试,倒计时
data:image/s3,"s3://crabby-images/d39f5/d39f545ad36c99843931147c82da3c9a5c4f684a" alt=""
View Performance Result 查看测试结果
data:image/s3,"s3://crabby-images/6f3b1/6f3b1ed6aef030f38bf3b7297c8123659ecf43c1" alt=""
Comparison 比较同一个 Profile 不同测试结果
- 这一点和 SMP 文档中 apple to apple performance comparison 相对应
data:image/s3,"s3://crabby-images/72d9f/72d9fcad56647aeef0456c01c7489dd46ef556c1" alt=""
2.6 Add Service Mesh Metrics
Configure Service Mesh Metrics
data:image/s3,"s3://crabby-images/9d7ed/9d7ed4f3467701633e9b830e46825b8750746dc7" alt=""
Add Grafana
data:image/s3,"s3://crabby-images/b4cb2/b4cb2b58166e5fcd6711b893ed6f5a8cd2eac608" alt=""
Add Promethues
data:image/s3,"s3://crabby-images/f5130/f513033abea141c6f0224b821d8d4472a689c308" alt=""
Environment & In Cluster Deployment
data:image/s3,"s3://crabby-images/5f4d2/5f4d2e6744ea4e16af8066fbe9ce05722d99bf66" alt=""
Service Meshes
data:image/s3,"s3://crabby-images/c73b5/c73b516072ad714e5474cc33618bf2d8fc15e654" alt=""
2.7 Conformance(SMI)
在 Manage Service Mesh 地方执行 SMI 协议检测
data:image/s3,"s3://crabby-images/f466b/f466b569069260807f0010e3a4536dc668307bff" alt=""
Service Mesh Interface Conformance Results, SMI 协议标准合规情况检测
data:image/s3,"s3://crabby-images/4004d/4004d05672b196559c5cffe84f2798cbe2640030" alt=""
摘自文档的更多检查结果
data:image/s3,"s3://crabby-images/49a16/49a1640f6007382114dc966f7ea5e02991c724b0" alt=""
附录
YouTube, Meshery - The Service Mesh Manager
Performance Management 文档
Run SMI Conformance 文档