Developing applications for Kubernetes using Docker for Mac
$echo `whoami`
data:image/s3,"s3://crabby-images/a6768/a676880fc55bd0d7b3558cc835919c39b0c2c5ed" alt=""
data:image/s3,"s3://crabby-images/58a76/58a765dd82c706d94c88d248dd7c3aa15ee8978b" alt=""
data:image/s3,"s3://crabby-images/bb8ce/bb8ce2dfe36eb5d77a80e7b1b0be0ad72be12d84" alt=""
Cloud Software Engineer at Cloudreach
Does anyone use Docker?
data:image/s3,"s3://crabby-images/f3c0a/f3c0a193f3386aa5a3d04f613fdfdfcaf4374e74" alt=""
Does anyone use Kubernetes?
data:image/s3,"s3://crabby-images/8f5a6/8f5a623ba32142a2cb99ab620ca74f19a98935bc" alt=""
Does Docker do Kubernetes?
data:image/s3,"s3://crabby-images/adb79/adb79656032c93f676572d740f312facf741900e" alt=""
YES. THEY. DO.
data:image/s3,"s3://crabby-images/dd5e2/dd5e25dd7d56ec5c6572a1311e709db2d6348f24" alt=""
data:image/s3,"s3://crabby-images/0e8d4/0e8d4a1a5e132138d0a618cd97fe78b97b10922f" alt=""
What does that even mean?
-
Use Kubernetes instead of Docker Swarm
-
Allow a 1 node local cluster
-
Add additional docker commands that play nice with Kubernetes
data:image/s3,"s3://crabby-images/9164b/9164b79f7372ba30f028c34b43ffd13f3df9575e" alt=""
Great, how do we start?
You already have it, if you have Docker installed
What Docker for Mac doesn't include...
-
Default Ingress Controller
-
Kubernetes Dashboard
-
Heapster
-
Storage Class
data:image/s3,"s3://crabby-images/d4896/d48965f156b59856641583afdfb4630e73de732d" alt=""
Don't worry, because you can add it to your cluster
data:image/s3,"s3://crabby-images/14819/14819ea58fac18428ed55d884d0635678821c78b" alt=""
But this will mess up my workflow
data:image/s3,"s3://crabby-images/b326e/b326e9eb846e08dc177394e1df084f74aca59971" alt=""
Why should I switch my workflow
data:image/s3,"s3://crabby-images/c2b57/c2b577f84bd6bbf2e0c918ec8a51ca85293c180a" alt=""
-
Speed
-
Modularity
-
Isolation
data:image/s3,"s3://crabby-images/568f2/568f2930fa49fa55007224ddaf912439f257afc0" alt=""
Unless....
data:image/s3,"s3://crabby-images/2b7d0/2b7d0c735d5741b12fa5f666bda6775d5ac666f3" alt=""
Why not Minikube?
- Single-node Kubernetes cluster inside a VM on your computer
- Allows you to use kubectl to access cluster for development purposes
- Test strategies on your computer instead of in the cloud
- Uses VirtualBox or xhyve driver
- Not bound to localhost
- You have to use minikube IPs
BUT
- docker stack deploy -c <docker-compose file> <name>
So how do I start
- kubectl create -f <kubernetes.yaml file>
- helm install <name of chart>
This is what I did before we start this demo….
- I installed the Kubernetes dashboard
- I installed the Nginx ingress controller
- Created a helm chart with values
- Downloaded images that I need ahead of time
https://github.com/troy0820/revconf
- Using local docker images to use in your cluster
- Deploying those local images to your cluster
- Use docker stack deploy command
- Using helm to manage our deployments
Demo Time
Revconf 2018
By Troy M. Connor
Revconf 2018
- 1,097