Final
This commit is contained in:
commit
54450daee7
47
README.md
Normal file
47
README.md
Normal file
@ -0,0 +1,47 @@
|
||||
# My Web Application
|
||||
|
||||
## Project Description
|
||||
|
||||
This project is a simple web application that provides a user interface to manage a MySQL database. The application consists of a single page that allows the user to perform basic CRUD operations on a list of items stored in the database.
|
||||
Containers
|
||||
|
||||
## The application consists of the following containers:
|
||||
|
||||
mysql: This container runs the MySQL database server.
|
||||
web: This container runs the web server and serves the web pages to the user.
|
||||
|
||||
|
||||
## The following Kubernetes objects are used in the application:
|
||||
|
||||
PersistentVolume: This object is used to create a named volume for the MySQL data.
|
||||
StatefulSet: This object is used to manage the mysql container and ensure that there is only one instance running at any given time.
|
||||
Deployment: This object is used to manage the web container and ensure that there is always at least one instance running.
|
||||
Service: This object is used to provide access to the mysql and web containers from outside the Kubernetes cluster.
|
||||
|
||||
## Virtual Networks and Named Volumes
|
||||
|
||||
The application uses a virtual network to allow communication between the mysql and web containers. The mysql container stores its data in a named volume called mysql-persistent-storage.
|
||||
|
||||
## Container Configuration
|
||||
|
||||
The mysql container is configured to use the mysql-persistent-storage volume for data storage. The web container is configured to connect to the mysql container using the Kubernetes service mysql.
|
||||
|
||||
## To run the application, perform the following steps:
|
||||
|
||||
1. Install Kubernetes on your machine.
|
||||
2. Install azure-cli: curl -sL https://aka.ms/InstallAzureCLIDeb | sudo bash
|
||||
3. Clone the project repository.
|
||||
4. Change into the project directory.
|
||||
4. Login in Azure: az login
|
||||
4. Execute "./prepare-app.sh" make sure it have execution permission.
|
||||
5. Wait for the mysql and web containers to start.
|
||||
|
||||
## To view the application on the web, perform the following steps:
|
||||
|
||||
Copy the IP address at the end of the prepare-app.sh file execution.
|
||||
In your web browser, navigate to http://<web-service-ip>.
|
||||
|
||||
|
||||
## To clean up the application, perform the following steps:
|
||||
|
||||
Execute "./remove-app.sh" make sure it have execution permission.
|
25
deployment.yaml
Normal file
25
deployment.yaml
Normal file
@ -0,0 +1,25 @@
|
||||
apiVersion: apps/v1
|
||||
kind: Deployment
|
||||
metadata:
|
||||
name: phpmyadmin
|
||||
namespace: ibanweb
|
||||
spec:
|
||||
selector:
|
||||
matchLabels:
|
||||
app: phpmyadmin
|
||||
replicas: 1
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: phpmyadmin
|
||||
spec:
|
||||
containers:
|
||||
- name: phpmyadmin
|
||||
image: phpmyadmin/phpmyadmin:latest
|
||||
env:
|
||||
- name: PMA_HOST
|
||||
value: mysql
|
||||
ports:
|
||||
- containerPort: 80
|
||||
name: http
|
||||
|
4
namespace.yaml
Normal file
4
namespace.yaml
Normal file
@ -0,0 +1,4 @@
|
||||
apiVersion: v1
|
||||
kind: Namespace
|
||||
metadata:
|
||||
name: ibanweb
|
41
prepare-app.sh
Executable file
41
prepare-app.sh
Executable file
@ -0,0 +1,41 @@
|
||||
#!/bin/bash
|
||||
|
||||
#!/bin/bash
|
||||
|
||||
# Set variables
|
||||
resourceGroupName="iban-app"
|
||||
aksClusterName="ibanapp"
|
||||
nodeCount=1
|
||||
|
||||
# Create resource group if it does not exist
|
||||
if [ $(az group exists --name $resourceGroupName) == "false" ]
|
||||
then
|
||||
az group create --name $resourceGroupName --location eastus
|
||||
fi
|
||||
|
||||
|
||||
az aks create --resource-group $resourceGroupName --name $aksClusterName --node-count $nodeCount --generate-ssh-keys
|
||||
|
||||
|
||||
az aks get-credentials --resource-group $resourceGroupName --name $aksClusterName
|
||||
kubectl config use-context $aksClusterName
|
||||
|
||||
|
||||
# create namespace
|
||||
kubectl apply -f namespace.yaml
|
||||
|
||||
# create mysql secrets
|
||||
kubectl create secret generic mysql-secret --from-literal=password=dromedario -n ibanweb
|
||||
|
||||
# create mysql statefulset and service
|
||||
kubectl apply -f statefulset.yaml
|
||||
kubectl apply -f service.yaml
|
||||
|
||||
# create phpmyadmin deployment
|
||||
kubectl apply -f deployment.yaml
|
||||
|
||||
# expose phpmyadmin deployment
|
||||
kubectl expose deployment phpmyadmin --type=LoadBalancer --port=80 --target-port=80 -n ibanweb
|
||||
|
||||
# Get the public IP address of the Kubernetes service
|
||||
kubectl get service phpmyadmin -n ibanweb -o jsonpath='{.status.loadBalancer.ingress[0].ip}'
|
14
remove-app.sh
Executable file
14
remove-app.sh
Executable file
@ -0,0 +1,14 @@
|
||||
#!/bin/bash
|
||||
|
||||
# delete app objects
|
||||
kubectl delete -f deployment.yaml
|
||||
kubectl delete -f service.yaml
|
||||
kubectl delete -f statefulset.yaml
|
||||
kubectl delete secret mysql-secret -n ibanweb
|
||||
kubectl delete namespace ibanweb
|
||||
|
||||
# Eliminar recurso AKS
|
||||
az aks delete --name ibanapp --resource-group iban-app --yes
|
||||
|
||||
# Eliminar recurso de grupo de recursos
|
||||
az group delete --name iban-app --yes
|
8
secret.yaml
Normal file
8
secret.yaml
Normal file
@ -0,0 +1,8 @@
|
||||
apiVersion: v1
|
||||
kind: Secret
|
||||
metadata:
|
||||
name: mysql-secret
|
||||
namespace: ibanweb
|
||||
type: Opaque
|
||||
data:
|
||||
password: YWxtZW5kcmE= #la contraseña es "almendra" en base64
|
12
service.yaml
Normal file
12
service.yaml
Normal file
@ -0,0 +1,12 @@
|
||||
apiVersion: v1
|
||||
kind: Service
|
||||
metadata:
|
||||
name: mysql
|
||||
namespace: ibanweb
|
||||
spec:
|
||||
ports:
|
||||
- name: mysql
|
||||
port: 3306
|
||||
selector:
|
||||
app: mysql
|
||||
|
53
statefulset.yaml
Normal file
53
statefulset.yaml
Normal file
@ -0,0 +1,53 @@
|
||||
apiVersion: v1
|
||||
kind: PersistentVolume
|
||||
metadata:
|
||||
name: my-pv
|
||||
spec:
|
||||
capacity:
|
||||
storage: 1Gi
|
||||
accessModes:
|
||||
- ReadWriteOnce
|
||||
persistentVolumeReclaimPolicy: Retain
|
||||
storageClassName: slow
|
||||
hostPath:
|
||||
path: /data/my-pv/
|
||||
---
|
||||
apiVersion: apps/v1
|
||||
kind: StatefulSet
|
||||
metadata:
|
||||
name: mysql
|
||||
namespace: ibanweb
|
||||
spec:
|
||||
selector:
|
||||
matchLabels:
|
||||
app: mysql
|
||||
serviceName: mysql
|
||||
replicas: 1
|
||||
template:
|
||||
metadata:
|
||||
labels:
|
||||
app: mysql
|
||||
spec:
|
||||
containers:
|
||||
- name: mysql
|
||||
image: mysql:latest
|
||||
env:
|
||||
- name: MYSQL_ROOT_PASSWORD
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: mysql-secret
|
||||
key: password
|
||||
ports:
|
||||
- containerPort: 3306
|
||||
name: mysql
|
||||
volumeMounts:
|
||||
- name: mysql-persistent-storage
|
||||
mountPath: /var/lib/mysql
|
||||
volumeClaimTemplates:
|
||||
- metadata:
|
||||
name: mysql-persistent-storage
|
||||
spec:
|
||||
accessModes: [ "ReadWriteOnce" ]
|
||||
resources:
|
||||
requests:
|
||||
storage: 1Gi
|
Loading…
Reference in New Issue
Block a user