forked from pires/kubernetes-vagrant-coreos-cluster
-
Notifications
You must be signed in to change notification settings - Fork 1
/
node.yaml
143 lines (141 loc) · 4.85 KB
/
node.yaml
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
#cloud-config
---
write-files:
- path: /etc/conf.d/nfs
permissions: '0644'
content: |
OPTS_RPC_MOUNTD=""
- path: /opt/bin/wupiao
permissions: '0755'
content: |
#!/bin/bash
# [w]ait [u]ntil [p]ort [i]s [a]ctually [o]pen
[ -n "$1" ] && \
until curl -o /dev/null -sIf http://${1}; do \
sleep 1 && echo .;
done;
exit $?
coreos:
units:
- name: rpcbind.service
enable: true
command: start
- name: rpc-statd.service
enable: true
command: start
- name: etcd-member.service
command: start
content: |
[Unit]
Description=etcd
Documentation=https://github.com/coreos/etcd
[Service]
Environment='ETCD_IMAGE_TAG=v3.1.8'
Environment='ETCD_DATA_DIR=/var/lib/etcd'
Environment='ETCD_USER=etcd'
Type=notify
Restart=always
RestartSec=5s
LimitNOFILE=40000
TimeoutStartSec=0
ExecStart=/usr/lib/coreos/etcd-wrapper --name __NAME__ \
--proxy on \
--listen-client-urls http://0.0.0.0:2379,http://0.0.0.0:4001 \
--advertise-client-urls http://$public_ipv4:2379,http://$public_ipv4:4001 \
--listen-peer-urls http://$private_ipv4:2380,http://$private_ipv4:7001 \
--initial-advertise-peer-urls http://$private_ipv4:2380 \
--initial-cluster __ETCD_SEED_CLUSTER__
[Install]
WantedBy=multi-user.target
- name: docker.service
command: start
drop-ins:
- name: 51-docker-mirror.conf
- __PROXY_LINE__name: http-proxy.conf
__PROXY_LINE__content: |
__PROXY_LINE__[Service]
__PROXY_LINE__EnvironmentFile=/etc/environment
- name: 50-docker-options.conf
content: |
[Service]
Environment='DOCKER_OPTS=__DOCKER_OPTIONS__'
- name: early-docker.service
drop-ins:
- __PROXY_LINE__name: http-proxy.conf
__PROXY_LINE__content: |
__PROXY_LINE__[Service]
__PROXY_LINE__EnvironmentFile=/etc/environment
- name: kube-certs.service
command: start
content: |
[Unit]
Description=Generate Kubernetes Node certificates
ConditionPathExists=/tmp/make-certs.sh
Requires=network-online.target
After=network-online.target
[Service]
ExecStartPre=-/usr/sbin/groupadd -r kube-cert
ExecStartPre=/usr/bin/chmod 755 /tmp/make-certs.sh
ExecStart=/tmp/make-certs.sh
Type=oneshot
RemainAfterExit=true
- name: hyperkube-import.service
command: start
content: |
[Unit]
Description=Import Hyperkube Docker image
Requires=docker.service
After=docker.service
ConditionPathExists=/vagrant/artifacts/hyperkube___RELEASE__.tar
[Service]
ExecStart=/usr/bin/docker load --input /vagrant/artifacts/hyperkube___RELEASE__.tar
Type=oneshot
RemainAfterExit=true
- name: kube-kubelet.service
command: start
content: |
[Unit]
Description=Kubernetes Kubelet
Documentation=https://github.com/GoogleCloudPlatform/kubernetes
Requires=hyperkube-import.service kube-certs.service
After=hyperkube-import.service kube-certs.service
[Service]
ExecStartPre=/usr/bin/mkdir -p /etc/kubernetes/manifests
ExecStartPre=-/usr/bin/docker rm -f kubelet
ExecStart=/usr/bin/docker run \
--volume=/:/rootfs:ro \
--volume=/sys:/sys:ro \
--volume=/etc/cni/net.d:/etc/cni/net.d:rw \
--volume=/opt/cni/bin:/opt/cni/bin:rw \
--volume=/etc/kubernetes:/etc/kubernetes:ro \
--volume=/var/lib/calico/:/var/lib/calico:rw \
--volume=/var/lib/docker/:/var/lib/docker:rw \
--volume=/var/lib/kubelet/:/var/lib/kubelet:shared \
--volume=/var/run:/var/run:rw \
--net=host \
--pid=host \
--privileged=true \
--name=kubelet \
-d \
gcr.io/google_containers/hyperkube-amd64:__RELEASE__ \
/hyperkube kubelet \
--containerized \
--address=$private_ipv4 \
--allow-privileged=true \
--pod-manifest-path=/etc/kubernetes/manifests \
--hostname-override=$public_ipv4 \
--cluster_dns=10.100.0.10 \
--cluster_domain=__DNS_DOMAIN__ \
--kubeconfig=/etc/kubernetes/node-kubeconfig.yaml \
--tls-cert-file=/etc/kubernetes/ssl/node.pem \
--tls-private-key-file=/etc/kubernetes/ssl/node-key.pem \
--network-plugin=cni \
--pod-cidr=__CLUSTER_CIDR__
Restart=on-failure
RestartSec=10
WorkingDirectory=/root/
[Install]
WantedBy=multi-user.target
update:
group: __CHANNEL__
reboot-strategy: off