Merge pull request #2537 from ijc/kubernetes

kubernetes: build kubelet from source & add openssl
This commit is contained in:
Ian Campbell 2017-09-27 12:13:53 +01:00 committed by GitHub
commit 4729125077
3 changed files with 36 additions and 7 deletions

View File

@ -36,7 +36,7 @@ services:
- name: sshd
image: linuxkit/sshd:d313eea3d9d7fbcbc927d06a6700325725db2a82
- name: kubelet
image: linuxkitprojects/kubernetes:4eba50ea1fae6f881c65429b9c21afadcdeec853
image: linuxkitprojects/kubernetes:f3be02879f599ed59be5e307b866249e1a2f2eff
files:
- path: etc/linuxkit.yml
metadata: yaml

View File

@ -1,14 +1,39 @@
FROM linuxkit/alpine:79987c65c66700171c073151c1d3f0372597bec2 AS build
FROM linuxkit/alpine:28254e4530703db4caa6b0199a025c30a987dfa1 AS build
ENV kubernetes_version v1.7.6
ENV cni_version v0.6.0
ENV kube_release_artefacts "https://dl.k8s.io/${kubernetes_version}/bin/linux/amd64"
RUN apk add -U --no-cache \
bash \
coreutils \
curl \
findutils \
git \
go \
grep \
libc-dev \
linux-headers \
make \
rsync \
&& true
ENV GOPATH=/go PATH=$PATH:/go/bin
ENV KUBERNETES_URL https://github.com/kubernetes/kubernetes.git
#ENV KUBERNETES_BRANCH pull/NNN/head
ENV KUBERNETES_COMMIT ${kubernetes_version}
RUN mkdir -p $GOPATH/src/github.com/kubernetes && \
cd $GOPATH/src/github.com/kubernetes && \
git clone $KUBERNETES_URL kubernetes
WORKDIR $GOPATH/src/github.com/kubernetes/kubernetes
RUN set -e; \
if [ -n "$KUBERNETES_BRANCH" ] ; then \
git fetch origin "$KUBERNETES_BRANCH"; \
fi; \
git checkout $KUBERNETES_COMMIT
RUN make WHAT="cmd/kubelet cmd/kubectl cmd/kubeadm"
RUN mkdir -p /out/etc/apk && cp -r /etc/apk/* /out/etc/apk/
#coreutils needed for du -B for disk image checks made by kubelet
# example: $ du -s -B 1 /var/lib/kubelet/pods/...
@ -25,18 +50,21 @@ RUN apk add --no-cache --initdb -p /out \
iptables \
libc6-compat \
musl \
openssl \
socat \
util-linux \
&& true
RUN cp _output/bin/kubelet /out/usr/bin/kubelet
RUN cp _output/bin/kubeadm /out/usr/bin/kubeadm
RUN cp _output/bin/kubectl /out/usr/bin/kubectl
# Remove apk residuals. We have a read-only rootfs, so apk is of no use.
RUN rm -rf /out/etc/apk /out/lib/apk /out/var/cache
RUN rmdir /out/var/run && ln -nfs /run /out/var/run
RUN curl -fSL -o /out/root/cni.tgz https://github.com/containernetworking/plugins/releases/download/${cni_version}/cni-plugins-amd64-${cni_version}.tgz
RUN curl -fSL -o /out/usr/bin/kubelet https://dl.k8s.io/${kubernetes_version}/bin/linux/amd64/kubelet && chmod 0755 /out/usr/bin/kubelet
RUN curl -fSL -o /out/usr/bin/kubeadm https://dl.k8s.io/${kubernetes_version}/bin/linux/amd64/kubeadm && chmod 0755 /out/usr/bin/kubeadm
RUN curl -fSL -o /out/usr/bin/kubectl https://dl.k8s.io/${kubernetes_version}/bin/linux/amd64/kubectl && chmod 0755 /out/usr/bin/kubectl
ADD kubelet.sh /out/usr/bin/kubelet.sh
ADD kubeadm-init.sh /kubeadm-init.sh

View File

@ -49,4 +49,5 @@ exec kubelet --kubeconfig=${conf} \
--network-plugin=cni \
--cni-conf-dir=/var/lib/cni/etc/net.d \
--cni-bin-dir=/var/lib/cni/opt/bin \
--cadvisor-port=0 \
$KUBELET_ARGS $@