Ubuntu16.04 环境 Kubeedge安装「建议收藏」

Ubuntu16.04 环境 Kubeedge安装「建议收藏」前期准备换源#备份sudocp/etc/apt/sources.list/etc/apt/sources.list.bak#更新sources.listsudotee/etc/apt/sources.list<<-‘EOF’debhttp://mirrors.aliyun.com/ubuntu/xenialmaindeb-srchttp://mirrors.aliyun.com/ubuntu/xenialmaindebhttp://mirr

大家好,又见面了,我是你们的朋友全栈君。

前期准备

换源

# 备份
sudo cp /etc/apt/sources.list /etc/apt/sources.list.bak
# 更新 sources.list
sudo tee /etc/apt/sources.list <<-'EOF'
deb http://mirrors.aliyun.com/ubuntu/ xenial main
deb-src http://mirrors.aliyun.com/ubuntu/ xenial main

deb http://mirrors.aliyun.com/ubuntu/ xenial-updates main
deb-src http://mirrors.aliyun.com/ubuntu/ xenial-updates main

deb http://mirrors.aliyun.com/ubuntu/ xenial universe
deb-src http://mirrors.aliyun.com/ubuntu/ xenial universe
deb http://mirrors.aliyun.com/ubuntu/ xenial-updates universe
deb-src http://mirrors.aliyun.com/ubuntu/ xenial-updates universe

deb http://mirrors.aliyun.com/ubuntu/ xenial-security main
deb-src http://mirrors.aliyun.com/ubuntu/ xenial-security main
deb http://mirrors.aliyun.com/ubuntu/ xenial-security universe
deb-src http://mirrors.aliyun.com/ubuntu/ xenial-security universe
EOF
sudo apt-get update

docker 安装(apt安装)

apt -y install docker.io

kubernetes 安装

关闭swapp

sudo sed -i '/ swap / s/^/#/' /etc/fstab
sudo swapoff -a

关闭防火墙

sudo ufw disable

安装 kubeadm, kubelet and kubectl

# 安装依赖
sudo apt-get update && apt-get install -y apt-transport-https
# 加载key
sudo curl https://mirrors.aliyun.com/kubernetes/apt/doc/apt-key.gpg | apt-key add - 
# 添加源
sudo cat <<EOF >/etc/apt/sources.list.d/kubernetes.list
deb https://mirrors.aliyun.com/kubernetes/apt/ kubernetes-xenial main
EOF
# 安装
sudo apt-get update
# apt-cache madison kubelet 命令可查找软件版本,制定版本安装
sudo apt-get install -y kubelet=1.18.0-00 kubeadm=1.18.0-00  kubectl=1.18.0-00

使用kubeadm 部署集群

# apiserver-advertise-address,pod-network-cidr根据本地环境修改
sudo kubeadm init --apiserver-advertise-address 192.168.0.49  \
--image-repository=registry.aliyuncs.com/google_containers \
--pod-network-cidr=10.244.0.0/16

如果看到如下提示,说明部署成功。记下这个条语句,将来的部署node节点时需要。

kubeadm join 192.168.0.49:6443 --token fkxju7.d39l2sct5bc4w5yo \
    --discovery-token-ca-cert-hash sha256:28b467ec8f97537069724028c5d51650983b8bbc2ac29a6e52b210bb2d1896ff 

配置本地用户执行权限

mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config

安装网络插件

kubectl apply -f https://docs.projectcalico.org/v3.14/manifests/calico.yaml

k8s 默认不会调度到master节点上

kubectl taint nodes --all node-role.kubernetes.io/master-

到这里,kubernetes 集群就创建成功了

Kubeedge 安装 (二进制安装)

下载二进制文件并解压

wget https://github.com/kubeedge/kubeedge/releases/download/v1.3.1/kubeedge-v1.3.1-linux-amd64.tar.gz
tar -xzvf kubeedge-v1.3.1-linux-amd64.tar.gz
mv kubeedge-v1.3.1-linux-amd64 kubeedge-v1.3.1

安装crds

cd kubeedge/build/crds/devices
kubectl create -f devices_v1alpha1_devicemodel.yaml
kubectl create -f devices_v1alpha1_device.yaml

cd kubeedge/build/crds/reliablesyncs
kubectl create -f cluster_objectsync_v1alpha1.yaml
kubectl create -f objectsync_v1alpha1.yaml

拷贝二进制文件到/usr/local/bin/目录

cp kubeedge/cloud/cloudcore /usr/local/bin/

配置云端节点

mkdir -p /etc/kubeedge/config/ 
cloudcore --minconfig > /etc/kubeedge/config/cloudcore.yaml 

修改配置文件

vim /etc/kubeedge/config/cloudcore.yaml 

注意根据你的环境修改以下三处。
1)kubeConfig的值
2)master的值
3)advertiseAddress的值,修改为master节点的IP

cloudcore 注册为service

cp kubeedge/build/tools/cloudcore.service   /etc/systemd/system
systemctl enable cloudcore
systemctl start cloudcore

云端安装完成

配置edge节点

安装 mosquitto

apt -y install mosquitto
apt-get install mosquitto-clients // 如果需要测试,则安装mqtt客户端

由于 KubeEdge 使用多个端口,故需用配置文件。服务端添加多端口:

vim /etc/mosquitto/conf.d/port.conf
port 1883
listener 1884
service mosquitto  restart

可以用如下命令验证服务是否正常

mosquitto_pub -h <mqtt服务IP> -p 1884 -t "hello" -m "this is hello world"

拷贝二进制文件到/usr/local/bin/目录

cp kubeedge/cloud/edgecore /usr/local/bin/

云端获取token(云端执行)

kubectl get secret tokensecret -n kubeedge -oyaml

root@k8sMaster:~# kubectl get secret tokensecret -n kubeedge -oyaml 
apiVersion: v1
data:
  tokendata: MjkyOGJjMDQ4MjE4YWYyODk0OWFlOGYxNjQ4ZTY5MjQzYmY5N2ZmYTMxNTRlZGZlOWQ1MWI4YTAyYmRlMzY2YS5leUpoYkdjaU9pSklVekkxTmlJc0luUjVjQ0k2SWtwWFZDSjkuZXlKbGVIQWlPakUyTVRNNE9EZzNPREY5LnAwaXIxZmlGVUlzQ3R0ZGdFTHZ5b3pmc1l4SVM3eHZ0cnZLZjNfSWIzMmM=
kind: Secret
...

#解码
echo MjkyOGJjMDQ4MjE4YWYyODk0OWFlOGYxNjQ4ZTY5MjQzYmY5N2ZmYTMxNTRlZGZlOWQ1MWI4YTAyYmRlMzY2YS5leUpoYkdjaU9pSklVekkxTmlJc0luUjVjQ0k2SWtwWFZDSjkuZXlKbGVIQWlPakUyTVRNNE9EZzNPREY5LnAwaXIxZmlGVUlzQ3R0ZGdFTHZ5b3pmc1l4SVM3eHZ0cnZLZjNfSWIzMmM= | base64 -d 

#输出
2928bc048218af28949ae8f1648e69243bf97ffa3154edfe9d51b8a02bde366a.eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJleHAiOjE2MTM4ODg3ODF9.p0ir1fiFUIsCttdgELvyozfsYxIS7xvtrvKf3_Ib32c

配置边缘节点

mkdir -p /etc/kubeedge/config
edgecore --minconfig > /etc/kubeedge/config/edgecore.yaml

修改边缘节点

# vim /etc/kubeedge/config/edgecore.yaml

注意4处地方。

  1. 修改edgehub下的token,为云端获取的token值
  2. 修改websocket下的server,默认为127.0.0.1:10000,需改为实际云端 IP 地址,此处为192.168.0.49:10000
  3. 修改(确认)podSandboxImage,X86平台为podSandboxImage: kubeedge/pause:3.1(默认),ARM 平台根据位数不同,可设为kubeedge/pause-arm:3.1ubeedge/pause-arm64:3.1
  4. 填写 edgeHub 下的 token 值,见 3.2.2 小节生成的结果。
    其它要点:cgroup 驱动默认值为:cgroupDriver: cgroupfs,无须改 Docker 配置。网络设备接口名称及 IP 地址,会运行上述命令时自动检测获取,无须修改(注:在一台虚拟机中,网卡为 enp0s3,但配置文件中依然为 eth0)

edgecore 注册为service

cp kubeedge/build/tools/edgecore.service   /etc/systemd/system
systemctl enable edgecore
systemctl start edgecore

边缘安装完成

查看节点状态

root@k8sMaster:/var/log# kubectl get node 
NAME          STATUS   ROLES        AGE     VERSION
edge-node     Ready    agent,edge   39m     v1.19.3-kubeedge-v1.6.0-beta.0
k8smaster     Ready    master       3h45m   v1.18.0

清除kubeedge

kubeedge运行文件:
1、/etc/kubeedge/: 证书、配置文件(云边均有)。
2、/var/lib/kubeedge/: 云端有socket文件kubeedge.sock ,边缘端有数据库文件edgecore.db。

如果要完全清理kubeedge环境,上述目录需要删除。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/162720.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • find 命令的 7 种用法[通俗易懂]

    find 命令的 7 种用法[通俗易懂]首先我们需要使用cd命令进入对应的目录,然后,命令如下:find.-typef-atime+365-execrm-rf{}\;如果你还没有完全理解上面的命令,完全不用担心。本文将介绍find命令的7个实际用途,您最终会掌握它。如果您已经知道了,那么阅读这篇文章对您来说将是一个很好的回顾。0.按名称或正则表达式查找文件让我们从最简单的用法开始。要按特定名称搜索文件,命令如下:find.-nametest.txt如何查找所有格式为pdf…

    2022年10月14日
    1
  • js中set和map的区别_list和set

    js中set和map的区别_list和setSet和Map的区别

    2025年9月29日
    1
  • python初级:基础知识-字符串

    python初级:基础知识-字符串

    2021年10月6日
    46
  • 图文详解| Node.js安装及环境配置之Windows篇

    图文详解| Node.js安装及环境配置之Windows篇

    2022年2月19日
    36
  • 风控模型评估

    风控模型评估  本文总结了一下评分卡建模过程中常用的模型评估方法,并结合代码展示,理论结合实际,方便初学者对模型评估的方法有深入的理解。之前写过一篇模型评估的指标,偏于理论,详情见风控模型指标详解。1.AUC  AUC值指的是ROC曲线下面积大小,该值能够量化反映基于ROC曲线衡量的模型性能。所以,需要了解ROC曲线的绘制方法。  首先,需要了解TPR(真阳性率)和FPR(假阳性率)。TPR就是P个正…

    2022年4月30日
    146
  • cg tut_cg和cgk的区别

    cg tut_cg和cgk的区别GestureDrawingwithAlexWooGestureDrawingwithAlexWooandLouisGonzaleshttp://eisneim.com/?page_id=1271——————————Animation——————————BasicsAnimation…

    2022年9月25日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号