Introduction
When building an Ubuntu VM, I like to install Ubuntu Server using the virtualized kernel. This gives us a little better performance and the freedom to install whatever desktop environment we want. The trade-off is that there is a manual step to the process that has to be revisted anytime we want to refresh the box.
Creating The VirtualBox Machine
Assuming that you already have a working VirtualBox environment, the first thing we need to do is grab the Ubuntu Server ISO. Make sure to download the 64-bit version, otherwise you will run into some odd issues down the road. Besides, RAM is cheap and you'll want more than 4GB of memory to do your work.
Once the ISO is downloaded, we need to create a new virtual machine in VirtualBox.
The first half of this step is to configure a new machine in VirtualBox. The most important element to this configuration is to use the paravirtualized network driver. Doing this improves network efficiency because much of the network stack can be bypassed, sending packets directly to the host's NIC
data:image/s3,"s3://crabby-images/306a4/306a42eb74b2c771d0488342a49c77516de9f30a" alt="Name the virtual machine"
data:image/s3,"s3://crabby-images/4fda0/4fda04b344682382f205d1f659f28e2edda56830" alt="Select RAM"
data:image/s3,"s3://crabby-images/911e6/911e64581df43162c9ab03b7ff24d49be44a389c" alt="Create virtual hard drive"
data:image/s3,"s3://crabby-images/579b8/579b8c47182f0381e6f729552a27d1be141b8f8f" alt="Select VirtualBox Disk Image"
data:image/s3,"s3://crabby-images/6e9a7/6e9a7e074e10bdcfc218b32772d119ffd1a0429d" alt="Select dynamic allocation"
data:image/s3,"s3://crabby-images/9d12b/9d12bf2caf1dd55477710d897084a66299125bee" alt="Select 100GB drive size"
data:image/s3,"s3://crabby-images/715d7/715d70e9679922e8ce955e757274008c54cd1307" alt="Leave notes for yourself"
data:image/s3,"s3://crabby-images/c723c/c723cc7d9170622ebc0849abf4022e54f653704d" alt="Disable floppy disk support"
data:image/s3,"s3://crabby-images/6f7e2/6f7e2b9938383e58f9a9da5e17b8406aa87b1462" alt="Give the VM 2 cores"
data:image/s3,"s3://crabby-images/afbd2/afbd21dacc2022fcbb2c9bd1ceee380c71349c56" alt="Insert the ISO into the virtual cd-rom drive"
data:image/s3,"s3://crabby-images/41ba6/41ba6b73c1a337ad83c8f43a7216f18c202a4551" alt="Specify the paravirtualized network driver"
data:image/s3,"s3://crabby-images/f01d5/f01d5ae6960e975b96b897b1f7507f9f19d477a2" alt="Move the VirtualBox menu to the top of the screen"
data:image/s3,"s3://crabby-images/1c78a/1c78a8ca15c0214a6df307e9568d83a5f5617fbb" alt="Summary of the VirtualBox configuration"
Running The Ubuntu Installer
Now that we have the VM configured, the time has come to run the installer. The key concept to remember in this step is to let the installer know that we are installing into a virual environment. That will give us access to the virtualization aware kernel, providing a bit of a performance boost. I do a lot of work with Docker, which has a tendency to use up inodes, so I like to use XFS formatted drives. If you aren't a Docker developer, then the default ext4 should work just fine for you. I also like to create a boot partition separate from the OS partition.
The following steps also appear as screen captures below.
- Install the virtualization aware kernel
- Name the machine bionic
- Use Vagrant for the full name
- Use vagrant for the user name and vagrant for the password
- Use manual partitioning to create 2 partitions
- Create a 1GB XFS boot partition
- Use the remaining space to create an XFS slash partition
- Do not enable automatic updates
- Select OpenSSH Server and Basic Ubuntu Server for sofware packages
- Log in for the first time
- Run sudo apt-get update and sudo apt-get dist-upgrade to update the box
- Run sudo shutdown -r now to reboot the machine
- Log back in and verify that no new package updates are available
- Shutdown the machine
data:image/s3,"s3://crabby-images/1f903/1f903fd47450eb9077f5585ab002495a78b21b23" alt="F4 to select 'Install a minimal virtual machine'"
data:image/s3,"s3://crabby-images/02faa/02faa11d522a21047552dd7e31d5f126ef23a9ff" alt="Manually partition the drive"
data:image/s3,"s3://crabby-images/74fed/74fed0483e4339141e76ee83bf0bba6bc4d82001" alt="Select the virtual disk"
data:image/s3,"s3://crabby-images/a4439/a4439f54588016d6300f47a90b92e910f753610d" alt="Create a new partition"
data:image/s3,"s3://crabby-images/96b12/96b126dd473e36b3693190b158f26c15bff333fc" alt="Setting for the boot partition"
data:image/s3,"s3://crabby-images/f52e7/f52e7c64800844c3c56374e437d1afbec8dae464" alt="Setting for the 'slash' partition"
data:image/s3,"s3://crabby-images/495e0/495e08ac2b46520610934c69e43e206551001659" alt="Select 'Basic Ubuntu Server' and 'OpenSSH Server'"
data:image/s3,"s3://crabby-images/2ce73/2ce737f157c804daecc7daccc1446a9b11f01226" alt="Initial log in"
data:image/s3,"s3://crabby-images/b215f/b215f270a2bfa16d53a6f93d25194275c080f930" alt="After package and kernel update"
data:image/s3,"s3://crabby-images/aa4c6/aa4c674003c2f378341a34c99c6a31af0b8cc7fb" alt="Disk partitions"
Administrative Rights
In order to install software, modify configuration files and shutdown the machine, our user will need to temporarily elevate its privileges via the sudo
command. Typically, the user has to enter in their password before sudo can be used. In an automated environment, like we are using here, this is a major inconvenience. There are several ways to elevate the user but I prefer to set up passwordless sudo. This is a security risk but since we're creating a disposable virtual machine for development, I'm okay making the trade off.
We need to add a file to the system, /etc/sudoers.d/passwordless
, which gives users in the sudo
or wheel
groups the ability to elevate their privileges without entering a password. After adding the file, set its permissions to be read-only via chmod 0400 /etc/sudoers.d/passwordless
%sudo ALL=(ALL) NOPASSWD:ALL
%wheel ALL=(ALL) NOPASSWD:ALL
Defaults !requiretty
Conclusion
Now that we have a clean Ubuntu installation, we'll use it next time as a base for our Vagrant box.