docs/static/v0.4/concepts/architecture/index.html
Meshery and its components are written using the following languages and technologies.
| Components | Languages and Technologies |
|---|---|
| Meshery Server | Golang, gRPC, GraphQL, SQLlite |
| Meshery Adapters | Golang, gRPC |
| Meshery WASM Filters | Rust and C++ |
| Meshery UI | ReactJS, NextJS, BillboardJS |
| Meshery Provider UI | ReactJS, NextJS |
| Meshery Remote Providers | any - must adhere to Meshery Extension Points |
| Meshery Operator | Golang, NATS |
| MeshSync | Golang |
| Meshery Database | Golang, SQL |
Meshery deploys as a set of containers. Meshery’s containers can be deployed to either Docker or Kubernetes.
Meshery’s REST API may be consumed by any number of clients. Clients need to present valid JWT token.
As a point of extension, Meshery supports two types of providers: Local and Remote.
This diagram outlines logical constructs within Meshery and their relationships.
Meshery Operator is the multi-service mesh operator (a Kubernetes custom controller) that manages MeshSync and it’s messaging broker.
See the Operator section for more information on the function of an operator and MeshSync section for more information on the function of meshsync.
Meshery Server’s database is responsible for collecting and centralizing the state of all elements under management, including infrastructure, application, and Meshery’s own components. Meshery’s database, while persisted to file, is treated as a cache.
See the Database section for more information on the function of the database.
Meshery uses the following list of network ports to interface with its various components:
| Component | Port |
|---|---|
| Meshery REST API | 9081/tcp |
| Meshery GraphQL | 9081/tcp |
| Meshery Broker | 4222/tcp, 6222/tcp, 8222/tcp, 7777/tcp, 7422/tcp, 7522/tcp |
| Learn Meshery Application | 10011/tcp |
| Meshery Adapters | 10000+/tcp |
| Meshery Remote Providers | 443/tcp |
| Service Mesh | Port |
|---|---|
| Meshery Adapter for App Mesh | 10005/tcp |
| Meshery Adapter for Consul | 10002/tcp |
| Meshery Adapter for Citrix Service Mesh | 10008/tcp |
| Meshery Adapter for Istio | 10000/tcp |
| Meshery Adapter for Kuma | 10007/tcp |
| Meshery Adapter for Linkerd | 10001/tcp |
| Meshery Adapter for NGINX Service Mesh | 10010/tcp |
| Meshery Adapter for Network Service Mesh | 10004/tcp |
| Meshery Adapter for Octarine | 10003/tcp |
| Meshery Adapter for Open Service Mesh | 10009/tcp |
| Meshery Adapter for Tanzu Service Mesh | 10010/tcp |
| Meshery Adapter for Traefik Mesh | 10006/tcp |
See the Adapters section for more information on the function of an adapter.
Some components within Meshery’s architecture are concerned with persisting data while others are only concerned with a long-lived configuration, while others have no state at all.
| Components | Persistence | Description |
|---|---|---|
| mesheryctl | stateless | command line interface that has a configuration file |
| Meshery Adapters | stateless | interface with service meshes on a transactional basis |
| Meshery Server | caches state | application cache is stored in user’s $HOME/.meshery/ folder |
| Meshery Providers | stateful | location of persistent user preferences, environment, tests and so on |
| Meshery Operator | stateless | operator of Meshery custom controllers, notably MeshSync |
| MeshSync | stateless | Kubernetes custom controller, continuously running discovery |