2015-08-17 09:20:45 +00:00
|
|
|
# This file describes the standard way to build Docker, using docker
|
|
|
|
#
|
|
|
|
# Usage:
|
|
|
|
#
|
|
|
|
# # Assemble the full dev environment. This is slow the first time.
|
|
|
|
# docker build -t docker -f Dockerfile.gccgo .
|
|
|
|
#
|
|
|
|
|
2015-12-16 23:56:28 +00:00
|
|
|
FROM gcc:5.3
|
2015-08-17 09:20:45 +00:00
|
|
|
|
|
|
|
# Packaged dependencies
|
|
|
|
RUN apt-get update && apt-get install -y \
|
|
|
|
apparmor \
|
|
|
|
aufs-tools \
|
|
|
|
btrfs-tools \
|
|
|
|
build-essential \
|
|
|
|
curl \
|
|
|
|
git \
|
|
|
|
iptables \
|
2015-12-02 16:43:41 +00:00
|
|
|
jq \
|
2015-08-17 09:20:45 +00:00
|
|
|
net-tools \
|
|
|
|
libapparmor-dev \
|
|
|
|
libcap-dev \
|
|
|
|
libsqlite3-dev \
|
|
|
|
mercurial \
|
|
|
|
parallel \
|
2015-11-22 10:32:10 +00:00
|
|
|
python-dev \
|
2015-08-17 09:20:45 +00:00
|
|
|
python-mock \
|
|
|
|
python-pip \
|
|
|
|
python-websocket \
|
|
|
|
--no-install-recommends
|
|
|
|
|
|
|
|
# Get lvm2 source for compiling statically
|
|
|
|
RUN git clone -b v2_02_103 https://git.fedorahosted.org/git/lvm2.git /usr/local/lvm2
|
|
|
|
# see https://git.fedorahosted.org/cgit/lvm2.git/refs/tags for release tags
|
|
|
|
|
|
|
|
# Compile and install lvm2
|
|
|
|
RUN cd /usr/local/lvm2 \
|
|
|
|
&& ./configure --enable-static_link \
|
|
|
|
&& make device-mapper \
|
|
|
|
&& make install_device-mapper
|
|
|
|
# see https://git.fedorahosted.org/cgit/lvm2.git/tree/INSTALL
|
|
|
|
|
2015-12-08 01:40:55 +00:00
|
|
|
# install seccomp
|
|
|
|
# this can be changed to the ubuntu package libseccomp-dev if dockerinit is removed,
|
|
|
|
# we need libseccomp.a (which the package does not provide) for dockerinit
|
|
|
|
ENV SECCOMP_VERSION v2.2.3
|
|
|
|
RUN set -x \
|
|
|
|
&& export SECCOMP_PATH=$(mktemp -d) \
|
|
|
|
&& git clone https://github.com/seccomp/libseccomp.git "$SECCOMP_PATH" \
|
|
|
|
&& ( \
|
|
|
|
cd "$SECCOMP_PATH" \
|
|
|
|
&& git checkout "$SECCOMP_VERSION" \
|
|
|
|
&& ./autogen.sh \
|
|
|
|
&& ./configure --prefix=/usr \
|
|
|
|
&& make \
|
|
|
|
&& make install \
|
|
|
|
) \
|
|
|
|
&& rm -rf "$SECCOMP_PATH"
|
|
|
|
|
2015-08-17 09:20:45 +00:00
|
|
|
ENV GOPATH /go:/go/src/github.com/docker/docker/vendor
|
|
|
|
|
|
|
|
# Get the "docker-py" source so we can run their integration tests
|
|
|
|
ENV DOCKER_PY_COMMIT 139850f3f3b17357bab5ba3edfb745fb14043764
|
|
|
|
RUN git clone https://github.com/docker/docker-py.git /docker-py \
|
|
|
|
&& cd /docker-py \
|
|
|
|
&& git checkout -q $DOCKER_PY_COMMIT
|
|
|
|
|
|
|
|
# Add an unprivileged user to be used for tests which need it
|
|
|
|
RUN groupadd -r docker
|
|
|
|
RUN useradd --create-home --gid docker unprivilegeduser
|
|
|
|
|
|
|
|
VOLUME /var/lib/docker
|
|
|
|
WORKDIR /go/src/github.com/docker/docker
|
2015-12-08 01:40:55 +00:00
|
|
|
ENV DOCKER_BUILDTAGS apparmor seccomp selinux
|
2015-08-17 09:20:45 +00:00
|
|
|
|
|
|
|
# Wrap all commands in the "docker-in-docker" script to allow nested containers
|
|
|
|
ENTRYPOINT ["hack/dind"]
|
|
|
|
|
|
|
|
# Upload docker source
|
|
|
|
COPY . /go/src/github.com/docker/docker
|