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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • VS2017配置opencv教程(超详细!!!)[通俗易懂]

    VS2017配置opencv教程(超详细!!!)[通俗易懂]前言:刚开始是不打算写这篇博客的,但是我最近为了完成对老师布置的区域生长算法,强行要配置一波opencv,因为换了电脑,所以选择了有黑黑主题酷酷的VS2017,但无奈网上的博客关于vs2017配置Opencv不够全(vs2010配置opencv的倒是贼多!),我当时是看了将近10篇文章才配置成功,所以在此我来从一个新入坑的角度来说一下怎么完整的配置一个OPencv!下面就分步来进行说明吧!…

    2022年6月13日
    30
  • rabbitmqkafka对比_全场景

    rabbitmqkafka对比_全场景这是陈东景于2021年8月29日下午16点原创作品,转载请标明出处!!!!在进行软件设计的过程中,如果软件设计业务上存在需要短时间内处理大批量的信息,又需要能保证软件能正常运行(保证软件的高可靠和高可用)。因为大批量(几十万,几百万级别的数据或者消息需要同一个时间处理),软件的IO过高,会导致软件运行阻塞或者消耗内存过高而崩溃,甚至是宕机。消息队列的概念被提了出来,通过缓存消息的模式,进行生产和消费。通过异步处理的方式,解耦这种短时间内出现大批量需要处理消息的场景。目前我们使用到的比…

    2022年10月14日
    5
  • VMware Workstation网络连接的三种方式原理详解 与 配置过程图解

    VMware Workstation网络连接的三种方式原理详解 与 配置过程图解

    2021年10月5日
    43
  • redis可视化客户端工具TreeNMS

    redis可视化客户端工具TreeNMS

    2021年11月3日
    60
  • 泰克|安捷伦|普源|PICO示波器程控软件二次开发NS-Scope

    泰克|安捷伦|普源|PICO示波器程控软件二次开发NS-Scope*主要功能:硬件连接;参数配置;运行参数;数据查询。*程控对象:示波器。*程控接口:兼容市面上所有具有GPIB、USB、RS232、LAN、RS485、TTL任意一种程控接口的示波器。*仪器兼容性:泰克Tektronix、是德科技Keysight、普源Rigol、力科、罗德与施瓦茨R&S等品牌示波器。1.软件概述>>为了解决示波器测试操作流程繁琐、参数配置复杂等问题,Namisoft开发的NS-Scope示波器自动化测试程控软件,通过对示波器的程序控制,…

    2022年10月12日
    3
  • 前端参数用MD5加密[通俗易懂]

    前端参数用MD5加密[通俗易懂]今天来讲一下如何用这个MD5来加密第一步:两种导入MD5.js一种你可以到以下这个地址去下载MD5的js路径:https://www.bootcdn.cn/blueimp-md5/另一种下面是md5的js,直接复制下去放到js文件里。亲测可用varhexcase=0;varb64pad=&quot;&quot;;varchrsz=8;functionhex_md…

    2022年7月11日
    53

发表回复

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

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