-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathDockerfile
69 lines (59 loc) · 2.77 KB
/
Dockerfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
# Copyright 2015 Skippbox, Ltd
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
FROM boot2docker/boot2docker
#Install Kubelet and Kubelet manifest
ENV K8S_VERSION=v1.2.0
RUN curl -fL -o $ROOTFS/usr/local/bin/kubectl https://storage.googleapis.com/kubernetes-release/release/v1.2.0/bin/linux/amd64/kubectl
#RUN mv kubelet /usr/bin/kubelet
RUN chmod +x $ROOTFS/usr/local/bin/kubelet
RUN chmod +x $ROOTFS/usr/local/bin/kubectl
RUN mkdir -p $ROOTFS/etc/kubernetes/manifests/
RUN mkdir -p $ROOTFS/etc/kubernetes/policies/
#RUN mkdir -p $ROOTFS/etc/kubernetes/certs/
RUN mkdir -p $ROOTFS/var/run/kubernetes/apiserver
RUN mkdir -p $ROOTFS/var/run/kubernetes/proxyserver
RUN mkdir -p $ROOTFS/var/run/kubernetes/kubelet
COPY kubernetes.yaml $ROOTFS/etc/kubernetes/manifests/kubernetes.yaml
COPY kubelet.kubeconfig $ROOTFS/etc/kubernetes/kubelet.kubeconfig
#COPY policy.jsonl $ROOTFS/etc/kubernetes/policies/policy.jsonl
#Create Kubelet service
#RUN { echo '[Unit]'; \
# echo 'Description=Kubernetes Kubelet'; \
# echo 'Documentation=https://github.com/kubernetes/kubernetes'; \
# echo; \
# echo '[Service]'; \
# echo 'ExecStart=/usr/local/bin/kubelet \'; \
# echo '--api-servers=http://127.0.0.1:8080 \'; \
# echo '--allow-privileged=true \'; \
# echo '--config=/usr/local/etc/kubernetes/manifests \'; \
# echo '--v=2'; \
# echo 'Restart=on-failure'; \
# echo 'RestartSec=5'; \
# echo; \
# echo '[Install]'; \
# echo 'WantedBy=multi-user.target'; \
# } > $ROOTFS/etc/systemd/system/kubelet.service
#COPY k8s.sh $ROOTFS/etc/boot2docker/hooks/after-docker.d/k8s.sh
COPY kubelet.sh $ROOTFS/usr/local/etc/init.d/kubelet
RUN chmod +x $ROOTFS/usr/local/etc/init.d/kubelet
RUN ln -s /usr/local/etc/init.d/kubelet $ROOTFS/etc/init.d/kubelet
COPY k8s.sh $ROOTFS/etc/rc.d/k8s.sh
RUN chmod +x $ROOTFS/etc/rc.d/k8s.sh
# Disabled to allow for activation by way of docker-machine
RUN echo "/etc/rc.d/k8s.sh" >> $ROOTFS/opt/bootscript.sh
RUN echo "docker run --rm -v /var/lib/boot2docker/:/target jpetazzo/nsenter" >> $ROOTFS/opt/bootscript.sh
# Copy socat into place
COPY deps/bin/socat $ROOTFS/usr/bin/socat
RUN /make_iso.sh
CMD ["cat", "boot2docker.iso"]