• Stars
    star
    284
  • Rank 145,616 (Top 3 %)
  • Language
    Shell
  • License
    ISC License
  • Created over 11 years ago
  • Updated about 2 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

packer.io template for building an Arch Linux base box

Packer Arch

Packer Arch is a bare bones Packer template and installation script that can be used to generate a Vagrant base box for Arch Linux. The template works with the default VirtualBox provider as well as with VMware, Parallels and libvirt providers.

Overview

My goal was to roughly duplicate the attributes from a DigitalOcean Arch Linux droplet:

  • 64-bit
  • 20 GB disk
  • 512 MB memory
  • Only a single /root partition (ext4)
  • No swap
  • Includes the base meta package and base-devel group
  • OpenSSH is also installed and enabled on boot

The installation script follows the official installation guide pretty closely, with a few tweaks to ensure functionality within a VM. Beyond that, the only customizations to the machine are related to the vagrant user and the steps recommended for any base box.

Usage

VirtualBox Provider

Assuming that you already have Packer, VirtualBox, and Vagrant installed, you should be good to clone this repo and go:

$ git clone https://github.com/elasticdog/packer-arch.git
$ cd packer-arch/
$ packer build -only=virtualbox-iso arch-template.json

Then you can import the generated box into Vagrant:

$ vagrant box add arch output/packer_arch_virtualbox.box

VMware Provider

Assuming that you already have Packer, VMware Fusion (or VMware Workstation), and Vagrant with the VMware provider installed, you should be good to clone this repo and go:

$ git clone https://github.com/elasticdog/packer-arch.git
$ cd packer-arch/
$ packer build -only=vmware-iso arch-template.json

Then you can import the generated box into Vagrant:

$ vagrant box add arch output/packer_arch_vmware.box

Parallels Provider

Assuming that you already have Packer, Parallels, Parallels SDK and Vagrant with the Parallels provider installed, you should be good to clone this repo and go:

$ git clone https://github.com/elasticdog/packer-arch.git
$ cd packer-arch/
$ packer build -only=parallels-iso arch-template.json

Then you can import the generated box into Vagrant:

$ vagrant box add arch output/packer_arch_parallels.box

libvirt Provider

Assuming that you already have Packer, Vagrant with the vagrant-libvirt plugin installed, you should be good to clone this repo and go:

$ git clone https://github.com/elasticdog/packer-arch.git
$ cd packer-arch/
$ packer build -only=qemu arch-template.json

Then you can import the generated box into Vagrant:

$ vagrant box add arch output/packer_arch_libvirt.box

NOTE: libvirt support is limited to QEMU/KVM only.

wrapacker

For convenience, there is a wrapper script named wrapacker that will run the appropriate packer build command for you that will also automatically ensure the latest ISO download URL and optionally use a mirror from a provided country code in order to build the final box.

$ wrapacker --country US --dry-run

For debugging purposes, execute:

$ PACKER_LOG=1 ./wrapacker --country=US --provider=virtualbox --on-error=ask --force

See the --help flag for additional details.

Known Issues

VMware Tools

The official VMware Tools do not currently support Arch Linux, and the Open Virtual Machine Tools (open-vm-tools) require extensive patching in order to compile correctly with a Linux 3.11 series kernel. So for the time being, I have not included support for the tools.

No tools means that the shared folder feature will not work, and when you run vagrant up to launch a VM based on the VMware box, you will see the following error message:

The HGFS kernel module was not found on the running virtual machine. This must be installed for shared folders to work properly. Please install the VMware tools within the guest and try again. Note that the VMware tools installation will succeed even if HGFS fails to properly install. Carefully read the output of the VMware tools installation to verify the HGFS kernel modules were installed properly.

Note that this issue does not apply to VirtualBox, as their official guest additions work just fine.

Vagrant Provisioners

The box purposefully does not include Puppet, Chef or Ansible for automatic Vagrant provisioning. My intention was to duplicate a DigitalOcean VPS and furthermore use the VM for testing Ansible playbooks for configuration management.

License

Packer Arch is provided under the terms of the ISC License.

Copyright Β© 2013–2017, Aaron Bull Schaefer.

More Repositories

1

transcrypt

transparently encrypt files within a git repository
Shell
1,467
star
2

genhost

generate unused hostnames by randomly picking from a word list
Shell
257
star
3

puppet-sandbox

A Vagrant-based Puppet development environment for creating new modules
Puppet
219
star
4

salt-sandbox

A Vagrant-based Salt development environment for creating new modules
Puppet
121
star
5

tiddlywiki-docker

Tools for running TiddlyWiki via a Docker container
Shell
42
star
6

yawl

Yet Another Word List (YAWL) by M. Leo Cooper
C
35
star
7

dotfiles

collection of home directory configuration files used across multiple unix-based systems
Shell
28
star
8

hyperboriarch

Ansible playbooks for configuring cjdns nodes running on Arch Linux
Shell
28
star
9

monarch

Ansible playbooks for configuring your own mail server on Arch Linux
16
star
10

vagrant-init

a template for provisioning new Vagrant projects
Ruby
8
star
11

spellabc

Converts characters into their equivalent spelling alphabet code words
Go
7
star
12

matasano-elixir

solutions to the matasano crypto challenges, written in elixir
Elixir
5
star
13

pygments-factor

pygment's lexer for factor language syntax highlighting
Python
2
star
14

lexibomb

a tile-based word game, written in elixir
Elixir
2
star
15

elasticdog-com

The source of my personal website
TypeScript
2
star
16

hello-sinatra

A barebones Sinatra application template using Slim, Compass, and MiniTest::Spec
Ruby
2
star
17

socket_address

An Elixir convenience library for manipulating Internet socket addresses.
Elixir
2
star
18

chef-repo

chef repository integrated with the opscode platform
Ruby
2
star
19

snowflakes

beautiful and unique snowflakes
Nix
1
star
20

actions-sandbox

Sandbox for Configuring GitHub Actions
Rust
1
star
21

miscellaneous-scripts

the name says it all
Shell
1
star
22

taxonate

Identify and filter files based on their programming language.
Rust
1
star