树莓派使用Docker部署EdgeX(jakarta版本)
使用Docker部署EdgeX
老师安排我搞边缘计算,搞了很久都没能明白边缘计算是什么,甚至对其兴趣不大,前一阵弄好了lorawan网关,该做网关内部的边缘计算了,发现自己已经慢慢地学了进去,总是想要把这个东西搞完善。我都要着手准备考研了,居然还在这里搞这个,执念太深。后继无人啊,自己的孩子总怕没人好好养。
这几天查阅文献的时候发现了这个边缘计算框架,这个看起来不是很容易上手,国内的EMQX也在搞相关的东西,他那一套是Neutron+NanoMQ+eKuiper+EMQX,不过感觉会变成收费产品,于是还是了解了解这个从2017年就已经有了的开源项目EdgeX Foundry。
弄了三天,终于弄好了。这几天看了几个旧版的EdgeX相关博客,有的缺少一些docker-compose安装的内容,有的已经不再适用新版本,使用curl命令快速体验EdgeX的方法总是会受到网络的限制,经常433拒绝连接。于是选择了官方文档中的“Getting Started with Docker”
多说无益,正文开始
硬件环境:Raspberry 4B
软件环境:Linux raspberrypi 5.10.17-v8+ #1414 SMP PREEMPT Fri Apr 30 13:23:25 BST 2021 aarch64 GNU/Linux
系统镜像在下文的相关资料中,如果不会烧写镜像,可以找一找相关博客,烧写器和镜像在下文中已经一并给出
安装docker&docker-compose
安装docker-ce
添加GPG密钥
curl -fsSL https://mirrors.ustc.edu.cn/docker-ce/linux/raspbian/gpg | sudo apt-key add -
获取安装包
wget https://download.docker.com/linux/debian/dists/buster/pool/edge/arm64/containerd.io_1.3.7-1_arm64.deb
wget https://download.docker.com/linux/debian/dists/buster/pool/edge/arm64/docker-ce-cli_19.03.13~3-0~debian-buster_arm64.deb
wget https://download.docker.com/linux/debian/dists/buster/pool/edge/arm64/docker-ce_19.03.13~3-0~debian-buster_arm64.deb
设置docker镜像
sudo nano /etc/docker/daemon.json
填入内容
{
"registry-mirrors": ["http://hub-mirror.c.163.com"]
}
重载
sudo systemctl daemon-reload
sudo systemctl restart docker
验证安装
docker -v
Docker version 19.03.13, build 4484c46
安装docker-compose
sudo apt install python3-pip # 安装pip3
sudo apt install libffi-dev # 安装libffi
pip3 install docker-compose # 安装docker-compose
为安装的docker-compose添加环境变量
nano ~/.zshrc
填入
export PATH="${PATH}:/home/pi/.local/bin"
加载
source ~/.zshrc
验证安装
docker-compose -v
docker-compose version 1.29.2, build unknown
部署EdgeX
克隆edgexfoundry/edgex-compose
git clone https://github.com/edgexfoundry/edgex-compose.git
如果git clone时出现超时和断开连接的情况,可以看下文相关资料中的Github克隆加速
切换分支
cd edgex-compose/
git checkout jakarta
生成docker-compose.yml
cd compose-builder/
make gen no-secty arm64 ds-mqtt asc-mqtt asc-ex-mqtt mqtt-broker mqtt-bus
拉取镜像
docker-compose pull
出现Permission Denied
sudo chmod 777 /var/run/docker.sock
启动Edgex
docker-compose up [-d] # -d可选,选择是否后台运行(无运行信息)
查看是否启动
docker-compose ps
访问EdgeX Console进入EdgeXUI界面

关闭Edgex
docker-compose down
Question
本人遇到了三个问题,还望可以得到解答
1.启用了EdgeX的安全模式后,不知道如何获取EdgeX UI界面的token
按照官方文档的操作会报错
有的时候时container冲突,有的时本地ip172.23.0.5:8443拒绝连接,最后的错误是container"/edgex-security-bootstrapper" Conflict,也就是容器冲突,可是用docker ps和docker-compose ps也看不到冲突的那个容器的id
docker-compose -p edgex -f docker-compose.yml run --rm -v `pwd`:/host:ro -u "$UID" --entrypoint "/edgex/secrets-config" proxy-setup -- proxy adduser --token-type jwt --id "$ID" --algorithm ES256 --public_key /host/ec256.pub --user _SOME_USERNAME_ --jwt "$KONGJWT"
Creating network "edgex_edgex-network" with driver "bridge"
Creating volume "edgex_consul-acl-token" with default driver
Creating volume "edgex_consul-config" with default driver
Creating volume "edgex_consul-data" with default driver
Creating volume "edgex_db-data" with default driver
Creating volume "edgex_edgex-init" with default driver
Creating volume "edgex_kong" with default driver
Creating volume "edgex_kuiper-data" with default driver
Creating volume "edgex_postgres-config" with default driver
Creating volume "edgex_postgres-data" with default driver
Creating volume "edgex_redis-config" with default driver
Creating volume "edgex_vault-config" with default driver
Creating volume "edgex_vault-file" with default driver
Creating volume "edgex_vault-logs" with default driver
Creating edgex-security-bootstrapper ... error
ERROR: for edgex-security-bootstrapper Cannot create container for service security-bootstrapper: Conflict. The container name "/edgex-security-bootstrapper" is already in use by container "aec25a2ae279686bc4a7e5518902d84b30af12e7fa547e8d4e74201c199fd439". You have to remove (or rename) that container to be able to reuse that name.
ERROR: for security-bootstrapper Cannot create container for service security-bootstrapper: Conflict. The container name "/edgex-security-bootstrapper" is already in use by container "aec25a2ae279686bc4a7e5518902d84b30af12e7fa547e8d4e74201c199fd439". You have to remove (or rename) that container to be able to reuse that name.
ERROR: Encountered errors while bringing up the project.
docker-compose -p edgex -f docker-compose.yml run --rm -v `pwd`:/host:ro -u "$UID" --entrypoint "/edgex/secrets-config" proxy-setup -- proxy adduser --token-type jwt --id "$ID" --algorithm ES256 --public_key /host/ec256.pub --user _SOME_USERNAME_ --jwt "$KONGJWT"
Creating edgex_proxy-setup_run ... done
level=ERROR ts=2022-06-03T07:09:17.874323866Z app=secrets-config source=bootstraphandler.go:76 msg="Failed to send new consumer request _SOME_USERNAME_: Post \"https://edgex-kong:8443/admin/consumers\": dial tcp 172.23.0.5:8443: connect: connection refused"
ERROR: 2
2.如何配置连接真实的MQTT南向设备?
3.如何进入docker的容器,使用mosquitto的命令,查看mosquitto的运行状态?
4.为什么使用64位raspbian之后,它的浏览器只要是打开一个网页就会卡顿?其他的命令行一类的东西都不卡
参考
EdgeX Foundry Documentation-Getting Started with Docker
https://github.com/edgexfoundry/edgex-compose/blob/jakarta/compose-builder/README.md
docker-compose up 时 Permission denied
相关资料
安装uuidgen
sudo apt-get install uuid-runtime
EdgeX启用安全模式(make gen 时不添加no-secty选项)时,可能会用到,至今不会使用EdgeX UI界面的Token生成
最后
如果本文章有任何错误还请指正,最后两个问题,希望可以得到高人指点,谢谢!
树莓派使用Docker部署EdgeX(jakarta版本)的更多相关文章
- 树莓派中Docker部署.Net Core 3.1 (一)
一.背景 受疫情影响,已经在家强制事假一个月了,除了刷简历外就是在家学习,闲来无事,最近买了几个树莓派4B的板子回来,准备用树莓派搭建个自动部署的平台和微服务示例,长话短说,节约时间,直接进入正题吧 ...
- 基于Docker部署4.2 版本的zabbix监控平台
准备工作 两台VMware 虚拟机 一台充当zabbix server(安装docker)ip:192.168.73.133 一台充当zabbix agent(安装docker)ip:192.168. ...
- Asp.Net Core&Docker部署到树莓派3B中
花了一点时间将吃灰数月的树莓派装上了Docker,并在容器中部署了一个Asp.Net Core应用程序,通过花生壳映射树莓派中的程序,可以使用外网访问树莓派,玩起来很有意思(外网访问地址:http:/ ...
- Docker 部署 RocketMQ Dledger 集群模式( 版本v4.7.0)
文章转载自:http://www.mydlq.club/article/97/ 系统环境: 系统版本:CentOS 7.8 RocketMQ 版本:4.7.0 Docker 版本:19.03.13 一 ...
- docker部署rockermq集群(docker-compose版本)
此处采用docker-compose部署 rockermq主主集群模式 创建相关文件夹 此处创建的文件一一对应docker-compose.yml文件中的映射文件夹,酌情创建,主要需要创建配置文件夹. ...
- 树莓派上 Docker 的安装和使用
Docker 是一个开源的应用容器引擎,可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化.容器是完全使用沙箱机制,相互之间不 ...
- 树莓派应用Docker
本期通过在树莓派上配置 Docker,来介绍 Docker 应用,欢迎来到"万物皆可 Docker"的时代! 什么是 Docker ? Docker 最初是 dotCloud 公司 ...
- 程序开发使用docker部署
我们公司自己研发了一套 grand-line 系统,使用 docker 来部署项目. 我是第一批小白鼠,一开始网络差,build 一次要半个小时,连接进入 web shell 也很慢,部署一个微信项目 ...
- 我使用celery以及docker部署遇到的问题
首先我本机测试时没有问题的,但是在线上docker中,任务一直显示 "Sending due task".超时的任务是 django orm update 操作,本地不会出现这样的 ...
随机推荐
- Restful-API和传统API的对比
阮一峰 RestFul-API 详解链接: http://www.ruanyifeng.com/blog/2014/05/restful_api.html 举例,传统api设计: 举例,RestFu ...
- 前端加密办法之混淆js加密
每个页面都是有数据和页面结构以及样式组成,对于单页面的作者来说这中分离的感觉会明显一点,那当我们通过ajax请求拿到数据之后我们一般就是把数据渲染到页面,但是数据接口又不想那么明显是一个json字符串 ...
- css3,css的基础全局运用
浮动 1.浮动起来的盒子不占用位置,浮动了一个盒子下面的标准流的盒子会顶上来 可用清除浮动的方法来解决标准流会顶替位置的问题 清除浮动给父盒子加overflow: hidden; 鼠标经过事件 : ...
- Java对象和多态
Java对象和多态 (面向对象) 面向对象基础 面向对象程序设计(Object Oriented Programming) 对象基于类创建,类相当于一个模板,对象就是根据模板创建出来的实体(就像做月饼 ...
- k8s pod故障分类与排查
一.Pod故障状态基本有几种Pod状态 处于PendingPod状态 处于WaitingPod状态 处于ContainerCreatingPod状态 ImagePullBackOffPod状态 Cra ...
- librttopo 安装
librttopo 安装 官网 下载地址 https://git.osgeo.org/gitea/rttopo/librttopo/tags 什么是 librttopo? The RT Topolog ...
- line-height: 1; line-height: 100%;是什么意思
先简单看个例子: css 页面: 应该猜测出来了: line-height: 1; = line-height: 100%; = font-size: 50px; 把哪一个放到最后都是一样的.我理解的 ...
- 【GPLT】 2018年天梯赛全国总决赛 L2-2 小字辈(c++)
题目: 这一题并不是很难,属于常规的图论遍历题,这里我是用的bfs(dfs应该也可以,但明显bfs简单一些). 本人写的时候写了很多没必要头文件,自己可以根据内容删去,必要的我会写上注释 如有错误,请 ...
- python @符号用法的简单理解
一.用作函数修饰符 作用是为现有函数增加额外的功能,常用于插入日志.性能测试.事务处理等等 创建函数修饰符的规则:(1)修饰符是一个函数(2)修饰符取被修饰函数为参数(3)修饰符返回值取代被修饰函数 ...
- Oracle 定时任务增删改查
创建 -- 创建定时任务 DECLARE jobno NUMBER; BEGIN dbms_job.submit ( jobno, -- 定时器ID,系统自动获得 'PRC_INSERT;', -- ...