From 8b4f2311e2f716610448b6051a5bce362c51e726 Mon Sep 17 00:00:00 2001 From: Gautam Prajapati Date: Tue, 23 Jun 2020 17:27:04 +0530 Subject: [PATCH] Update readme for current progress --- README.md | 27 +++++++++++++++++---------- 1 file changed, 17 insertions(+), 10 deletions(-) diff --git a/README.md b/README.md index 614f241..31b6b4e 100644 --- a/README.md +++ b/README.md @@ -1,23 +1,30 @@ # Celery-Kubernetes-Operator -A basic Celery operator to be written in Python. To be used to manage simple Celery applications on a Kubernetes cluster. To be built as a demo project to proposed EuroPython 2020 proposal. We'll be using open source [KOPF](https://github.com/zalando-incubator/kopf) framework to write this operator in Python. +A basic Celery operator written in Python. To be used to manage simple Celery applications on a Kubernetes cluster. It is being built as a demo project to proposed EuroPython 2020 proposal. With some minor tweaks, to be used in Grofers production as well in the future. This operator is being written with the help of [KOPF](https://github.com/zalando-incubator/kopf) framework open sourced by Zalando SE. # Project Scope -This project aims to have following things in place- -1. A Custom Resource Definition(CRD) to spec out a Celery deployment having these attributes - +The general idea is to bridge the gap between infrastructure and application developers where application developers can just spec out a simple celery deployment yaml and have to do nothing more than `kubectl apply -f `to spin up their own celery cluster. + +It aims to have following things in place- +1. A Custom Resource Definition(CRD) to spec out a Celery deployment having (but not limited to) these attributes - + - Celery image - Celery app module name - - Broker URL - - Worker Class(sync, gevent etc) - Queue name - Resource Constraints(lim_cpu, req_cpu, lim_mem, req_mem) - Log Level - - Number of threads - - Flower setup configuration(if any) + - Number of workers + - Concurrency + - Basic Flower setup configuration for monitoring 2. A custom controller implementation that registers and manages self-healing capabilities of custom Celery resource for these operations - - CREATE - Creates the Celery CRD resource along with exposing a native Service object for Flower - - UPDATE - Reads the CRD modifications and updates the running Celery resource appropriately(delete and re-create) - - DELETE - Deletes the resource and flower service + - CREATE - Creates the worker and flower deployments along with exposing a native Service object for Flower + - UPDATE - Reads the CRD modifications and updates the running deployments using RollingUpdate strategy + - DELETE - Deletes the custom resource and all the child deployments 3. Keep a watch on CPU/Memory metrics of resource pod and autoscale/downscale the number of workers on given constraints +# Current Progress + +1. `crd.yaml` to spec out a simple celery deployment available under `templates/` directory. +2. Create and update handlers are defined and act accordingly as custom resource is created and updated. Deletion works automagically, thanks to KOPF adopt functions. + # Directory Structure # Inspiration