In this project, we will create a Django web application connected to a MySQL database and deploy them on Kubernetes using Minikube. This process involves the creation of deployment files and services. To handle environment variables, we'll employ Kubernetes secrets. Additionally, We will expose the Django application using nginx ingress .
Ensure that you have the following prerequisites installed on your system:
- Clone this repository to your local machine:
git clone https://github.com/Harasisco/K8s-Django-App.git
cd K8s-Django-App
- Start Minikube from a terminal with administrator access (but not logged in as root):
minikube start
- Enable the NGINX Ingress controller:
minikube addons enable ingress
Verify that the NGINX Ingress controller is running:
kubectl get pods -n ingress-nginx
You will see something like thie:
NAME READY STATUS RESTARTS AGE
ingress-nginx-admission-create-dm92w 0/1 Completed 0 66s
ingress-nginx-admission-patch-zmqwz 0/1 Completed 1 66s
ingress-nginx-controller-7c6974c4d8-z9xfj 1/1 Running 0 66s
- Create our custom namespaces:
kubectl create namespace development
kubectl create namespace database
-
Deploy the MySQL database:
- Start with our service and secret environment file:
kubectl create -f mysql-service.yaml kubectl create -f mysql-secret.yaml
- Then deploy the MySQL database:
kubectl create -f mysql-deploy.yaml
- Check if the MySQL database started correctly:
kubectl get pods,svc -n database kubectl logs pod/mysql-deploy-79c5dd7699-b52h6 -n database
-
Deploy the Django app:
- Start with our service and secret environment file:
kubectl create -f web_app_secret.yaml kubectl create -f web_app_service.yaml
- Create our ingress-nginx Port Forwarder:
kubectl create -f web_app_ingress.yaml
- Deploy the Django app:
Before deploying the web app, make sure everything before is working correctly
kubectl create -f web_app_deploy.yaml
-
Verify that the Ingress controller is directing traffic:
curl --resolve "hello-world.info:80:$( minikube ip )" -i http://hello-world.info
You will get something like this:
<h1>Hello, World!</h1>
For additional insight into your cluster state, minikube bundles the Kubernetes Dashboard, allowing you to get easily acclimated to your new environment:
make sure to run this command in new tab
minikube dashboard
- Firstly execute the MySQL pod using:
kubectl exec -it mysql-deploy-79c5dd7699-b52h6 -n database -- /bin/bash
- Secondery check the MySQL data base info:
$ mysql -p
> show databases;
> use my_database;
> show tables;
-
You will see that No tables shown.
-
In a new tab execute the Django pod same as what we did with the MySQL pod, then:
kubectl exec -it django-app-deploy-7df69494dd-tn72r -n development -- /bin/bash
cd mysite/
python manage.py migrate
You will get this:
$ kubectl exec -it django-app-deploy-7df69494dd-tn72r -n development -- /bin/bash
root@django-app-deploy-7df69494dd-tn72r:/code# cd mysite/
root@django-app-deploy-7df69494dd-tn72r:/code/mysite# python manage.py migrate
Operations to perform:
Apply all migrations: admin, auth, contenttypes, sessions
Running migrations:
Applying contenttypes.0001_initial... OK
Applying auth.0001_initial... OK
Applying admin.0001_initial... OK
Applying admin.0002_logentry_remove_auto_add... OK
Applying admin.0003_logentry_add_action_flag_choices... OK
Applying contenttypes.0002_remove_content_type_name... OK
Applying auth.0002_alter_permission_name_max_length... OK
Applying auth.0003_alter_user_email_max_length... OK
Applying auth.0004_alter_user_username_opts... OK
Applying auth.0005_alter_user_last_login_null... OK
Applying auth.0006_require_contenttypes_0002... OK
Applying auth.0007_alter_validators_add_error_messages... OK
Applying auth.0008_alter_user_username_max_length... OK
Applying auth.0009_alter_user_last_name_max_length... OK
Applying auth.0010_alter_group_name_max_length... OK
Applying auth.0011_update_proxy_permissions... OK
Applying auth.0012_alter_user_first_name_max_length... OK
Applying sessions.0001_initial... OK
root@django-app-deploy-7df69494dd-tn72r:/code/mysite#
- Finally, Go back to the MySQL tab and rerun the
show tables;
command to figoure out that the Django spp and MySQL database are linked correctly.
Kubernetes secrets serve as a secure vault for confidential data like passwords and API keys that applications need to operate. They offer a protective layer against exposing sensitive information directly in code or configuration files, reducing the risk of unauthorized access. By storing secrets separately in Kubernetes, we enhance security, ensuring that only authorized entities can access and manage this critical information. This separation of concerns not only fortifies the application against potential security breaches but also simplifies the management of sensitive data in a scalable and efficient manner.
Ingress is an API object that defines rules for how external traffic should be routed to services. The NGINX Ingress Controller interprets these Ingress rules and configures the NGINX server accordingly.