【kubeEdge】离线部署

部署 kubeEdge

在线部署

在线方式部署直接执行以下命令,会联网下载需要的安装文件执行安装

$ keadm init --advertise-address={ip} --kubeedge-version={version} --kube-config={config_path},

离线部署

离线准备工作

所有下载操作均在可以联网的机子上进行,然后复制到需要安装的部署机

从 kubeEdge 的官方 git 仓库的 https://github.com/kubeedge/kubeedge/releases 中获取合适的版本的 keadm 和 kubeedge 包,以及校验包

在云端和边端主机上,都执行下面的步骤:

  • 将 keadm 压缩包中的可执行文件 keadm 复制到 ​​/usr/local/bin​​ 下 tar -xvf
  • 将 kubeedge 压缩包(cloudcore和edgecore的二进制文件)放置到 ​​/etc/kubeedge​​ 目录下
  • 将 checksum 放置到 ​​/etc/kubeedge​​ 目录下
  • 选择合适的版本,从 https://github.com/kubeedge/kubeedge 下载源码
云端 cloudcore
  1. 复制所需物料到云端主机
  1.   将源码中 ​​/build/crds​​​ 中的所有内容拷贝到云端部署机的 ​​/etc/kubeedge/crds​​ 目录
  2.   将源码中 ​​/build/tools/cloudcore.service​​​ 文件放置到云端部署机的 ​​/etc/kubeedge​​ 目录
  1. 使用下面的命令初始化 cloudcore
keadm init --advertise-address={ip} --kubeedge-versinotallow={version} --kube-cnotallow={config_path}
  1. ip 换成 cloudcore 所在的主机 ip
  2. version 换成自己的安装的版本,因为 keadm 默认版本不一定和我们需要的一样。
  3. config 路径指向 kubernetes 的配置路径,默认是​​/root/.kube/config​​,也可设置为 /etc/kubernetes/admin.conf
  4.   如果出现下面的内容,初始化成功
Kubernetes version verification passed, KubeEdge installation will start... 
KubeEdge cloudcore is running, For logs visit: /var/log/kubeedge/cloudcore.log 
CloudCore started
  1. 修改 flannel-ds 和 kube-proxy 的配置
  1.   通过kubectl edit ds -n kube-system kube-flannel-ds修改flannel配置:
  2.   通过kubectl edit ds -n kube-system kube-proxy修改kube-proxy配置:
  1. 云端配置文件 cloudcore.yaml
  1.   /etc/kubeedge/config/cloudcore.yaml
边端 edgecore
  1. 安装 MQTT 服务
  1.   在边缘节点还需要安装 MQTT 服务,需要以下的 deb 包和依赖:
  2.   下载 mosquitto 服务端和客户端以及依赖包
$ apt install mosquitto     
$ apt install mosquitto-clients
# 连配置卸载:apt autopurge  mosquitto
  1.   安装 apt 增强工具,并下载依赖包
# 创建目录
$ mkdir mosquitto
# apt 增强工具
$ apt install aptitude 
# 清理缓存空间
$ aptitude clean
# 只下载依赖且不安装
$ aptitude --download-only install mosquitto
# 将依赖deb从缓存拷贝置创建当前目录
$ mv /var/cache/apt/archives/*.deb ./
  1.   执行安装
$ dpkg -i ./mosquitto/*.deb
  1. 配置 MQTT 服务
  1.   添加配置文件
  2.   在​​/etc/mosquitto/conf.d​​​目录下,添加配置文件​​myconfig.conf​​ 配置文件:
sudo vi /etc/mosquitto/conf.d/myconfig.conf
  1.   粘入下面这些配置
#添加 broker 监听端口(很重要,否则只能本机访问)
listener 1883
#-------------------------------------------
# 如果关闭匿名访问,客户端必须使用用户名密码
allow_anonymous true#指定 用户名-密码 文件
password_file /etc/mosquitto/pwfile.txt
#--------------------------------------------
  1. 添加账户密码
sudo mosquitto_passwd -c /etc/mosquitto/pwfile.txt <<用户名>>
  1. 启动mosquitto查看运行状态
sudo service mosquitto start
sudo service mosquitto status
  1. 在云端运行 keadm gettoken 将返回 token 令牌,该令牌将在加入边缘节点时使用。
  2. 复制所需物料到边端主机
  1.   将源码中 ​​./build/tools/edgecore.service​​​ 文件复制到边端主机的 ​​/etc/kubeedge​​ 目录
  2.   通过下面的命令让边端纳入云端管理
$ keadm join --cloudcore-ipport={ip}:{port} --kubeedge-version={version} --token={token}
  1.   可以通过 journalctl -u edgecore.service -f 查看 edgecore 的日志,或在云端 kubectl get nodes 查看是否能看到我们刚加入的 edge 节点(systemcl status)
  1. 检查服务状态
service edgecore status
  1. 导入pause镜像
  1.   在能联网的机子上拉取 kubeedge/pause:3.1 镜像,使用 docker save -o kubeedge_pause_3.1.tar kubeedge/pause:3.1 命令打包,在边缘节点上,使用 docker load -i kubeedge_pause_3.1.tar 命令导入镜像
  1. 配置边端配置文件 edgecore.yaml
  1.   /etc/kubeedge/config/edgecore.yaml

edge Pod 实验

如果想要将应用调度到edge端,需要给edge端打上标签后,在应用的yaml文件中进行指定。

kubectl label nodes edge name=edge

根据k8s的这个规则,可以将节点通过 label 的方式进行分组,比如将某几个节点都打上标签为 name=edge,当调度应用到 edge 节点时,会找到 label 为 edge 的所有节点,根据设置的副本数,将应用启动起来,如果设置的副本数超过了设置 edge 标签的节点数,则多出的将会显示 pending 状态,从而无法启动。

编辑应用的 yaml 文件,添加 nodeSelector,下面给出一个例子 nginx.yaml

apiVersion: apps/v1
kind: Deployment
metadata:name: nginx-deploymentlabels:app: nginx
spec:replicas: 1selector:matchLabels:app: nginxtemplate:metadata:labels:app: nginxspec:nodeSelector: ##添加的配置name: "edge" ##打的标签是什么,这里就写什么containers:- name: nginximage: nginx:latestimagePullPolicy: IfNotPresentports:- containerPort: 80hostPort: 80

通过 kubectl get pod -o wide 查看,可看到该pod成功被部署到edge01节点上。

在边缘节点上查看容器 docker ps

启用 kubectl logs 功能

如果不开启此功能,在云端无法通过 kubectl logs 查看边端 pods 的日志

开启云端的 cloudStream 和边端的 edgeStream(websocketde 的另外一个通道10003),通过该通道传递数据

云端支持 Metrics-server

需要复用 kubectl logs 中的 cloudStream 和 edgeStream 的通道

重置部署

清除 keadm init 或 keadm join 造成的影响均可使用 keadm reset,这个操作会删除 /etc/kubeedge 下的文件,如有需要请提前备份。重置操作不会清理 /etc/mosquitto

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/823523.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CSS3 新特性 box-shadow 阴影效果、圆角border-radius

圆角 使用CSS3 border-radius属性&#xff0c;你可以给任何元素制作"圆角"&#xff0c;border-radius属性&#xff0c;可以使用以下规则&#xff1a; &#xff08;1&#xff09;四个值&#xff1a;第一个值为左上角&#xff0c;第二个值为右上角&#xff0c;第三个值…

Trigger触发器

触发器是指当满足预设的条件时去执行一些事务的工具&#xff0c;比如我们希望鼠标移到某个按钮上方时&#xff0c;这个按钮的颜色、大小发生一些改变。这个时候&#xff0c;条件是鼠标移到按钮上&#xff0c;执行的事务是改变按钮的颜色和大小。 触发器种类 触发器主要运用的场…

组织机构代码是哪几位?营业执照怎么看组织机构代码?

组织机构代码是哪几位? 组织机构代码通常指的是组织机构代码证上的一组特定数字&#xff0c;它用于唯一标识一个组织或机构。在中国&#xff0c;组织机构代码由9位数字组成&#xff0c;前8位是本体代码&#xff0c;最后1位是校验码。这组代码是按照国家有关标准编制的&#x…

GitHub repository - Pulse - Contributors - Network

GitHub repository - Pulse - Contributors - Network 1. Pulse2. Contributors3. NetworkReferences 1. Pulse 显示该仓库最近的活动信息。该仓库中的软件是无人问津&#xff0c;还是在火热地开发之中&#xff0c;从这里可以一目了然。 2. Contributors 显示对该仓库进行过…

Realsense D455 调试

1 Realsense D455 配置&#xff1a; RGB&#xff1a;彩色相机&#xff0c;FOV&#xff08;h&#xff0c;v&#xff09;&#xff08; 90*65 &#xff09;红外点阵发射&#xff1a;位于上图中RGB右边&#xff0c;发射特定模式的红外光&#xff0c;通常是一种点阵图案&#xff0c…

用Skimage学习数字图像处理(021):图像特征提取之线检测(下)

本节是特征提取之线检测的下篇&#xff0c;讨论基于Hough变换的线检测方法。首先简要介绍Hough变换的基本原理&#xff0c;然后重点介绍Skimage中含有的基于Hough变换的直线和圆形检测到实现。 目录 10.4 Hough变换 10.4.1 原理 10.4.2 实现 10.4 Hough变换 Hough变换&…

项目实现:Boost搜索引擎

目录 一.项目背景 二. 搜索引擎的宏观原理 三.使用到的技术栈与项目环境 四.正排索引vs倒排索引 五.认识标签与去标签 六.建立索引模块 七&#xff0c;编写http服务端 八&#xff0c;编写前端页面 九.搜索结果的优化 遇到的问题&#xff1a; 项目源码&#xff1a;boos…

JS/TS笔记学习1

周末总得学点什么吧~ 奥利给! 跑火车 递归 减速 let currentIndex 0; let speed 500; // 初始速度&#xff0c;单位是毫秒 let decrement 20; // 每次迭代速度减少的量 const cells document.querySelectorAll(.cell); function highlightCell() { cells.forEach(…

Boost电感的作用

Boost电感在Boost升压电路中起着关键的作用。Boost电路是一种DC-DC电源转换器&#xff0c;其主要功能是将低电压直流&#xff08;DC&#xff09;信号转换为高电压直流&#xff08;DC&#xff09;信号。Boost电感在这个过程中起着平滑电流、储存能量和提高电路效率的作用。 具体…

柯桥商务口语之怎么样说英语更加礼貌?十个礼貌用语get起来!

当你在国外需要帮助的时候&#xff0c;这些礼貌用语真的是能够帮到你的哦 1.Would/Could you help me? 你可帮助我吗&#xff1f; 相信有些人想请求帮助的时候&#xff0c;一开口就用Can you&#xff0c;这个用在朋友或者熟人上面当然是没有问题的&#xff0c;但是如果是向…

Node.js 中的 RSA 加密、解密、签名与验证详解

引言 在现代的网络通信中&#xff0c;数据安全显得尤为重要。RSA加密算法因其非对称的特性&#xff0c;广泛应用于数据的加密、解密、签名和验证等安全领域。本文将详细介绍RSA算法的基本原理&#xff0c;并结合Node.js环境&#xff0c;展示如何使用内置的crypto模块和第三方库…

基于 LSTM 模型的古诗词自动生成算法实现及系统实现

近年来&#xff0c;研究者在利用循环神经网络&#xff08;Recurrent Neural Network&#xff0c;RNN&#xff09;进行古诗自动生成方面取得了显著的效果。但 RNN 存在梯度问题&#xff0c;导致处理时间跨度较长的序列时 RNN 并不具备长期记忆存储功能。随后&#xff0c;出现的基…

【架构方法论(一)】架构的定义与架构要解决的问题

文章目录 一. 架构定义与架构的作用1. 系统与子系统2. 模块与组件3. 框架与架构4. 重新定义架构&#xff1a;4R 架构 二、架构设计的真正目的-别掉入架构设计的误区1. 是为了解决软件复杂度2. 简单的复杂度分析案例 三. 案例思考 本文关键字 架构定义 架构与系统的关系从业务逻…

企业linux-堡垒机与跳板机测试案例-6140字详谈

在开始今天内容前&#xff0c;小编先把专栏前面学的Linux命令&#xff08;部分&#xff09;做了思维导图帮助各位平时的学习&#xff1a; 场景&#xff1a; 运维人员管理三台机器&#xff0c;通过远程连接工具连接上三台机器&#xff0c;也知道这三台机器root密码&#xff0c…

【Java探索之旅】掌握数组操作,轻松应对编程挑战

&#x1f3a5; 屿小夏 &#xff1a; 个人主页 &#x1f525;个人专栏 &#xff1a; Java编程秘籍 &#x1f304; 莫道桑榆晚&#xff0c;为霞尚满天&#xff01; 文章目录 &#x1f4d1;前言一、数组巩固练习1.1 数组转字符串1.2 数组拷贝1.3 求数组中的平均值1.4 查找数组中指…

Windows版Apache 2.4.59解压直用(免安装-绿色-项目打包直接使用)

windows下Apache分类 Apache分为 安装版和解压版 安装版: 安装方便&#xff0c;下一步------下一步就OK了&#xff0c;但重装系统更换环境又要重新来一遍&#xff0c;会特别麻烦 解压版&#xff08;推荐&#xff09;&#xff1a; 这种方式&#xff08;项目打包特别方便&#x…

力扣哈哈哈哈

public class MyStack {int top;Queue<Integer> q1;Queue<Integer> q2;public MyStack() {q1new LinkedList<Integer>();q2new LinkedList<Integer>();}public void push(int x) {q2.offer(x);//offer是入队方法while (!q1.isEmpty()){q2.offer(q1.pol…

HPTNet:为点云提取表面特征

论文题目&#xff1a;High-Performance Feature Extraction Network for Point Cloud Semantic Segmentation 论文地址&#xff1a;https://ieeexplore.ieee.org/abstract/document/10474110 文章目录 1. 平面几何特征的提取2. 几何和语义特征的分开处理3. Transformer模块4. 结…

MySQL基础知识——MySQL事务

事务背景 什么是事务&#xff1f; 一组由一个或多个数据库操作组成的操作组&#xff0c;能够原子的执行&#xff0c;且事务间相互独立&#xff1b; 简单来说&#xff0c;事务就是要保证一组数据库操作&#xff0c;要么全部成功&#xff0c;要么全部失败。 注&#xff1a;MyS…

代码随想录算法训练营第一天 | 704. 二分查找 | 27. 移除元素

704. 二分查找 int search(int* nums, int numsSize, int target) {int left 0, right numsSize, mid;while (left < right) {mid left (right -left) / 2;if (nums[mid] < target) {left mid 1;} else if (nums[mid] > target) {right mid;} else {return mid…