This project is designed to make it easy to build Linux virtual machines on Windows for use as dev-environment servers or for use as a Linux desktop. Or at least as easy as it can get: hosting one OS on another takes work!
I've written these instructions based on the assumption that you're running vanilla Windows, so this should work even if you don't have any of the pre-requisites yet.
- Configures your user account with administrative access
- SSH key-based login; remote access via passwords disabled
- Password-less sudo (but you can change it if you like)
- Password-less login to deskstop (if you choose to install Ubuntu-desktop)
- Installs your "dotfiles" from a separate git repository
- Installs the recipes and apt-get packages you specify
- Separation of code and data; user-specific data stored in data-bags
- Easy maintenance of chef recipes using librarian-chef
Install the software listed below on your Windows box. You'll want to make sure that 7zip, Git and Ruby are all in the PATH. In particular, it is very helpful to configure git so that the full set of git utilities in git/bin -- which includes the indispensable ssh.exe -- are accessible in the path.
Install Ruby gems
gem install bundler
gem install vagrant
gem install librarian
Configure git
git config --global user.name "Your Name Here"
git config --global user.email "your_email@example.com"
Download and extract the virtual machine image by pasting these commands into a command-shell (cmd.exe). The base virtual machine is 64-bit Ubuntu 10 "Lucid Lynx".
:: Using the "vagrant box" command on Windows is painfully slow because
:: the decompressor is written in Ruby. So let's simulate this command
::instead: "vagrant box add lucid64 http://files.vagrantup.com/lucid64.box
set boxname=lucid64
md %USERPROFILE%\.vagrant.d\boxes\%boxname%
cd %USERPROFILE%\.vagrant.d\boxes\%boxname%
curl http://files.vagrantup.com/%boxname%.box > %boxname%.7z
7z x %boxname%.7z
del %boxname%.7z
In a Windows command-shell:
:: first: change to the directory where "build-linux-vm" should exist
:: cd "the-parent-directory-where-you-would-like-build-linux-vm"
:: clone the repository
git clone https://github.com/webcoyote/build-linux-vm.git
Use your favorite text editor to modify these files to configure your Linux virtual machine as you like it.
- data_bags\admins\admins.json - Configure your personal account
- data_bags\install\install.json - Chef recipes and apt-packages to install
- Cheffile - Which recipes to download for installation by install.json
- Vagrantfile - reconfigure VM parameters (bridged vs. NAT networking, etc.)
In a Windows command-shell:
:: Change to the directory where the git repository exists
cd build-linux-vm
:: update chef cookbooks
librarian-chef update
:: build virtual machine
vagrant up
:: ... several minutes from now: success!
- Mounting error:
The following SSH command responded with a non-zero exit status.
Vagrant assumes that this means the command failed!
mount -t vboxsf -o uid=
id -u vagrant
,gid=id -g vagrant
v-csc-2 /tmp /vagrant-chef-1/chef-solo-2/cookbooks
SOLUTION: Run "librarian-chef update" on the Windows host system and then run "vagrant reload"
On Windows, it is necessary to configure repositories to use the git protocol instead of https to avoid password prompts:
git remote add origin git@github.com:webcoyote/build-linux-vm.git
I mention this because, by default GitHub suggests HTTPS-based URLs instead of GIT-based, and it took me a while to figure out WTF I had to use a password when my SSH key was there!
This project is built with Vagrant, Chef, Librarian and VirtualBox. If this doesn't work it is probably my fault, I would very much appreciate your feedback so I can fix it for you :)