--- /dev/null
+# Copyright (C) 2013 W. Trevor King <wking@tremily.us>
+#
+# Redistribution and use in source and binary forms, with or without
+# modification, are permitted provided that the following conditions are met:
+#
+# * Redistributions of source code must retain the above copyright notice, this
+# list of conditions and the following disclaimer.
+#
+# * Redistributions in binary form must reproduce the above copyright notice,
+# this list of conditions and the following disclaimer in the documentation
+# and/or other materials provided with the distribution.
+#
+# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
+# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+
+FROM NAMESPACE/gentoo-syslog:TAG
+MAINTAINER A. U. Thor <author@example.com>
+#VOLUME ["PORTAGE:/usr/portage:ro", "PORTAGE/distfiles:/usr/portage/distfiles:rw"]
+RUN emerge -v net-misc/memcached
+RUN eselect news read new
+RUN rc-update add memcached default
+
+# Container networking happens automatically
+RUN sed -i 's/need net$/use net/' /etc/init.d/*
+
+CMD sed -i "s/^MEMUSAGE=.*/MEMUSAGE=\"${MEMUSAGE}\"/" /etc/conf.d/memcached && rc default && tail -F /var/log/messages
+EXPOSE 11211
--- /dev/null
+Run this [Memcached][] image with:
+
+ $ docker run -d -name memcached-0 -m 128m -e MEMUSAGE=118 wking/memcached
+
+The 10MB difference between container memory and the
+Memcached-specific `MEMUSAGE` limit gives some overhead for the
+`memcached` process itself and auxilliary processes to ensure that
+`MEMUSAGE` stops us before we hit “out of memory” errors.
+
+Then [link][linking] to it from your client container:
+
+ $ docker run -link memcached-0:memcached your-client
+
+Inside your client, use the `MEMCACHED_PORT` environment variable
+(which should be something like `tcp://172.17.0.8:11211`) to configure
+your client's Memcached connection. Linking like this *does not*
+expose the port on your host interface (that's what `-p` is for). You
+can spin up as many Memcached containers as you like (`memcached-1`,
+`memcached-2`, …), and link to any of them from any client container.
+
+[Memcached]: http://memcached.org/
+[linking]: http://docs.docker.io/en/latest/use/port_redirection/#linking-a-container