We've tried to make this setup as generic as possible. Some unevitable choices are documented below.
Run like so:
vagrant up
export KUBECONFIG=$(pwd)/kubeconfig.yml
vagrant ssh youkube-01 -c 'sudo cat /etc/kubernetes/admin.conf' > $KUBECONFIG
No clear directions in kubeadm docs so using trial and error we ended up with:
- A record for the node's hostname mapping to the external IP, instead of default 127.0.0.1.
- Added a record for all the names that
kubeadm init
report the self-signed cert to be generated for. - One record per other node.
We just happened to select Flannel for pod networking, gotta have one.
Initially services would not work. You'd get a response on the expected port only if addressing the node that the pod lived on.
That turned out to be because flannel by default binds to eth0, which is Vagrant's interface for ssh etc.
We found the flanneld flag --iface=eth1
to change that.
We allow regular pods to be scheduled on the master. This is so we can run a multi-node cluster on 2x4GB memory.
Hard coded 192.168.38.1X, for no particular reason, where X is the node number.
We allow NodePort to be anything from port 80 and up. This is so we can host HTTP(S) on standard ports without simulating a LoadBalancer.
A sample pod can be created using kubectl create -f perimeter-test.yml
.
During pod network troubleshooting we also had to check that kubectl -n channel exec test -- curl http://perimeter.channel/
works.
Avoid kubernetes ports when setting nodePort:
.
Example for two nodes:
# https://github.com/Yolean/kubernetes-mysql-cluster/tree/scale-2, but first:
vagrant ssh youkube-01 --no-tty -c 'sudo mkdir -p /mnt/local-storage/mysql-mariadb-0'
vagrant ssh youkube-02 --no-tty -c 'sudo mkdir -p /mnt/local-storage/mysql-mariadb-1'
vagrant ssh youkube-03 --no-tty -c 'sudo mkdir -p /mnt/local-storage/mysql-mariadb-2'
kubectl apply -f local-volume/mysql-cluster/
# and now that the PVC is created (with matchLabels), apply the manifests from kubernetes-mysql-cluster
# https://github.com/Yolean/kubernetes-kafka/tree/scale-2
vagrant ssh youkube-01 --no-tty -c 'sudo mkdir -p /mnt/local-storage/data-pzoo-0'
vagrant ssh youkube-02 --no-tty -c 'sudo mkdir -p /mnt/local-storage/data-pzoo-1'
vagrant ssh youkube-03 --no-tty -c 'sudo mkdir -p /mnt/local-storage/data-pzoo-2'
vagrant ssh youkube-01 --no-tty -c 'sudo mkdir -p /mnt/local-storage/data-kafka-0'
vagrant ssh youkube-02 --no-tty -c 'sudo mkdir -p /mnt/local-storage/data-kafka-1'
vagrant ssh youkube-03 --no-tty -c 'sudo mkdir -p /mnt/local-storage/data-kafka-2'
kubectl apply -f local-volume/kafka/
# https://github.com/Yolean/kubernetes-monitoring
vagrant ssh youkube-02 --no-tty -c 'sudo mkdir -p /mnt/local-storage/prometheus-custom-db-prometheus-custom-0'
vagrant ssh youkube-01 --no-tty -c 'sudo mkdir -p /mnt/local-storage/prometheus-k8s-db-prometheus-k8s-0'
vagrant ssh youkube-02 --no-tty -c 'sudo mkdir -p /mnt/local-storage/prometheus-k8s-db-prometheus-k8s-1'
The standard "addon" with influxdb should work, but an alternative is Yolean/kubernetes-kafka#120.
The remainder of this readme is from the forked https://github.com/coreos/coreos-vagrant
This repo provides a template Vagrantfile to create a CoreOS virtual machine using the VirtualBox software hypervisor. After setup is complete you will have a single CoreOS virtual machine running on your local machine.
IRC: #coreos on freenode.org
Mailing list: coreos-dev
- Install dependencies
- VirtualBox 4.3.10 or greater.
- Vagrant 1.6.3 or greater.
- Clone this project and get it running!
git clone https://github.com/coreos/coreos-vagrant/
cd coreos-vagrant
- Startup and SSH
There are two "providers" for Vagrant with slightly different instructions. Follow one of the following two options:
VirtualBox Provider
The VirtualBox provider is the default Vagrant provider. Use this if you are unsure.
vagrant up
vagrant ssh
VMware Provider
The VMware provider is a commercial addon from Hashicorp that offers better stability and speed. If you use this provider follow these instructions.
VMware Fusion:
vagrant up --provider vmware_fusion
vagrant ssh
VMware Workstation:
vagrant up --provider vmware_workstation
vagrant ssh
vagrant up
triggers vagrant to download the CoreOS image (if necessary) and (re)launch the instance
vagrant ssh
connects you to the virtual machine.
Configuration is stored in the directory so you can always return to this machine by executing vagrant ssh from the directory where the Vagrantfile was located.
- Get started using CoreOS
There is optional shared folder setup. You can try it out by adding a section to your Vagrantfile like this.
config.vm.network "private_network", ip: "172.17.8.150"
config.vm.synced_folder ".", "/home/core/share", id: "core", :nfs => true, :mount_options => ['nolock,vers=3,udp']
After a 'vagrant reload' you will be prompted for your local machine password.
When using the VirtualBox provider for Vagrant (the default), Ignition is used to provision the machine. This uses a special plugin that is
automatically installed when using the default Vagrantfile. The config options for the plugin are all prefixed with config.ignition
and can
be found in this Vagrantfile or in the README of the plugin
To get started, run curl https://discovery.etcd.io/new\?size\=X
, where X
is the number of servers in your cluster (if a size is not provided,
the default of 3 will be used). Then, replace <token>
in the cl.conf
file with the generated token from the curl command. More configuration may be added if necessary. Then, use config transpiler to write the Ignition config
to config.ign by running ct --platform=vagrant-virtualbox < cl.conf > config.ign
. To see all available configuration options, check out
the Container Linux Configuration Specification as well as the Container Linux Config Transpiler Getting Started Documentation.
There is also a basic Ignition file provided based on the Container Linux config that is included. To use that instead (not recommended),
copy config.ign.sample
to config.ign
and make any necessary modifications. Check out the Ignition Getting Started documentation
to learn about the available features.
When using the VMWare provider for Vagrant, the Vagrantfile will provision your CoreOS VM(s)
with coreos-cloudinit if a user-data
file is found in the project directory. coreos-cloudinit simplifies the
provisioning process through the use of a script or cloud-config document.
To get started, copy user-data.sample
to user-data
and make any necessary modifications.
Check out the coreos-cloudinit documentation to learn about the available features.
The Vagrantfile will parse a config.rb
file containing a set of options used to configure your CoreOS cluster.
See config.rb.sample
for more information.
Launching a CoreOS cluster on Vagrant is as simple as configuring $num_instances
in a config.rb
file to 3 (or more!) and running vagrant up
.
If using the VirtualBox provider (default), copy the make sure to create a config.ign
as described above so that the machines can be configured with
etcd and flanneld correctly. Also, make sure to provide a fresh discovery URL in your config.ign
file to bootstrap etcd in your cluster.
If you are using the VMWare provider, make sure you provide a fresh discovery URL in your user-data
if you wish to bootstrap etcd in your cluster.
CoreOS is a rolling release distribution and versions that are out of date will automatically update. If you want to start from the most up to date version you will need to make sure that you have the latest box file of CoreOS. You can do this by running
vagrant box update
By setting the $expose_docker_tcp
configuration value you can forward a local TCP port to docker on
each CoreOS machine that you launch. The first machine will be available on the port that you specify
and each additional machine will increment the port by 1.
Follow the Enable Remote API instructions to get the CoreOS VM setup to work with port forwarding.
Then you can then use the docker
command from your local shell by setting DOCKER_HOST
:
export DOCKER_HOST=tcp://localhost:2375
If vagrant fails to run successfully, first make sure that the latest version of the coreos-vagrant project has been downloaded, then run
vagrant destroy -f
to remove old machines, vagrant box update
to update the OS box, and vagrant plugin update vagrant-ignition
to
update the ignition plugin. If the problems persist after that, please report bugs at https://issues.coreos.com.