From 176e53e9d12534207a14b3dc0f3b9c3b2525cad6 Mon Sep 17 00:00:00 2001 From: Mike Ng Date: Mon, 27 May 2024 21:36:23 -0400 Subject: [PATCH 1/2] docs: add a Why section to the readme (#91) Signed-off-by: Mike Ng Co-authored-by: Chunlin Yang --- README.md | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) diff --git a/README.md b/README.md index 5518043c..6cbaf01c 100755 --- a/README.md +++ b/README.md @@ -1,12 +1,43 @@ # Maestro + Maestro is a system to leverage [CloudEvents](https://cloudevents.io/) to transport Kubernetes resources to the target clusters, and then transport the resource status back. The resources are stored in a database and the status is updated in the database as well. The system is composed of two parts: the Maestro server and the Maestro agent. - The Maestro server is responsible for storing the resources and their status. And sending the resources to the message broker in the CloudEvents format. The Maestro server provides Resful APIs and gRPC APIs to manage the resources. - Maestro agent is responsible for receiving the resources and applying them to the target clusters. And reporting back the status of the resources. ## Architecture + Taking MQTT as an example: + ![Maestro Architecture](./arch.png) +## Why + +Maestro was created to address several critical challenges associated with managing Kubernetes clusters at scale. +Traditional Kubernetes native and custom resources rely heavily on etcd, +which has well-known limitations in terms of scalability and performance. +As the number of clusters increases, the strain on etcd can lead to significant issues, +making it difficult to achieve high-scale Kubernetes cluster management. +To overcome these challenges, Maestro introduces a system that leverages a traditional relational database for storing relevant data, +providing a more scalable and efficient solution. + +### Motivations + +**Scalability**: Kubernetes-based solutions often face scalability issues due to the limitations of etcd. +Maestro aims to overcome these issues by decoupling resource management from the etcd store, +allowing for more efficient handling of a large number of clusters. +This approach supports the goal of managing up to 200,000+ clusters without linear scaling of the infrastructure. + +**Cost Effectiveness**: Running a central orchestrator in a Kubernetes-based environment can be costly. +Maestro reduces infrastructure and maintenance costs by leveraging a relational database and optimized content delivery mechanisms. + +**Improve Feedback Loop**: Traditional Kubernetes solutions have limitations in the feedback loop, +making it difficult to observe the state of resources effectively. +Maestro addresses this by providing a robust feedback loop mechanism, +ensuring that resource status is continuously updated and monitored. + +**Improve Security Architecture**: Maestro enhances security by eliminating the need for kubeconfigs, +reducing the need for direct access to clusters. + ## Run for the first time ### Make a build, run postgres and mqtt broker From 4207cd14e58bea4ca9fe111c1f361e13e0e5534e Mon Sep 17 00:00:00 2001 From: "red-hat-konflux[bot]" <126015336+red-hat-konflux[bot]@users.noreply.github.com> Date: Tue, 28 May 2024 10:04:52 +0800 Subject: [PATCH 2/2] Update docker.io/library/postgres Docker tag to v16 (#83) Co-authored-by: red-hat-konflux <123456+red-hat-konflux[bot]@users.noreply.github.com> Co-authored-by: Chunlin Yang --- .tekton/integration-test.yaml | 2 +- .tekton/unit-test.yaml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.tekton/integration-test.yaml b/.tekton/integration-test.yaml index 3b2cebb0..176ee17b 100644 --- a/.tekton/integration-test.yaml +++ b/.tekton/integration-test.yaml @@ -104,7 +104,7 @@ spec: ) echo -n "$TEST_OUTPUT" | tee $(results.TEST_OUTPUT.path) sidecars: - - image: docker.io/library/postgres:14.2 + - image: docker.io/library/postgres:16.3 name: database-test env: - name: PGDATA diff --git a/.tekton/unit-test.yaml b/.tekton/unit-test.yaml index b168bd85..0678c003 100644 --- a/.tekton/unit-test.yaml +++ b/.tekton/unit-test.yaml @@ -104,7 +104,7 @@ spec: ) echo -n "$TEST_OUTPUT" | tee $(results.TEST_OUTPUT.path) sidecars: - - image: docker.io/library/postgres:14.2 + - image: docker.io/library/postgres:16.3 name: database-test env: - name: PGDATA