Kubernetes集群部署(flannel网络配置)

Kubernetes集群部署(flannel网络配置)

  • 一.docker引擎部署
  • 二.flannel网络配置
    • 1.master(192.168.159.128)
    • 2.node(192.168.159.129、130)

一.docker引擎部署

所有node节点部署docker引擎,这边就不一一部署,详见docker安装脚本

二.flannel网络配置

1.master(192.168.159.128)

##写入分配的子网段到ETCD中,供flannel使用##

/opt/etcd/bin/etcdctl --ca-file=ca.pem --cert-file=server.pem --key-file=server-key.pem --endpoints="https://192.168.159.128:2379,https://192.168.159.129:2379,https://192.168.159.130:2379" set /coreos.com/network/config '{ "Network": "172.17.0.0/16", "Backend": {"Type": "vxlan"}}'

Kubernetes集群部署(flannel网络配置)_第1张图片

##查看写入信息##

/opt/etcd/bin/etcdctl --ca-file=ca.pem --cert-file=server.pem --key-file=server-key.pem --endpoints="https://192.168.159.128:2379,https://192.168.159.129:2379,https://192.168.159.130:2379" get /coreos.com/network/config

Kubernetes集群部署(flannel网络配置)_第2张图片
##拷贝到所有node节点##

scp flannel-v0.10.0-linux-amd64.tar.gz [email protected]:/root
scp flannel-v0.10.0-linux-amd64.tar.gz [email protected]:/root

Kubernetes集群部署(flannel网络配置)_第3张图片

2.node(192.168.159.129、130)

tar zxvf flannel-v0.10.0-linux-amd64.tar.gz 
mkdir /opt/kubernetes/{cfg,bin,ssl} -p
mv mk-docker-opts.sh flanneld /opt/kubernetes/bin/

vim flannel.sh
#!/bin/bash

ETCD_ENDPOINTS=${1:-"http://127.0.0.1:2379"}

cat </opt/kubernetes/cfg/flanneld

FLANNEL_OPTIONS="--etcd-endpoints=${ETCD_ENDPOINTS} \
-etcd-cafile=/opt/etcd/ssl/ca.pem \
-etcd-certfile=/opt/etcd/ssl/server.pem \
-etcd-keyfile=/opt/etcd/ssl/server-key.pem"

EOF

cat </usr/lib/systemd/system/flanneld.service
[Unit]
Description=Flanneld overlay address etcd agent
After=network-online.target network.target
Before=docker.service

[Service]
Type=notify
EnvironmentFile=/opt/kubernetes/cfg/flanneld
ExecStart=/opt/kubernetes/bin/flanneld --ip-masq \$FLANNEL_OPTIONS
ExecStartPost=/opt/kubernetes/bin/mk-docker-opts.sh -k DOCKER_NETWORK_OPTIONS -d /run/flannel/subnet.env
Restart=on-failure

[Install]
WantedBy=multi-user.target

EOF

systemctl daemon-reload
systemctl enable flanneld
systemctl restart flanneld

##这上面都是脚本内容##

Kubernetes集群部署(flannel网络配置)_第4张图片
##开启flannel网络功能##

. flannel.sh https://192.168.159.128:2379,https://192.168.159.129:2379,https://192.168.159.130:2379

systemctl status flanneld.service 
cat /run/flannel/subnet.env           #查看网段环境变量文件

在这里插入图片描述

Kubernetes集群部署(flannel网络配置)_第5张图片
Kubernetes集群部署(flannel网络配置)_第6张图片

##配置docker连接flannel##

vim /usr/lib/systemd/system/docker.service
EnvironmentFile=/run/flannel/subnet.env            #13行插入
$DOCKER_NETWORK_OPTIONS                            #14行-H 前加入

##重启docker服务##

systemctl daemon-reload
systemctl restart docker

##查看flannel网络##

ifconfig

##测试ping通对方docker0网卡 证明flannel起到路由作用##
docker run -it centos:7 /bin/bash                    #启动容器并进入

yum install net-tools -y
ifconfig
##再次测试ping通两个node中的centos:7容器##

Kubernetes集群部署(flannel网络配置)_第7张图片
Kubernetes集群部署(flannel网络配置)_第8张图片
Kubernetes集群部署(flannel网络配置)_第9张图片
Kubernetes集群部署(flannel网络配置)_第10张图片

Kubernetes集群部署(flannel网络配置)_第11张图片

你可能感兴趣的:(k8s)