We provide our own packages to ensure that all services have versions of their dependencies that will work together. Where possible, our packages simply declare dependencies on a vendor's own packages (Docker, for example).
With Kubernetes, packages are still in incubation; we will continue to produce our own for now and repackage as new Kubernetes releases come out.
By default, Kismatic will install its own repos onto machines and use them to download Kismatic packages. This may not be acceptable, for example, if you want to adopt a "golden image" prior to rolling out a many-node cluster, if you need to install a cluster in a lab where most machines are disconnected from the internet, or if you simply want to save bandwidth. If this is your use case, please view the instructions below.
- Add the Kismatic repo to the machine
sudo curl https://kismatic-packages-rpm.s3-accelerate.amazonaws.com/kismatic.repo -o /etc/yum.repos.d/kismatic.repo
- Install the RPMs for the type of node you want to create
Component | Install Command |
---|---|
Etcd | sudo yum -y install etcd-3.1.9-1 |
Kubernetes Node | sudo yum -y install docker-engine-1.12.6-1.el7.centos kubelet-1.7.1_1-1 kubectl-1.7.1_1-1 |
- Add the Kismatic repo to the machine
- Add the Kismatic public key to apt
wget -qO - https://kismatic-packages-deb.s3-accelerate.amazonaws.com/public.key | sudo apt-key add -
- Add the Kismatic repo
cat <<EOF > /etc/apt/sources.list.d/kubernetes.list
deb https://kismatic-packages-deb.s3-accelerate.amazonaws.com kismatic-xenial main
EOF
- Refresh the machine's repo cache
sudo apt-get update
- Install the RPMs for the type of node you want to create
Component | Install Command |
---|---|
Etcd | sudo apt-get -y -t=kismatic-xenial install etcd=3.1.9 |
Kubernetes Node | sudo apt-get -y -t=kismatic-xenial install docker-engine=1.12.6-0~ubuntu-xenial kubelet=1.7.1-1 kubectl=1.7.1-1 |
If you maintain a package repository, you should not perform step 1 in the instructions above. Instead, you should point machines to your own package repository and keep it in sync with Kismatic.
Each Kismatic package will also have many transitive dependencies. To be able to install nodes fully disconnected from the internet, you will need to synchronize your repo with these packages' repos as well.
Dependencies and their versions will change over time and as such they are not listed here. Instead, they can be derived from any machine that is integrated with our repos using the commands linked below.
One way to ensure you've correctly synchronized your repo is to install a test cluster.
- Provision 1 node of each role
- Install the Kismatic packages
- Run
kismatic plan
to generate a new Plan file - Update the Plan file to identify your nodes and using the configuration
disable_package_installation=true
. - Run
kismatic validate
- During validation, the Kismatic inspector will check your packages to be sure they installed correctly and will fail if any of them are missing.
Changes to dependencies should be called out in the notes that accompany a release.
Listing dependencies of a package: yum deplist $PACKAGE
Listing dependencies of a package: apt-cache depends $PACKAGE