Go to file
Thorsten Klein a969f2fa50
Merge pull request #231 from JohnnyCrazy/patch-1
Added a link to the AUR package in README.md (thanks @JohnnyCrazy)
2020-04-28 19:50:52 +02:00
.github/ISSUE_TEMPLATE update issue templates 2020-04-23 08:48:02 +02:00
cli Merge pull request #187 from docteurklein/registry-localhost 2020-04-23 08:09:52 +02:00
docs Add notes about --enable-registry-cache disabling push access (thanks for the hint @deiwin) 2020-04-23 08:19:26 +02:00
tests Merge pull request #187 from docteurklein/registry-localhost 2020-04-23 08:09:52 +02:00
vendor update vendor 2020-04-19 11:53:50 +02:00
version update default K3sVersion to use latest tag 2019-05-03 22:04:39 -04:00
.gitignore exclude .local 2019-11-07 14:41:57 +01:00
.travis.yml Run the e2e in DinD 2020-01-21 10:53:04 +01:00
Dockerfile Poor-man e2e tests 2020-01-21 10:53:03 +01:00
go.mod update vendor 2020-04-19 11:53:50 +02:00
go.sum update vendor 2020-04-19 11:53:50 +02:00
install.sh Allow passing TAG to install a specific release 2019-09-10 22:06:25 +02:00
LICENSE update README 2019-04-03 10:27:09 +02:00
main.go Add notes about --enable-registry-cache disabling push access (thanks for the hint @deiwin) 2020-04-23 08:19:26 +02:00
Makefile update golangci-lint in Makefile 2020-03-06 09:29:12 +01:00
README.md Added a link to the AUR package in README.md 2020-04-28 18:42:16 +02:00

k3d

Build Status Go Report Card License Downloads Releases Homebrew

k3s in docker

k3s is the lightweight Kubernetes distribution by Rancher: rancher/k3s

This repository is based on @zeerorg's zeerorg/k3s-in-docker, reimplemented in Go by @iwilltry42 in iwilltry42/k3d, which is now rancher/k3d.

Requirements

Get

You have several options there:

  • use the install script to grab the latest release:

    • wget: wget -q -O - https://raw.githubusercontent.com/rancher/k3d/master/install.sh | bash
    • curl: curl -s https://raw.githubusercontent.com/rancher/k3d/master/install.sh | bash
  • use the install script to grab a specific release (via TAG environment variable):

    • wget: wget -q -O - https://raw.githubusercontent.com/rancher/k3d/master/install.sh | TAG=v1.3.4 bash
    • curl: curl -s https://raw.githubusercontent.com/rancher/k3d/master/install.sh | TAG=v1.3.4 bash
  • Use Homebrew: brew install k3d (Homebrew is avaiable for MacOS and Linux)

  • Install via AUR package rancher-k3d-bin: yay -S rancher-k3d-bin

  • Grab a release from the release tab and install it yourself.

  • Via go: go install github.com/rancher/k3d (Note: this will give you unreleased/bleeding-edge changes)

or...

Build

  1. Clone this repo, e.g. via go get -u github.com/rancher/k3d
  2. Inside the repo run
    • 'make install-tools' to make sure required go packages are installed
  3. Inside the repo run one of the following commands
    • make build to build for your current system
    • go install to install it to your GOPATH (Note: this will give you unreleased/bleeding-edge changes)
    • make build-cross to build for all systems

Usage

Check out what you can do via k3d help

Example Workflow: Create a new cluster and use it with kubectl (Note: kubectl is not part of k3d, so you have to install it first if needed)

  1. k3d create to create a new single-node cluster (docker container)
  2. export KUBECONFIG=$(k3d get-kubeconfig) to make kubectl to use the kubeconfig for that cluster
  3. execute some commands like kubectl get pods --all-namespaces
  4. k3d delete to delete the default cluster

Exposing Services

If you want to access your services from the outside (e.g. via Ingress), you need to map the ports (e.g. port 80 for Ingress) using the --publish flag (or aliases). Check out the examples here.

What now?

Find more details under the following Links:

Connect

  1. Join the Rancher community on slack via slack.rancher.io
  2. Go to rancher-users.slack.com and join our channel #k3d
  3. Start chatting