thumbor: Update to post v6.0
[dockerfile.git] / README.md
1 [Dockerfiles][] for assorted [Gentoo][]-based [Docker][] images.
2
3 Dockerfiles are sorted into directories with names matching the
4 suggested repository.  To avoid duplicating ephemeral data (namespace,
5 timestamp tag, …), they appear in the `Dockerfile.template` as markers
6 (`${NAMESPACE}`, `${TAG}`, …).  The `build.sh` script replaces the
7 markers with values while generating a `Dockerfile` from each
8 `Dockerfile.template` (using [envsubst][]), and then builds each tag
9 with:
10
11     $ docker build -t $NAMESPACE/$REPO:$TAG $REPO
12
13 for example:
14
15     $ docker build -t wking/gentoo-en-us:20131205 gentoo-en-us
16
17 The dependency graph is:
18
19     wking/gentoo  (amd64 stage3)
20     `-- gentoo-portage  (adds portage directory)
21         `-- gentoo-python (drops Python 2.7)
22             `-- gentoo-utc  (adds a system timezone)
23                 `-- gentoo-en-us  (adds locale)
24                     `-- gentoo-openrc  (configure OpenRC for Docker)
25                         `-- gentoo-syslog  (adds syslog-ng and associates)
26                             |-- buildbot  (adds a Buildbot master and slave)
27                             |-- docker-registry  (adds a Docker registry server)
28                             |-- gentoo-layman  (adds layman for Gentoo overlays)
29                             |   |-- package-cache  (adds a package-cache proxy)
30                             |   `-- thumbor  (adds Thumbor)
31                             |-- gentoo-node  (adds Node and npm)
32                             |   `-- hubot  (adds hubot with an IRC adapter)
33                             |-- irker  (adds irker, and spawns irkerd by default)
34                             |-- memcached  (adds Memcached)
35                             |-- nagios  (adds Nagios)
36                             |-- nginx  (adds Nginx)
37                             |   |-- nginx-proxy  (SSL/TLS proxying via SNI)
38                             |   |-- kibana  (adds Kibana)
39                             |   `-- kibana-azure  (adds Azure's Kibana)
40                             |-- ngircd  (adds ngIRCd)
41                             |-- postgresql  (adds PostgreSQL)
42                             |-- redis  (adds Redis)
43                             |-- salt  (adds a Salt Stack install)
44                             |   |-- salt-master  (enables a Salt Stack master)
45                             |   `-- salt-minion  (enables a Salt Stack minion)
46                             |-- stunnel  (adds stunnel)
47                             `-- gentoo-java  (adds IcedTea)
48                                 `-- elasticsearch  (adds Elasticsearch)
49
50 Run:
51
52     $ ./build.sh
53
54 to seed from the Gentoo mirrors and build all images.  There are a
55 number of variables in the `build.sh` script that configure the build
56 (`AUTHOR`, `NAMESPACE`, …).  We use [POSIX parameter
57 expansion][parameter-expansion] to make it easy to override variables
58 as you see fit.
59
60     $ NAMESPACE=jdoe DATE=20131210 ./build.sh
61
62 I'd like to avoid bloating the images with the Portage tree, but
63 without ugly hacks [that is not currently possible][3156].
64
65 [Docker]: http://www.docker.io/
66 [Dockerfiles]: http://www.docker.io/learn/dockerfile/
67 [Gentoo]: http://www.gentoo.org/
68 [envsubst]: http://www.gnu.org/software/gettext/manual/html_node/envsubst-Invocation.html
69 [parameter-expansion]: http://pubs.opengroup.org/onlinepubs/9699919799/utilities/V3_chap02.html#tag_18_06_02
70 [3156]: https://github.com/dotcloud/docker/issues/3156