使用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之后,它的浏览器只要是打开一个网页就会卡顿?其他的命令行一类的东西都不卡

参考

树莓派安装docker-compose

EdgeX 树莓派实践部署

EdgeX Foundry Documentation-Getting Started with Docker

https://github.com/edgexfoundry/edgex-compose/blob/jakarta/compose-builder/README.md

docker-compose up 时 Permission denied

相关资料

树莓派镜像烧录器

树莓派4B64位系统镜像

docker删除所有容器镜像

如何安装uuidgen

安装uuidgen

sudo apt-get install uuid-runtime

EdgeX启用安全模式(make gen 时不添加no-secty选项)时,可能会用到,至今不会使用EdgeX UI界面的Token生成

据说是用来生成UI界面token的方法

docker-compose多文件

Github克隆加速

最后

如果本文章有任何错误还请指正,最后两个问题,希望可以得到高人指点,谢谢!

树莓派使用Docker部署EdgeX(jakarta版本)的更多相关文章

  1. 树莓派中Docker部署.Net Core 3.1 (一)

    一.背景 受疫情影响,已经在家强制事假一个月了,除了刷简历外就是在家学习,闲来无事,最近买了几个树莓派4B的板子回来,准备用树莓派搭建个自动部署的平台和微服务示例,长话短说,节约时间,直接进入正题吧 ...

  2. 基于Docker部署4.2 版本的zabbix监控平台

    准备工作 两台VMware 虚拟机 一台充当zabbix server(安装docker)ip:192.168.73.133 一台充当zabbix agent(安装docker)ip:192.168. ...

  3. Asp.Net Core&Docker部署到树莓派3B中

    花了一点时间将吃灰数月的树莓派装上了Docker,并在容器中部署了一个Asp.Net Core应用程序,通过花生壳映射树莓派中的程序,可以使用外网访问树莓派,玩起来很有意思(外网访问地址:http:/ ...

  4. Docker 部署 RocketMQ Dledger 集群模式( 版本v4.7.0)

    文章转载自:http://www.mydlq.club/article/97/ 系统环境: 系统版本:CentOS 7.8 RocketMQ 版本:4.7.0 Docker 版本:19.03.13 一 ...

  5. docker部署rockermq集群(docker-compose版本)

    此处采用docker-compose部署 rockermq主主集群模式 创建相关文件夹 此处创建的文件一一对应docker-compose.yml文件中的映射文件夹,酌情创建,主要需要创建配置文件夹. ...

  6. 树莓派上 Docker 的安装和使用

    Docker 是一个开源的应用容器引擎,可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化.容器是完全使用沙箱机制,相互之间不 ...

  7. 树莓派应用Docker

    本期通过在树莓派上配置 Docker,来介绍 Docker 应用,欢迎来到"万物皆可 Docker"的时代! 什么是 Docker ? Docker 最初是 dotCloud 公司 ...

  8. 程序开发使用docker部署

    我们公司自己研发了一套 grand-line 系统,使用 docker 来部署项目. 我是第一批小白鼠,一开始网络差,build 一次要半个小时,连接进入 web shell 也很慢,部署一个微信项目 ...

  9. 我使用celery以及docker部署遇到的问题

    首先我本机测试时没有问题的,但是在线上docker中,任务一直显示 "Sending due task".超时的任务是 django orm update 操作,本地不会出现这样的 ...

随机推荐

  1. 定制卡牌式 banner

    HTML <template> <view > <swiper class='swiperClass' autoplay interval="2000" ...

  2. Native方法的使用

    Java不是完美的,Java的不足除了体现在运行速度上要比传统的C++慢许多之外,Java无法直接访问到操作系统底层(如系统硬件等),为此Java使用native方法来扩展Java程序的功能. 可以将 ...

  3. java中Super指向他紧邻的父类,而不是最底层的基类

    3.2 当有两次继承时,演示super指向他紧邻的父类 我们把上面的例子扩展成两次继承, 就看出:马克-to-win,Super是一个参考(或说指针)指向他紧邻的父类,而不是最底层的基类. 例1.3. ...

  4. CCF201409-3 字符串匹配

    问题描述 给出一个字符串和多行文字,在这些文字中找到字符串出现的那些行.你的程序还需支持大小写敏感选项:当选项打开时,表示同一个字母的大写和小写看作不同的字符:当选项关闭时,表示同一个字母的大写和小写 ...

  5. jboss 7.1.1.final 报错 set the maxParameterCount attribute on the Connector

    Therefore, I cannot just add the connector attribute in standalone.xml like so: 在 <JBOSS_HOME> ...

  6. python+pytest接口自动化(13)-token关联登录

    在PC端登录公司的后台管理系统或在手机上登录某个APP时,经常会发现登录成功后,返回参数中会包含token,它的值为一段较长的字符串,而后续去请求的请求头中都需要带上这个token作为参数,否则就提示 ...

  7. c语言实现双链表的基本操作—增删改查

    //初始化 Node*InitList() { Node*head=(Node*)malloc(sizeof(Node)); if(NULL==head) { printf("内存分配失败! ...

  8. RTSP可用网络流

    推荐个音视频学习的网站 https://www.zzsin.com,里面有音视频学习资料和测试视频提供下载B站搜乔红 rtsp://wowzaec2demo.streamlock.net/vod/mp ...

  9. 2021蓝桥杯省赛B组(C/C++)E.路径【最短路DP】

    2021蓝桥杯省赛B组题目(C/C++)E.路径 最短路径, 因为变化情况比较多, 所以开始想的是深搜, 但是太慢了, 跑不出来, 后来就想着优化一下, 有的地方到另一个地方可能会考虑很多遍, 于是考 ...

  10. Blazor 组件库 BootstrapBlazor中 Ajax 组件的使用

    组件解决的问题 由于Blazor在与服务器连接时使用了Websocket,仅在第一次连接时会走原MVC的连接逻辑.所以,我们无法在这个过程中完成例如身份认证.cookie处理等操作. 此组件即为解决此 ...