For some time now, I've been exploring ways to modernize my machine learning journey, starting from my master's dissertation on gravitational wave detection using neural networks. One of my primary objectives was to create and orchestrate machine learning models and algorithms efficiently.
In the context of this project, think of a machine learning algorithm as an application that takes some data as input, learns from that data during training, and can then make predictions when new data is fed into it. The machine learning model represents the output of this entire process.
- Objective
- Versioning Flow
- Tools
- Getting Started
- Requirements
- Usage
- Project Structure
- Troubleshooting
- Contributions
- License
- Contact
- Acknowledgments
In the realm of machine learning, orchestrating the training and deployment of models can be a complex task. This project aims to streamline and automate the end-to-end machine learning process, encompassing data ingestion, data processing, model training with hyperparameter optimization, experiment tracking, model evaluation, and model deployment in the context of gravitational wave detection using neural networks.
We follow the Semantic Versioning and gitflow for versioning this project. For the versions available, see the tags on this repository.
The following tools are used in this project:
-
Terraform: Infrastructure-as-Code tool used to automate the setup of the Kubernetes cluster and related resources.
-
Kubernetes (kind): A lightweight Kubernetes implementation that allows running Kubernetes clusters inside Docker containers.
-
MetalLB: A Load Balancer for Kubernetes environments, enabling external access to services in the local environment.
-
ArgoCD: A GitOps Continuous Delivery tool for Kubernetes, facilitating the management of applications.
-
Traefik: An Ingress Controller for Kubernetes, routing external traffic to applications within the cluster.
-
Cert-Manager: A certificate management tool, enabling the use of HTTPS for applications.
-
Keycloak: An identity management and access control service, securing applications and resources.
-
Minio: A cloud storage server compatible with Amazon S3, providing object storage for applications.
-
Postgres: A relational database used to store application data.
-
MLflow: A Machine Learning lifecycle management platform, simplifying the deployment and tracking of ML models.
-
JupyterHub: A multi-user Jupyter environment, allowing users to write and share code collaboratively.
-
Airflow: An open-source platform to programmatically author, schedule, and monitor workflows.
-
Spark: An open-source, distributed computing system that provides an interface for programming entire clusters with implicit data parallelism and fault tolerance.
-
Ray: An open-source distributed computing framework that brings the power of Python to distributed computing.
These tools together enable the creation of a complete infrastructure for the development and management of Machine Learning applications in the Kubernetes environment.
To use ML Model Orchestration, you need to have the following prerequisites installed and configured:
- Terraform:
- Installation: Visit the Terraform website and follow the instructions for your operating system.
- Docker:
- Installation: Install Docker by following the instructions for your operating system from the Docker website.
- Kubernetes CLI (kubectl):
- Installation: Install
kubectl
by following the instructions for your operating system from the Kubernetes website.
- Installation: Install
- Helm:
- Installation: Install Helm by following the instructions for your operating system from the Helm website.
To get started with the MLflow POC, follow these steps:
- Clone this repository to your local computer.
git clone https://github.com/GersonRS/data-engineering-for-machine-learning
- Change directory to the repository:
cd data-engineering-for-machine-learning
Make sure you have Terraform installed on your system, along with other necessary dependencies.
- Run
terraform init
to initialize Terraform configurations.
terraform init
This command will download the necessary Terraform plugins and modules.
- Run
terraform apply
to start the provisioning process. Wait until the infrastructure is ready for use.
terraform apply
Review the changes to be applied and confirm with yes when prompted. Terraform will now set up the Kubernetes cluster and deploy the required resources.
- After the Terraform apply is complete, the output will display URLs for accessing the applications. Use the provided URLs to interact with the applications.
- The Terraform output will also provide the credentials necessary for accessing and managing the applications. Run
terraform output
to get the credentials.
terraform output -json
Once the infrastructure is successfully provisioned, you can utilize the installed applications, including MLflow, to track and manage your Machine Learning experiments. Access the applications through the provided URLs and log in using the credentials generated during setup. Follow these steps to utilize the Proof of Concept (PoC):
-
Access the JupyterHub URL: After the infrastructure is provisioned using Terraform, you will receive the JupyterHub URL as an output. Open a web browser and navigate to this URL.
-
Log in to JupyterHub: On the JupyterHub login page, click on "Sign in with Keycloak." Use the credentials provided in the output of the Terraform apply command, as mentioned in step 6 of the previous section.
-
Access Jupyter Notebook: Upon successful login, you will have access to a Jupyter Notebook environment. Locate the "/opt/bitnami/jupyterhub-singleuser" directory within the Jupyter environment.
-
Upload Files: Upload the files from the "code" folder of this repository into the "/opt/bitnami/jupyterhub-singleuser" directory.
-
Execute "main.ipynb": Open the "main.ipynb" Jupyter Notebook file and execute it. This notebook contains the necessary code to initiate the Proof of Concept.
-
Monitor Experiment in MLflow: Upon execution of the notebook, the MLflow experiment will be initiated. To monitor the experiment, access the MLflow URL provided in the output of the Terraform apply command. This URL will allow you to track and analyze the results of the PoC.
Please note that these steps provide a high-level overview of the usage process. Ensure you have met all the requirements mentioned in the "Requirements" section before proceeding with the above steps. Additionally, refer to the provided documentation and comments within the code for any further instructions or configurations.
If you encounter any problems, refer to the Troubleshooting section for potential solutions to common issues that may arise during the setup and usage of the PoC.
To definitively stop the cluster on a single command (that is the reason we delete some resources from the state file), you can use the following command:
terraform state rm $(terraform state list | grep "argocd_application\|argocd_project\|kubernetes_\|helm_\|keycloak_") && terraform destroy
A dirtier alternative is to directly destroy the Docker containers and volumes (replace kind-cluster by the cluster name you defined in locals.tf):
# Stop and remove Docker containers
docker container stop kind-cluster-control-plane kind-cluster-worker{,2,3} && docker container rm -v kind-cluster-control-plane kind-cluster-worker{,2,3}
# Remove the Terraform state file
rm terraform.state
Or delete the cluster directly by kind
kind delete cluster
This project follows a structured directory layout to organize its resources effectively:
.
├── LICENSE
├── locals.tf
├── main.tf
├── modules
│ ├── argocd
│ ├── cert-manager
│ ├── jupyterhub
│ ├── keycloak
│ ├── kind
│ ├── kube-prometheus-stack
│ ├── metallb
│ ├── minio
│ ├── mlflow
│ ├── oidc
│ ├── postgresql
│ └── traefik
├── outputs.tf
├── README.md
├── terraform.tf
└── variables.tf
15 directories, 83 files
- charts - Directory containing all the helm charts used in the project.
- LICENSE - License file of the project.
- locals.tf - Terraform locals file.
- main.tf - Main Terraform configuration file.
- modules - Directory containing all the Terraform modules used in the project.
- argocd - Directory for configuring ArgoCD application.
- cert-manager - Directory for managing certificates using Cert Manager.
- jupyterhub - Directory for setting up JupyterHub application.
- keycloak - Directory for installing and configuring Keycloak.
- kind - Directory for creating a Kubernetes cluster using Kind.
- metallb - Directory for setting up MetalLB, a load balancer for Kubernetes.
- minio - Directory for deploying and configuring Minio for object storage.
- mlflow - Directory for setting up MLflow, a machine learning lifecycle management platform.
- oidc - Directory for OpenID Connect (OIDC) configuration.
- postgresql - Directory for deploying and configuring PostgreSQL database.
- traefik - Directory for setting up Traefik, an ingress controller for Kubernetes.
- outputs.tf - Terraform outputs file.
- pyproject.toml - Poetry config.
- README.md - Project's README file, containing important information and guidelines.
- terraform.tf - Terraform configuration file for initializing the project.
- variables.tf - Terraform variables file, containing input variables for the project.
In some cases, you could encounter an error like this the first deployment:
╷
│ Error: Error while waiting for application argocd to be created
│
│ with module.argocd.argocd_application.this,
│ on .terraform/modules/argocd/main.tf line 55, in resource "argocd_application" "this":
│ 55: resource "argocd_application" "this" {
│
│ error while waiting for application argocd to be synced and healthy: rpc error: code = Unavailable desc = connection error: desc = "transport: error while dialing: dial tcp 127.0.0.1:45729: connect: connection refused"
╵
This error is due to the way we provision Argo CD on the final steps of the deployment. We use the bootstrap Argo CD to deploy the final Argo CD module, which causes a redeployment of Argo CD and consequently a momentary loss of connection between the Argo CD Terraform provider and the Argo CD server.
You can simply re-run the command terraform apply to finalize the bootstrap of the cluster.
You could stumble upon loki-stack-promtail stuck in a creation loop with the following logs:
level=error ts=2023-05-09T06:32:38.495673778Z caller=main.go:117 msg="error creating promtail" error="failed to make file target manager: too many open files"
Stream closed EOF for loki-stack/loki-stack-promtail-bxcmw (promtail)
If that’s the case, you will have to increase the upper limit on the number of INotify instances that can be created per real user ID:
# Increase the limit until next reboot
sudo sysctl fs.inotify.max_user_instances=512
# Increase the limit permanently (run this command as root)
echo 'fs.inotify.max_user_instances=512' >> /etc/sysctl.conf
If you encounter a login error, specifically an error 500, while attempting to access JupyterHub, follow these steps to resolve the issue:
-
Access MinIO Storage: In case of a login error, navigate to the MinIO Storage using the provided MinIO URL available in the Terraform output.
-
Single Sign-On (SSO) Login: Log in to MinIO using the Single Sign-On (SSO) credentials. This will establish a session that will allow you to successfully log in to other components.
-
Return to JupyterHub: After successfully logging in to MinIO, return to the JupyterHub login page.
-
Refresh the Page: Refresh the JupyterHub page. This will complete the login process, and you should now have access to the Jupyter Notebook environment.
This troubleshooting procedure is specifically designed to address login errors that result in an error 500 when accessing JupyterHub. By logging in to MinIO using SSO and refreshing the JupyterHub page, you can resolve the issue and continue with the usage of the Proof of Concept.
If you continue to experience login issues or encounter other technical difficulties, please refer to the provided documentation, check for any additional error messages, and ensure that you have followed all the prerequisites and setup instructions accurately.
Sometimes, during the installation of Python libraries in Jupyter Notebook, you may encounter an issue where the kernel does not recognize the appropriate environment. To resolve this problem, follow these steps:
- Select the Correct Kernel:
When working with Jupyter Notebook, ensure that you are using the correct kernel corresponding to the specific Python environment you intend to use. To do this, follow these steps:
-
a. Click on the "Kernel" option in the Jupyter Notebook toolbar.
-
b. Choose the "Change Kernel" option.
-
c. A dropdown menu will appear showing available kernels. Click on the option that corresponds to the name of the notebook you are working on, such as "main.ipynb" for the "main.ipynb" notebook.
-
d. The notebook will now use the selected kernel, ensuring that the required Python libraries are properly recognized and utilized.
By selecting the appropriate kernel, you can ensure that the Python libraries required for your specific notebook are correctly installed and utilized, mitigating any potential issues related to library compatibility or recognition.
If you encounter any other issues or difficulties while using the Proof of Concept, refer to this "Troubleshooting" section for solutions to common problems. If the problem persists or if you experience unique challenges, consider consulting the provided documentation or seeking assistance from the community.
Contributions are welcome! Feel free to create a pull request with improvements, bug fixes, or new features. Contributions are what make the open source community an amazing place to learn, inspire, and create. Any contribution you make will be greatly appreciated.
To contribute to the project, follow the steps below:
- Fork the project.
- Create a branch for your contribution (git checkout -b feature-mycontribution).
- Make the desired changes to the code.
- Commit your changes (git commit -m 'MyContribution: Adding new feature').
- Push the branch to your Fork repository (git push origin feature-mycontribution).
- Open a Pull Request on the main branch of the original project. Describe the changes and wait for the community's review and discussion.
We truly value your interest in contributing to the MLflow-Kube project. Together, we can make it even better!
This project is licensed under the MIT License - see the LICENSE file for details.
For any inquiries or questions, please contact:
We appreciate your interest in using ML Model Orchestration on Kubernetes. We hope this configuration simplifies the management of your Machine Learning experiments on Kubernetes! 🚀📊