-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathdeploydocker.sh
executable file
·66 lines (61 loc) · 2.15 KB
/
deploydocker.sh
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
source env.sh
mkdir -p ${DOCKER_PATH}
# 创建docker systemd service文件
echo "========创建docker systemd service文件========"
cat > ${DOCKER_PATH}/docker.service <<"EOF"
[Unit]
Description=Docker Application Container Engine
Documentation=https://docs.docker.com
After=network-online.target firewalld.service flanneld.service
Wants=network-online.target flanneld.service
[Service]
Type=notify
EnvironmentFile=-/run/flannel/docker
# the default is not to use systemd for cgroups because the delegate issues still
# exists and systemd currently does not support the cgroup feature set required
# for containers run by docker
ExecStart=/usr/bin/dockerd $DOCKER_NETWORK_OPTIONS
ExecReload=/bin/kill -s HUP $MAINPID
# Having non-zero Limit*s causes performance problems due to accounting overhead
# in the kernel. We recommend using cgroups to do container-local accounting.
LimitNOFILE=infinity
LimitNPROC=infinity
LimitCORE=infinity
# Uncomment TasksMax if your systemd version supports it.
# Only systemd 226 and above support this version.
#TasksMax=infinity
TimeoutStartSec=0
# set delegate yes so that systemd does not reset the cgroups of docker containers
Delegate=yes
# kill only the docker process, not all processes in the cgroup
KillMode=process
# restart the docker process if it exits prematurely
Restart=on-failure
StartLimitBurst=3
StartLimitInterval=60s
[Install]
WantedBy=multi-user.target
EOF
cat ${DOCKER_PATH}/docker.service
# 分发docker systemd service文件和启动
echo "========分发docker systemd service文件和启动========"
for node_ip in ${NODE_IPS[@]}
do
echo ">>> ${node_ip}"
echo "分发docker.service"
scp ${DOCKER_PATH}/docker.service \
root@${node_ip}:/usr/lib/systemd/system/
echo "启动docker"
ssh root@${node_ip} "
systemctl stop firewalld
systemctl disable firewalld
systemctl daemon-reload
systemctl enable docker
systemctl restart docker
echo 'wait 3s for docker up'
sleep 3
systemctl status docker | grep Active
/usr/sbin/ip addr show flannel.1
/usr/sbin/ip addr show docker0"
if [ $? -ne 0 ];then echo "启动docker失败,退出脚本";exit 1;fi
done