/vagrant-box-centos7-minikube

Primary LanguageShellApache License 2.0Apache-2.0

Deprication notice

Development of this project has been moved to https://github.com/Q24/vagrant-box-centos7-minikube

vagrant-box-centos7-minikube

Description

This project contains everything needed to build the centos7-minikube vagrant box. The box is build using Vagrant's packer tool. Currently only a box for the VirtualBox provider is built.

The box resulting is based on a clean CentOS 7 minimal install. I try to keep the builds up to date with the latest version of this box. Several tools are included in the box:

  • ansible
  • minikube
  • docker
  • helm
  • kubectl
  • kubetail

Built boxes can be found on Vagrant Cloud

Prerequisites

To be able to build the box yourself, you'll need at least following tools installed:

The build wil be uploaded to Vagrant Cloud, so you'll need an account and corresponding token there. On top of that, the box has to be pre-created for the upload to succeed.

Usage

  1. Make sure you have a Vagrant Cloud account with an authentication token. You need to have "admin" access to the Vagrant Cloud box, or you need to be the owner of the box for the upload to work automatically. This token can be created via Account settings -> Security. You can enter the username and token when requested by the build.sh script (but you will need to do this every time when creating a new build), or you can create a file build.env in the root of this repository where you set the variables as follows:
DEFAULT_VAGRANT_CLOUD_USER="your.username"
DEFAULT_VAGRANT_CLOUD_TOKEN="your.vagrant.cloud.token"
  1. The script will update box mrvantage/centos7-minikube. This name is hardcoded in the scripts. If you wish to create a box in your own account, change the following two environment variables in build.sh:
export VAGRANT_CLOUD_BOX_USER="mrvantage"
export VAGRANT_CLOUD_BOX_NAME="centos7-minikube"
  1. Make your changes, and commit them in your local git repository.
  2. From this project's root directory run the build.sh bash script:
./build.sh
  1. The packer Vagrant builder will create and package your new box in a file named build/package.box.
  2. Vagrant cloud post-processor will create a new version and upload the box to the Vagrant Cloud.
  3. If the box build succeeded, the script will automatically create a tag in your local git repository. If you are happy with the results, push to GitHub, and create a GitHub release based on the tag.
  4. Finally, log into your Vagrant Cloud and release the box to make it available for everybody, and publish the GitHub release.
  5. Get yourself a celebratory beer!

Using the base box

You can use the base box like any other base box. The box itself is provisioned with Ansible, so if you wish to use Ansible in your provisioning process, you do not need to install Ansible again, as this is already part of the base box.

Configure your Vagrantfile as follows to re-use the pre-installed Ansible (if you don't want to use Ansible to do your provisioning, you can skip this):

# Provision using Ansible, using the pre-installed Ansible in the base box
config.vm.provision :ansible_local do |ansible|
    ansible.playbook = "playbook.yml"
    ansible.install = false
    ansible.compatibility_mode = "2.0"
    ansible.become = true # This can be true or false, whether or not you need to do stuff as root
end

Changelog

You can find the changelog here.

License

This code is licensed under the Apache 2.0 license.