Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/k911/local-kubernetes-cluster-docker-for-mac
Create single-node local Kubernetes cluster with Docker for mac for development or testing purposes
https://github.com/k911/local-kubernetes-cluster-docker-for-mac
docker docker-for-mac kubernetes local-cluster macos
Last synced: about 1 month ago
JSON representation
Create single-node local Kubernetes cluster with Docker for mac for development or testing purposes
- Host: GitHub
- URL: https://github.com/k911/local-kubernetes-cluster-docker-for-mac
- Owner: k911
- License: mit
- Created: 2018-09-21T12:39:13.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2019-04-05T07:18:22.000Z (almost 6 years ago)
- Last Synced: 2024-11-11T19:42:18.754Z (3 months ago)
- Topics: docker, docker-for-mac, kubernetes, local-cluster, macos
- Size: 666 KB
- Stars: 0
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Local Kubernetes Cluster (macOS)
This guide allows you to run single-node Kubernetes cluster directly on your local machine, to try out Kubernetes or develop with it.
- [Installation](#installation)
- [Usage](#usage)
- [FAQ](#faq)
- [Deploying Kubernetes Dashboard](#kubernetes-dashboard)## Installation
0. Unless you're using Docker for mac already, uninstall everything regarding Docker and Kubernetes you've ever installed, e.g.:
- `brew uninstall docker docker-compose docker-machine minikube kubectl`
- Finder -> Applications -> remove Docker ToolboxIf you don't remove them and install Docker for mac, they'll be overridden anyway.
Remarks: Every container, volume, machine and image you've used will be lost.
1. Install or update "Docker for mac"
https://docs.docker.com/docker-for-mac/install/
Note: You always should keep your software up-to-date, but please ensure you've got version at least: "18.06.0-ce-mac70"
To check your version on macOS toolbar, click Docker icon data:image/s3,"s3://crabby-images/3ed13/3ed13dfce96de736f2a1ae59bf02f8f74eddbb93" alt="Docker Deamon icon" and select "About Docker"
data:image/s3,"s3://crabby-images/c7244/c7244540ced42a8aa3ba9ac7b178961e542532d1" alt="About Docker"
2. Once, you've installed successfully "Docker for mac" application:
Select: data:image/s3,"s3://crabby-images/3ed13/3ed13dfce96de736f2a1ae59bf02f8f74eddbb93" alt="Docker Deamon icon" -> Preferences -> data:image/s3,"s3://crabby-images/c70b7/c70b791005e6320cf146defadb9c494b7d361a1b" alt="Kubernetes icon"
Then check "Enable Kubernetes", select "Kubernetes" as default orchestrator and "Apply".
data:image/s3,"s3://crabby-images/a7148/a714877b9bb28192d163afc511f1cb594c192145" alt="Configured kubernetes"
3. This will display a message that the Kubernetes cluster needs to be intially installed using internet connection.
data:image/s3,"s3://crabby-images/52d55/52d55aec4f85b7e0eccd8c851a1805d9216ea19d" alt="Initial Kubernetes installation"
Click install.
3. Docker deamon and Kubernetes cluster will be ready in several minutes
data:image/s3,"s3://crabby-images/50601/50601013875260f4d45111e345536dd69e005131" alt="Wait for installation to end"
## Usage
- Commands in your terminal `docker`, `docker-machine`, `docker-compose`, `kubectl` are accessible again, after Docker for mac installation, so you continue using them as usual.
- You may need to update your local application environment variables from ip addresses like `192.168.99.100` to `localhost` or `host.docker.internal`.
- Changing context is now possible via data:image/s3,"s3://crabby-images/3ed13/3ed13dfce96de736f2a1ae59bf02f8f74eddbb93" alt="Docker Deamon icon" -> Kubernetes -> Select context
data:image/s3,"s3://crabby-images/f055d/f055d83d8c8141b3728e7be82fff12b645392c04" alt="Changing Kubernetes context"
## FAQ
### Previously I've used ip address 192.168.99.100 (or similar) to access docker applications in container and on host machine (e.g. macOS terminal)
- Use `host.docker.internal` hostname in containers
- Docker for mac exposes container ports locally, so in macOS terminal you have to use `localhost` or `127.0.0.1` to connect with them, but if you want to use the same address in container and in macOS you can execute following command to bind host `host.docker.internal` to local ip address:
```bash
echo "127.0.0.1 host.docker.internal" | sudo tee -a /etc/hosts
```- [Docker for mac documentation reference](https://docs.docker.com/docker-for-mac/networking/#there-is-no-docker0-bridge-on-macos)
### I've messed up something and kubectl won't response.
- Go to data:image/s3,"s3://crabby-images/3ed13/3ed13dfce96de736f2a1ae59bf02f8f74eddbb93" alt="Docker Deamon icon" -> Preferences -> Reset Kubernetes cluster. If Kubernetes won't restart in 5 minutes, you've to "Reset disk image", so every image, container and volume you've created will be lost.
## Kubernetes Dashboard
Kubernetes Dashboard is a general purpose, web-based UI for Kubernetes clusters. It allows users to manage applications running in the cluster and troubleshoot them, as well as manage the cluster itself.data:image/s3,"s3://crabby-images/e2726/e272649980c1c86dce81bff52e6da66f2ea3c500" alt="Dashboard"
See https://github.com/kubernetes/dashboard for more details.
Guide:
1. Execute following command
```bash
$ kubectl apply -f https://raw.githubusercontent.com/kubernetes/dashboard/master/src/deploy/recommended/kubernetes-dashboard.yaml# secret/kubernetes-dashboard-certs created
# serviceaccount/kubernetes-dashboard created
# role.rbac.authorization.k8s.io/kubernetes-dashboard-minimal created
# rolebinding.rbac.authorization.k8s.io/kubernetes-dashboard-minimal created
# deployment.apps/kubernetes-dashboard created
# service/kubernetes-dashboard created
```2. Check whether deployment is already available
```bash
$ kubectl get deployments/kubernetes-dashboard -n kube-system# NAME DESIRED CURRENT UP-TO-DATE AVAILABLE AGE
# kubernetes-dashboard 1 1 1 1 37s
```3. Proxy cluster network to your local machine
```bash
$ kubectl proxy --port=8001 --api-prefix=# Starting to serve on 127.0.0.1:8001
```4. Now you can visit Kubernetes Dashboard under this url:
http://localhost:8001/api/v1/namespaces/kube-system/services/https:kubernetes-dashboard:/proxy/
5. If following page will appear, click "skip" button
data:image/s3,"s3://crabby-images/ffac6/ffac62947decbc5a2da350fdc0ae844db8cddeb3" alt="Login Page"