This morning, like a lot of the Docker community, I receieved an email I had been waiting for since November, confirmation that Kubernetes on Docker for Mac had made its way through to a public edge release.

text

The version of Docker I was running was on the stable channel;

graphical user interface, text, application

The first thing I did was open up the preferences;

graphical user interface, text, application, email

and used the switch to edge link in there to go straight to the Docker for Mac download page;

graphical user interface, text, application, email, website

Once there, I clicked on the Get Docker for Mac (Edge) button which went onto download the latest disk image, once downloaded I double clicked it and was presented with the drag & drop installer;

text, website

I quit Docker, and dragged the Docker application to my Applications folder. Once it had copied across I reopened Docker which gave me the following warning;

graphical user interface, text, application

I was fine with that, so clicked on Reset and Restart, to be able to do this Docker needed my password;

graphical user interface, text, application

After a few minutes, Docker for Mac started up, the first thing I did was open the About Docker window to confirm the version;

graphical user interface, application

As you can see, this window now shows the version numbers of all of the Docker components installed and available. What we are insterested in is Kubernetes v.1.8.2. I also checked the version on the command line using the Docker client ;

Docker + Kubernetes 1/14
$ docker version
$ docker-compose version
$ docker-machine version

text

As you can see from the results above, everything matched. So lets take a look at Kubernetes, which by default is disabled.

To enable Kubernetes open the preferences and click on the Kubernetes icon;

graphical user interface, text, application, email

Once in there tick Enable Kubernetes and then click on the Apply button;

graphical user interface, text, application

This will present you with a message informing you that Docker will need a few minutes to install and configure the cluster, as well as an internet connection so it can download the compoents.

graphical user interface, text, application

After a few minutes you should see the following message;

graphical user interface, text, application

Docker for Mac also installs the Kubernetes command line client, kubectl, you can check this is installed by running;

Docker + Kubernetes 2/14
$ kubectl version

text

Running the following command will give you information about the nodes running in your Kubernetes cluster, we should see just the one;

Docker + Kubernetes 3/14
$ kubectl get nodes

graphical user interface, text, application, chat or text message

Now that we have a single node cluster up and running lets dig a little deeper into how Docker have done their deployment. You may remember in the Kubernetes preferences pane there is an option which allows you to Show system containers, tick this and click Apply;

graphical user interface, text, application

Running the following command will list of the running containers, but only show the container name, image used and the command which was executed;

Docker + Kubernetes 4/14
$ docker container ls --format "table{{.Names}}\t{{.Image }}\t{{.Command}}"

You can see the results below;

text

One thing to note is that only one of the container images is from Docker themselves, the rest are from Google. You can find out more information on how these images are built at the following page;

kubernetes/kubernetes

We can find out a little more on the installation itself by running the following commands;

Docker + Kubernetes 5/14
$ kubectl get namespaces
$ kubectl get pods --namespace kube-system

As you can see from the terminal output below, this lists all of the pods which containers below belong to;

text

The one service which is missing is the Kubernetes Dashboard, this would be a good excuse to install it.

Installing the Dashboard is quite a simple task, running the following command will deploy it your Kubernetes cluster;

Docker + Kubernetes 6/14
$ kubectl create -f https://raw.githubusercontent.com/kubernetes/dashboard/master/src/deploy/recommended/kubernetes-dashboard.yaml

After a minute or two you should be able to run the following commands to view the deployments and services running in the kube-system namespace;

Docker + Kubernetes 7/14
$ kubectl get deployments --namespace kube-system
$ kubectl get services --namespace kube-system

text

Now that the Dashboard is running you can access it through the proxy service provided by kubectl, to start this service simply run;

Docker + Kubernetes 8/14
$ kubectl proxy

text

Once the proxy has started open the following URL in your browser;

http://localhost:8001/api/v1/namespaces/kube-system/services/https:kubernetes-dashboard:/proxy/

This should show you a login page;

graphical user interface, text, application, email

As we are connected via the proxy we do not need to sign in using either Kubeconfig or with a Token, so just press Skip, this will take you straight to the Dashboard;

graphical user interfacegraphical user interface

Docker also provide an example application, lets take a look at deploying it.

The Docker Compose file, yes you read that right we are going be using Docker Compose, looks like the following;

Docker + Kubernetes 9/14
version: '3.3'

services:
  web:
    build: web
    cover:
    image: dockerdemos/lab-web
    volumes:
     - "./web/static:/static"
    ports:
     - "80:80"

  words:
    build: words
    cover:
    image: dockerdemos/lab-words
    deploy:
      replicas: 5
      endpoint_mode: dnsrr
      resources:
        limits:
          memory: 16M
        reservations:
          memory: 16M

  db:
    build: db
    cover:
    image: dockerdemos/lab-db

Running the following command;

Docker + Kubernetes 10/14
$ docker stack deploy --compose-file stack.yml demo

Will launch a demo application which was origininally used during European DockerCon 17.

text

Once the stack is stable and running you can check run;

Docker + Kubernetes 11/14
$ kubectl get pods

a screenshot of a computer

As you can see, this has launched several pods, we can also check the deployment and services by running;

Docker + Kubernetes 12/14
$ kubectl get deployments
$ kubectl get services

text

As you see, the web service has a type of LoadBalancer, while the Exteral-IP address is shown as you should be able to open your browser and go to http://localhost/ where you should be able to see the demo application;

graphical user interface

Running the following command will stop and remove the example service;

Docker + Kubernetes 13/14
$ docker stack remove demo

If you want to remove the Kubernetes Dashboard you can run;

Docker + Kubernetes 14/14
$ kubectl delete deployment kubernetes-dashboard --namespace kube-system

As you can see, Kubernetes on Docker for Mac is quite straight forward, and so far I have to say I much prefer it to running Minikube , having everything all in a single place really makes things straight foward.