Skip to content

Latest commit

 

History

History
169 lines (122 loc) · 5.14 KB

README.md

File metadata and controls

169 lines (122 loc) · 5.14 KB

puppet-apt_cacher_ng

A Puppet module for apt-cacher-ng, with a Vagrantfile for quick deployment on Vagrant.

Requires puppetlabs stdlib module

Original author: Alban Peignier

Other contributors:

Usage

The apt_cacher_ng module provides two main "entry points": one for the server and one for clients.

Server

The main class, apt_cacher_ng will install the apt_cacher_ng server. You can simply include the class, or if you want to install a specific version you can use the version parameter like the following:

class { 'apt_cacher_ng':
  version => '0.4.6-1ubuntu1',
}
  • The server will be available on the default port (3142).
  • The server will not use itself as a cache by default.

If you'd like to set an admin password for the web interface, you can do so with the admin_user and admin_pw parameters. Make sure to set both parameters (or none). Also, keep in mind that only alphanumeric characters, dashes and underscores are accepted for the password:

class { 'apt_cacher_ng':
  admin_user => 'clown_goose',
  admin_pw   => '12tgDd23456ytGfDW32',
}

Client

The class apt_cacher_ng::client helps you configure a server as a client for an apt proxy. It has two "modes" of configuration: setting up one proxy with no alternative, and setting up a list of proxies where the first in the list that is currently available will be used (autodetection).

Both modes use the servers parameter to the apt_cacher_ng::client class. This parameter should be an array that contains server strings. The servers strings are fqdn (or IP address) and port in the same mannger as you'd write it for HTTP, without the "http://" prefix.

  • To setup one proxy with no fallback, set the autodetect parameter to false and make sure to provide only one server value for the servers parameter:

    class { 'apt_cacher_ng::client':
      servers    => ['192.168.31.42:3142'],
      autodetect => false,
    }

    Per askubuntu:54099, you'll need to do this on older Ubuntu and Debian releases. Lucid and Squeeze support Acquire::http::ProxyAutoDetect; Karmic and Lenny don't.

  • To setup a list of proxies, keep the autodetect paramter to a value of true (this is the default value) and specify all servers in the servers parameter:

    class { 'apt_cacher_ng::client':
      servers => ['192.168.30.42:3142', '192.168.31.42:3142'],
    }

    When setting up autodetect, you can override the number of seconds till timeout (default is 30):

    class { 'apt_cacher_ng::client':
      servers => ['192.168.30.42:3142', '192.168.31.42:3142'],
      timeout => 15,
    }

    Also when setting up autodetect, you can set the verbose parameter to false to make the autodetection process act quietly:

    class { 'apt_cacher_ng::client':
      servers => ['192.168.30.42:3142', '192.168.31.42:3142'],
      verbose => false,
    }

Providing an apt cache for your Vagrant virtual machines

To install apt-cacher-ng on a fresh box in Vagrant:

vagrant up aptcache

The Vagrantfile specifies a box named aptcache providing its service from http://192.168.31.42:3142. You should be able to browse to it from your host OS to manage it.

Using the apt cache

To configure your own Vagrant box to access the aptcache box:

  • Configure your VM for host-only networking, by adding the following line to your Vagrantfile:

      config.vm.network :hostonly, "192.168.31.2"
    

    (Change the final octet (2) to make sure it's unique on your machine. Don't use 1: it'll probably be used by your host OS for its vboxnet0 adapter.)

  • Inside your box, create /etc/apt/apt.conf.d/71proxy with the line:

      Acquire::http { Proxy "http://192.168.31.42:3142"; };
    

    If you're using Puppet Provisioning, put this in your manifest_file, e.g. my_manifest.pp:

      file { "/etc/apt/apt.conf.d/71proxy": 
        owner   => root,
        group   => root,
        mode    => '0644',
        content => 'Acquire::http { Proxy "http://192.168.31.42:3142"; };',
      }
    

    You could also install the Puppet module and use apt_cacher_ng::client as above.

Testing

To perform a smoke test:

make smoke

To smoke test both the module and the Vagrantfile's manifest_file:

make test

To test the module properly, install Vagrant and:

make vm