This project contains a Serverless Python function for running MySQL.
Follow the instructions how to setup MySQL on Kubernetes and run the function with OpenFaaS.
Run Kubernetes locally or on your virtual machine. You can do this with minikube start
.
Set the OPENFAAS_URL
environmental variable to http://<kubernetes_ip>:31112
.
If you're running Kubernetes with Minikube, you can check the value with
minikube ip
Then use helm to install MySQL.
helm install stable/mysql
After the installation you will find instructions how to connect to your MySQL server in the heml install
output.
Note: MySQL can be accessed via port
3306
on the following DNS name from within your cluster:<output_value_from_helm_install.default.svc.cluster.local>
To get your root password run:
MYSQL_ROOT_PASSWORD=$(kubectl get secret --namespace default \<output_value_from_helm_install\> -o jsonpath="{.data.mysql-root-password}" | base64 --decode; echo)
Run an Ubuntu pod that you can use as a client:
kubectl run -i --tty ubuntu --image=ubuntu:16.04 --restart=Never -- bash -il
Install the MySQL client:
$ apt-get update && apt-get install mysql-client -y
Connect using the MySQL CLI, then provide your password:
$ mysql -h <output_value_from_helm_install> -p
To connect to your database directly from outside the K8s cluster:
MYSQL_HOST=127.0.0.1
MYSQL_PORT=3306
Execute the following commands to route the connection:
export POD_NAME=$(kubectl get pods --namespace default -l "app=<output_value_from_helm_install>" -o jsonpath="{.items[0].metadata.name}")
kubectl port-forward $POD_NAME 3306:3306 &
Note: Do not forget to run
kubectl port-forward $POD_NAME 3306:3306
in background with&
, which is missing in thehelm install
output.
Connect with
mysql -h ${MYSQL_HOST} -P${MYSQL_PORT} -u root -p${MYSQL_ROOT_PASSWORD}
Once you have access to your MySQL Server, you can use the MySQL CLI to import data.
Create database with:
CREATE DATABASE demo;
USE demo;
Now create a table in the database:
CREATE TABLE `meetup_users` (
`id` INT UNSIGNED PRIMARY KEY AUTO_INCREMENT NOT NULL,
`name` VARCHAR(50) NOT NULL,
`email` VARCHAR(50) NOT NULL,
`date_of_birth` DATE NOT NULL,
`city` VARCHAR(80) NOT NULL,
KEY (`id`)
) ENGINE=InnoDB;
Insert some data into the table:
INSERT INTO meetup_users
(`name`, `email`, `date_of_birth`, `city`)
VALUES
("John", "jdoe@gmail.com", "1986-07-06", "Munich"),
("Tatiana", "tania@yahoo.com", "1993-03-14", "Moscow"),
("Frea", "frs@gmail.com", "2000-12-30", "Copenhagen"),
("Xavier", "xavier@yahoo.com", "1972-10-25", "Paris");
Copy env.example.yml
to env.yml
and replace 127.0.0.1
with <output_value_from_helm_install.default.svc.cluster.local>
.
Replace docwareiy
in the stack.yml
file with your own Docker Hub username.
Setup secret
mkdir -p ~/secrets && /
echo $(MYSQL_ROOT_PASSWORD) > ~/secrets/secret_mysql_key.txt && /
kubectl create secret generic secret-mysql-key --from-file=secret-mysql-key=$HOME/secrets/secret_mysql_key.txt --namespace openfaas-fn
You can find more about using secrets with OpenFaaS in the official Documentation.
Build and push the function:
$ faas build && faas push && faas deploy
Note: You need
faas-cli
version0.6.11
or newer.
Now we have the mysql function. Let's test it.
Invoke the function with:
echo "" | curl http://192.168.99.100:31112/function/mydb --header 'Query: {"action": "select"}'
You should see the following result:
[
{'id': 1, 'name': 'John', 'email': 'jdoe@gmail.com', 'date_of_birth': datetime.date(1986, 7, 6), 'city': 'Munich'},
{'id': 2, 'name': 'Tatiana', 'email': 'tania@yahoo.com', 'date_of_birth': datetime.date(1993, 3, 14), 'city': 'Moscow'},
{'id': 3, 'name': 'Frea', 'email': 'frs@gmail.com', 'date_of_birth': datetime.date(2000, 12, 30), 'city': 'Copenhagen'},
{'id': 4, 'name': 'Xavier', 'email': 'xavier@yahoo.com', 'date_of_birth': datetime.date(1972, 10, 25), 'city': 'Paris'}
]
Now insert a new row:
echo "" | curl http://192.168.99.100:31112/function/mydb --header 'Query: {"action": "insert", "values": ["Martin", "martin@gmail.com", "1998-10-30", "Sofia"]}''
Result:
['Insert done']
Check if the insert worked as expected:
echo "" | curl http://192.168.99.100:31112/function/mydb --header 'Query: {"action": "select"}'
Result:
[
{'id': 1, 'name': 'John', 'email': 'jdoe@gmail.com', 'date_of_birth': datetime.date(1986, 7, 6), 'city': 'Munich'},
{'id': 2, 'name': 'Tatiana', 'email': 'tania@yahoo.com', 'date_of_birth': datetime.date(1993, 3, 14), 'city': 'Moscow'},
{'id': 3, 'name': 'Frea', 'email': 'frs@gmail.com', 'date_of_birth': datetime.date(2000, 12, 30), 'city': 'Copenhagen'},
{'id': 4, 'name': 'Xavier', 'email': 'xavier@yahoo.com', 'date_of_birth': datetime.date(1972, 10, 25), 'city': 'Paris'},
{'id': 5, 'name': 'Martin', 'email': 'martin@gmail.com', 'date_of_birth': datetime.date(1998, 10, 30), 'city': 'Sofia'}
]