Skip to content

Commit 6863b10

Browse files
author
Peng Zhao
committed
Initial Import
1 parent 1c215d5 commit 6863b10

File tree

2,787 files changed

+626299
-14
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

2,787 files changed

+626299
-14
lines changed

AUTHORS

+1,033
Large diffs are not rendered by default.

CHANGELOG.md

+2,131
Large diffs are not rendered by default.

CONTRIBUTING.md

+434
Large diffs are not rendered by default.

Dockerfile

+251
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,251 @@
1+
# This file describes the standard way to build Docker, using docker
2+
#
3+
# Usage:
4+
#
5+
# # Assemble the full dev environment. This is slow the first time.
6+
# docker build -t docker .
7+
#
8+
# # Mount your source in an interactive container for quick testing:
9+
# docker run -v `pwd`:/go/src/github.com/docker/docker --privileged -i -t docker bash
10+
#
11+
# # Run the test suite:
12+
# docker run --privileged docker hack/make.sh test
13+
#
14+
# # Publish a release:
15+
# docker run --privileged \
16+
# -e AWS_S3_BUCKET=baz \
17+
# -e AWS_ACCESS_KEY=foo \
18+
# -e AWS_SECRET_KEY=bar \
19+
# -e GPG_PASSPHRASE=gloubiboulga \
20+
# docker hack/release.sh
21+
#
22+
# Note: AppArmor used to mess with privileged mode, but this is no longer
23+
# the case. Therefore, you don't have to disable it anymore.
24+
#
25+
26+
FROM ubuntu:trusty
27+
28+
# add zfs ppa
29+
RUN apt-key adv --keyserver hkp://p80.pool.sks-keyservers.net:80 --recv-keys E871F18B51E0147C77796AC81196BA81F6B0FC61
30+
RUN echo deb http://ppa.launchpad.net/zfs-native/stable/ubuntu trusty main > /etc/apt/sources.list.d/zfs.list
31+
32+
# add llvm repo
33+
RUN apt-key adv --keyserver hkp://p80.pool.sks-keyservers.net:80 --recv-keys 6084F3CF814B57C1CF12EFD515CF4D18AF4F7421
34+
RUN echo deb http://llvm.org/apt/trusty/ llvm-toolchain-trusty main > /etc/apt/sources.list.d/llvm.list
35+
36+
# Packaged dependencies
37+
RUN apt-get update && apt-get install -y \
38+
apparmor \
39+
aufs-tools \
40+
automake \
41+
bash-completion \
42+
btrfs-tools \
43+
build-essential \
44+
clang-3.8 \
45+
createrepo \
46+
curl \
47+
dpkg-sig \
48+
gcc-mingw-w64 \
49+
git \
50+
iptables \
51+
jq \
52+
libapparmor-dev \
53+
libcap-dev \
54+
libltdl-dev \
55+
libsqlite3-dev \
56+
libsystemd-journal-dev \
57+
libtool \
58+
mercurial \
59+
pkg-config \
60+
python-dev \
61+
python-mock \
62+
python-pip \
63+
python-websocket \
64+
s3cmd=1.1.0* \
65+
ubuntu-zfs \
66+
xfsprogs \
67+
libzfs-dev \
68+
tar \
69+
--no-install-recommends \
70+
&& ln -snf /usr/bin/clang-3.8 /usr/local/bin/clang \
71+
&& ln -snf /usr/bin/clang++-3.8 /usr/local/bin/clang++
72+
73+
# Get lvm2 source for compiling statically
74+
ENV LVM2_VERSION 2.02.103
75+
RUN mkdir -p /usr/local/lvm2 \
76+
&& curl -fsSL "https://mirrors.kernel.org/sourceware/lvm2/LVM2.${LVM2_VERSION}.tgz" \
77+
| tar -xzC /usr/local/lvm2 --strip-components=1
78+
# see https://git.fedorahosted.org/cgit/lvm2.git/refs/tags for release tags
79+
80+
# Compile and install lvm2
81+
RUN cd /usr/local/lvm2 \
82+
&& ./configure \
83+
--build="$(gcc -print-multiarch)" \
84+
--enable-static_link \
85+
&& make device-mapper \
86+
&& make install_device-mapper
87+
# see https://git.fedorahosted.org/cgit/lvm2.git/tree/INSTALL
88+
89+
# Configure the container for OSX cross compilation
90+
ENV OSX_SDK MacOSX10.11.sdk
91+
RUN set -x \
92+
&& export OSXCROSS_PATH="/osxcross" \
93+
&& git clone --depth 1 https://github.com/tpoechtrager/osxcross.git $OSXCROSS_PATH \
94+
&& curl -sSL https://s3.dockerproject.org/darwin/${OSX_SDK}.tar.xz -o "${OSXCROSS_PATH}/tarballs/${OSX_SDK}.tar.xz" \
95+
&& UNATTENDED=yes OSX_VERSION_MIN=10.6 ${OSXCROSS_PATH}/build.sh
96+
ENV PATH /osxcross/target/bin:$PATH
97+
98+
# install seccomp: the version shipped in trusty is too old
99+
ENV SECCOMP_VERSION 2.2.3
100+
RUN set -x \
101+
&& export SECCOMP_PATH="$(mktemp -d)" \
102+
&& curl -fsSL "https://github.com/seccomp/libseccomp/releases/download/v${SECCOMP_VERSION}/libseccomp-${SECCOMP_VERSION}.tar.gz" \
103+
| tar -xzC "$SECCOMP_PATH" --strip-components=1 \
104+
&& ( \
105+
cd "$SECCOMP_PATH" \
106+
&& ./configure --prefix=/usr/local \
107+
&& make \
108+
&& make install \
109+
&& ldconfig \
110+
) \
111+
&& rm -rf "$SECCOMP_PATH"
112+
113+
# Install Go
114+
# IMPORTANT: If the version of Go is updated, the Windows to Linux CI machines
115+
# will need updating, to avoid errors. Ping #docker-maintainers on IRC
116+
# with a heads-up.
117+
ENV GO_VERSION 1.5.3
118+
RUN curl -fsSL "https://storage.googleapis.com/golang/go${GO_VERSION}.linux-amd64.tar.gz" \
119+
| tar -xzC /usr/local
120+
ENV PATH /go/bin:/usr/local/go/bin:$PATH
121+
ENV GOPATH /go:/go/src/github.com/docker/docker/vendor
122+
123+
# Compile Go for cross compilation
124+
ENV DOCKER_CROSSPLATFORMS \
125+
linux/386 linux/arm \
126+
darwin/amd64 \
127+
freebsd/amd64 freebsd/386 freebsd/arm \
128+
windows/amd64 windows/386
129+
130+
# (set an explicit GOARM of 5 for maximum compatibility)
131+
ENV GOARM 5
132+
133+
# This has been commented out and kept as reference because we don't support compiling with older Go anymore.
134+
# ENV GOFMT_VERSION 1.3.3
135+
# RUN curl -sSL https://storage.googleapis.com/golang/go${GOFMT_VERSION}.$(go env GOOS)-$(go env GOARCH).tar.gz | tar -C /go/bin -xz --strip-components=2 go/bin/gofmt
136+
137+
ENV GO_TOOLS_COMMIT 823804e1ae08dbb14eb807afc7db9993bc9e3cc3
138+
# Grab Go's cover tool for dead-simple code coverage testing
139+
# Grab Go's vet tool for examining go code to find suspicious constructs
140+
# and help prevent errors that the compiler might not catch
141+
RUN git clone https://github.com/golang/tools.git /go/src/golang.org/x/tools \
142+
&& (cd /go/src/golang.org/x/tools && git checkout -q $GO_TOOLS_COMMIT) \
143+
&& go install -v golang.org/x/tools/cmd/cover \
144+
&& go install -v golang.org/x/tools/cmd/vet
145+
# Grab Go's lint tool
146+
ENV GO_LINT_COMMIT 32a87160691b3c96046c0c678fe57c5bef761456
147+
RUN git clone https://github.com/golang/lint.git /go/src/github.com/golang/lint \
148+
&& (cd /go/src/github.com/golang/lint && git checkout -q $GO_LINT_COMMIT) \
149+
&& go install -v github.com/golang/lint/golint
150+
151+
# Install two versions of the registry. The first is an older version that
152+
# only supports schema1 manifests. The second is a newer version that supports
153+
# both. This allows integration-cli tests to cover push/pull with both schema1
154+
# and schema2 manifests.
155+
ENV REGISTRY_COMMIT_SCHEMA1 ec87e9b6971d831f0eff752ddb54fb64693e51cd
156+
ENV REGISTRY_COMMIT 47a064d4195a9b56133891bbb13620c3ac83a827
157+
RUN set -x \
158+
&& export GOPATH="$(mktemp -d)" \
159+
&& git clone https://github.com/docker/distribution.git "$GOPATH/src/github.com/docker/distribution" \
160+
&& (cd "$GOPATH/src/github.com/docker/distribution" && git checkout -q "$REGISTRY_COMMIT") \
161+
&& GOPATH="$GOPATH/src/github.com/docker/distribution/Godeps/_workspace:$GOPATH" \
162+
go build -o /usr/local/bin/registry-v2 github.com/docker/distribution/cmd/registry \
163+
&& (cd "$GOPATH/src/github.com/docker/distribution" && git checkout -q "$REGISTRY_COMMIT_SCHEMA1") \
164+
&& GOPATH="$GOPATH/src/github.com/docker/distribution/Godeps/_workspace:$GOPATH" \
165+
go build -o /usr/local/bin/registry-v2-schema1 github.com/docker/distribution/cmd/registry \
166+
&& rm -rf "$GOPATH"
167+
168+
# Install notary server
169+
ENV NOTARY_VERSION docker-v1.10-5
170+
RUN set -x \
171+
&& export GOPATH="$(mktemp -d)" \
172+
&& git clone https://github.com/docker/notary.git "$GOPATH/src/github.com/docker/notary" \
173+
&& (cd "$GOPATH/src/github.com/docker/notary" && git checkout -q "$NOTARY_VERSION") \
174+
&& GOPATH="$GOPATH/src/github.com/docker/notary/Godeps/_workspace:$GOPATH" \
175+
go build -o /usr/local/bin/notary-server github.com/docker/notary/cmd/notary-server \
176+
&& GOPATH="$GOPATH/src/github.com/docker/notary/Godeps/_workspace:$GOPATH" \
177+
go build -o /usr/local/bin/notary github.com/docker/notary/cmd/notary \
178+
&& rm -rf "$GOPATH"
179+
180+
# Get the "docker-py" source so we can run their integration tests
181+
ENV DOCKER_PY_COMMIT e2878cbcc3a7eef99917adc1be252800b0e41ece
182+
RUN git clone https://github.com/docker/docker-py.git /docker-py \
183+
&& cd /docker-py \
184+
&& git checkout -q $DOCKER_PY_COMMIT \
185+
&& pip install -r test-requirements.txt
186+
187+
# Setup s3cmd config
188+
RUN { \
189+
echo '[default]'; \
190+
echo 'access_key=$AWS_ACCESS_KEY'; \
191+
echo 'secret_key=$AWS_SECRET_KEY'; \
192+
} > ~/.s3cfg
193+
194+
# Set user.email so crosbymichael's in-container merge commits go smoothly
195+
RUN git config --global user.email '[email protected]'
196+
197+
# Add an unprivileged user to be used for tests which need it
198+
RUN groupadd -r docker
199+
RUN useradd --create-home --gid docker unprivilegeduser
200+
201+
VOLUME /var/lib/docker
202+
WORKDIR /go/src/github.com/docker/docker
203+
ENV DOCKER_BUILDTAGS apparmor seccomp selinux
204+
205+
# Let us use a .bashrc file
206+
RUN ln -sfv $PWD/.bashrc ~/.bashrc
207+
208+
# Register Docker's bash completion.
209+
RUN ln -sv $PWD/contrib/completion/bash/docker /etc/bash_completion.d/docker
210+
211+
# Get useful and necessary Hub images so we can "docker load" locally instead of pulling
212+
COPY contrib/download-frozen-image-v2.sh /go/src/github.com/docker/docker/contrib/
213+
RUN ./contrib/download-frozen-image-v2.sh /docker-frozen-images \
214+
buildpack-deps:jessie@sha256:25785f89240fbcdd8a74bdaf30dd5599a9523882c6dfc567f2e9ef7cf6f79db6 \
215+
busybox:latest@sha256:e4f93f6ed15a0cdd342f5aae387886fba0ab98af0a102da6276eaf24d6e6ade0 \
216+
debian:jessie@sha256:f968f10b4b523737e253a97eac59b0d1420b5c19b69928d35801a6373ffe330e \
217+
hello-world:latest@sha256:8be990ef2aeb16dbcb9271ddfe2610fa6658d13f6dfb8bc72074cc1ca36966a7
218+
# see also "hack/make/.ensure-frozen-images" (which needs to be updated any time this list is)
219+
220+
# Download man page generator
221+
RUN set -x \
222+
&& export GOPATH="$(mktemp -d)" \
223+
&& git clone --depth 1 -b v1.0.4 https://github.com/cpuguy83/go-md2man.git "$GOPATH/src/github.com/cpuguy83/go-md2man" \
224+
&& git clone --depth 1 -b v1.4 https://github.com/russross/blackfriday.git "$GOPATH/src/github.com/russross/blackfriday" \
225+
&& go get -v -d github.com/cpuguy83/go-md2man \
226+
&& go build -v -o /usr/local/bin/go-md2man github.com/cpuguy83/go-md2man \
227+
&& rm -rf "$GOPATH"
228+
229+
# Download toml validator
230+
ENV TOMLV_COMMIT 9baf8a8a9f2ed20a8e54160840c492f937eeaf9a
231+
RUN set -x \
232+
&& export GOPATH="$(mktemp -d)" \
233+
&& git clone https://github.com/BurntSushi/toml.git "$GOPATH/src/github.com/BurntSushi/toml" \
234+
&& (cd "$GOPATH/src/github.com/BurntSushi/toml" && git checkout -q "$TOMLV_COMMIT") \
235+
&& go build -v -o /usr/local/bin/tomlv github.com/BurntSushi/toml/cmd/tomlv \
236+
&& rm -rf "$GOPATH"
237+
238+
# Build/install the tool for embedding resources in Windows binaries
239+
ENV RSRC_COMMIT ba14da1f827188454a4591717fff29999010887f
240+
RUN set -x \
241+
&& export GOPATH="$(mktemp -d)" \
242+
&& git clone https://github.com/akavel/rsrc.git "$GOPATH/src/github.com/akavel/rsrc" \
243+
&& (cd "$GOPATH/src/github.com/akavel/rsrc" && git checkout -q "$RSRC_COMMIT") \
244+
&& go build -v -o /usr/local/bin/rsrc github.com/akavel/rsrc \
245+
&& rm -rf "$GOPATH"
246+
247+
# Wrap all commands in the "docker-in-docker" script to allow nested containers
248+
ENTRYPOINT ["hack/dind"]
249+
250+
# Upload docker source
251+
COPY . /go/src/github.com/docker/docker

0 commit comments

Comments
 (0)