meshery 初步试用 & Service Mesh Performance(SMP) 了解

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 的性能横向比较。

协议

按照定义的 metadata 数据接入新 Service Mesh

运行性能测试(图中的 11 是倒计时,点击 run test 后,就会产生一个大大的倒计时数字)

不同 Service Mesh 性能横向比较

0.2 SMI(Service Mesh Interface)

这一块在平台上的体现是 SMI 协议合规度检测,从协议定义的 Traffic Spec、Traffic Split、Traffic Access 三个方向进行检测(由于暂未找到应用相关的数据,尚不知晓关于流量方便的具体平台展现形式)。

0.3 文档导读

由于 Meshery 是 Layer5 的官方标准实现,此次调研以 Meshery 的平台为主要切入点,看其标准在平台上的具体落实情况来进一步了解,其调研的数据主要来源以下三个地方

  1. 官方文档(含 Github)
  2. 官方 YouTube 频道
  3. 官方提供的在线实验

一、环境准备

使用 layer5 官方提供的在线 lab 来运行。

Interactive Service Mesh Labs

有以下两点需要注意:

  1. 按照步骤进行运行即可,需要注意的是,当我们正常安装 Meshery 后,添加 Provider 一般是不生效的,我们需要点击 terminal 的 + 号,选择 “Select port to view on Host1”,并且输入端口后 9081 才能访问系统。
  2. 另外,当我们正常安装完成后,可查看 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 ↓

Login ↓

2.2 平台菜单一览

菜单分为以下几个部分

  1. Performance(SMP). 用来对 Service Mesh 进行性能测试。
  2. Conformance(SMI). 用来测试 Service Mesh 的协议合规度检测。
  3. Lifecycle. 用来管理不同的 Service Mesh。

SMP&SMI ↓

Configuration ↓

Lifecycle&Service Meshes ↓

2.3 Dashboard

Dashboard without data

Dashboard with data

  1. Service Mesh 看板显示了当前接入的 mesh 和组件
  2. Metrics 直接嵌入的 Grafana 或 Promethues 面板

2.4 Install Service Mesh

通过 Meshery 可以管理多种 Service Mesh,我们可以在 meshery 中直接添加 service mesh 和示例程序。

Linkerd Adapter

点击加号,添加 Linkerd Service Mesh

点击加号,添加示例程序

2.5 Performance

2.5.1 Performance Dashboard

Performance Dashboard without data

Performance Dashboard with data

2.5.2 Profiles

SMP Profiles without data

SMP Profiles 列表

查看 SMP Profile 详情以及具体测试数据结果

![Meshery - The Service Mesh Manager 35-47 screenshot.png]

2.5.1 Add Profile

Profile 表单

SMP Profile Service Mesh Options,选择具体的 Service Mesh

SMP Profile Service Mesh Load Generator,选择负载产生器

SMP Profile Advanced Options,进一步定制压测的请求信息

2.5.4 Run Test

Run test 运行测试,倒计时

View Performance Result 查看测试结果

Comparison 比较同一个 Profile 不同测试结果

  1. 这一点和 SMP 文档中 apple to apple performance comparison 相对应

2.6 Add Service Mesh Metrics

Configure Service Mesh Metrics

Add Grafana

Add Promethues

Environment & In Cluster Deployment

Service Meshes

2.7 Conformance(SMI)

在 Manage Service Mesh 地方执行 SMI 协议检测

Service Mesh Interface Conformance Results, SMI 协议标准合规情况检测

摘自文档的更多检查结果

附录