00

准备工作

本系列物联网开发入门实战教程中硬件选取乐鑫 ESP8266 开发板,服务器采用树莓派 3B+/4B 主板,云端物联网平台基于开源EMQX社区版搭建,带你完整体验物联网场景端到端全栈开发过程。

乐鑫 ESP8266:

树莓派 4B:

01

树莓派系统烧录

树莓派(Raspberry Pi)是一款基于ARM的微型电脑主板,以SD/MicroSD卡为内存硬盘,卡片主板周围有1/2/4个USB接口和一个10/100 以太网接口,可连接键盘、鼠标和网线,同时拥有视频模拟信号的电视输出接口和HDMI高清视频输出接口,以上部件全部整合在一张仅比信用卡稍大的主板上,具备所有PC的基本功能只需接通电视机和键盘,就能执行如电子表格、文字处理、玩游戏、播放高清视频等诸多功能。

安装烧录工具

首先,打开树莓派官网,根据你的电脑系统下载对应烧录工具

https://www.raspberrypi.com/software/

cf29ae50e774e25aa1e06b460d9c3238.png

安装 Raspberry Pi Imager后,打开软件,选择 Raspberry Pi OS (64-bit),并选择存储 MicroSD 卡。

b5a34a5cb110bf456b68a94804d97187.png

571e94cc11930be627a880f976735004.png

点击右下角的设置按钮,进行配置工作。

a9482cbfc72ba5ac51a1ea57ed9ce894.png

在高级设置页面,你需要根据实际情况配置如下信息:

配置项
参数值
主机名emqx.local
SSH服务开启
username : emqx
密码 : emqx@123
配置Wi-Fi热点名 : 按实际情况配置
密码 : 按实际情况配置

04b1467cd2c3b2225013e7303e65ac8b.png

最后,点击烧录按钮,开始烧录固件,直到烧录完成。

61f15f4f9a7a8fa11e0e213c0136d8f5.png

c339c11ff3e5af2ff0ac605922e2cb02.png

02

安装 EMQX 社区版

EMQX  是一款完全开源,高度可伸缩,高可用的分布式 MQTT 消息服务器,同时也支持 CoAP/LwM2M 协议,适用于 IoT、M2M 和移动应用程序。

EMQX 提供了高效可靠海量物联网设备连接,可处理千万级别的并发,实时处理消息和事件流数据,帮助您快速构建关键业务的物联网平台与应用。

  • 基于 APL 2.0 开放源码协议

  • 完整 MQTT 3.1.0、3.1.1 和 5.0 规范,支持 MQTT-SN

  • Masterless 高可用集群架构

  • 高并发、低时延、高性能

  • 可扩展的网关和插件体系

因为树莓派系统是基于 Debian 裁剪版,所以我们下载支持 Debian 操作系统的开源社区版。操作步骤如下:

2.1 SSH登陆树莓派:

ssh emqx@emqx.local

2.2 配置 EMQX Apt 源:

curl -s https://assets.emqx.com/scripts/install-emqx-deb.sh | sudo bash

2.3 安装 EMQX:

sudo apt-get install emqx

2.4 启动 EMQX:

sudo systemctl start emqx

控制台完整操作过程如下:

Last login: Sat Aug 19 21:01:31 on console
iot$ ssh emqx@emqx.local
The authenticity of host 'emqx.local (***)' can't be established.
ECDSA key fingerprint is SHA256:***/ouBrME10.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added 'emqx.local,***%en0' (ECDSA) to the list of known hosts.
emqx@emqx.local's password: 
Linux emqx 6.1.21-v8+ #1642 SMP PREEMPT Mon Apr  3 17:24:16 BST 2023 aarch64


The programs included with the Debian GNU/Linux system are free software;
the exact distribution terms for each program are described in the
individual files in /usr/share/doc/*/copyright.


Debian GNU/Linux comes with ABSOLUTELY NO WARRANTY, to the extent
permitted by applicable law.
Last login: Wed May  3 04:23:52 2023


emqx@emqx:~ $ curl -s https://assets.emqx.com/scripts/install-emqx-deb.sh | sudo bash
Detected operating system as debian/bullseye.
Checking for curl...
Detected curl...
Checking for gpg...
Detected gpg...
Running apt-get update... done.
Installing debian-archive-keyring which is needed for installing 
apt-transport-https on many Debian systems.
Installing apt-transport-https... done.
Installing /etc/apt/sources.list.d/emqx_emqx.list...done.
Importing gpg key... done.
Running apt-get update... done.


The repository is setup! You can now install packages.


emqx@emqx:~/ $ sudo apt-get install emqx
Reading package lists... Done
Building dependency tree... Done
Reading state information... Done
The following package was automatically installed and is no longer required:
  libfuse2
Use 'sudo apt autoremove' to remove it.
The following NEW packages will be installed:
  emqx
0 upgraded, 1 newly installed, 0 to remove and 96 not upgraded.
Need to get 39.9 MB of archives.
After this operation, 93.8 MB of additional disk space will be used.
Get:1 https://packages.emqx.com/emqx/emqx/debian bullseye/main arm64 emqx arm64 5.1.6 [39.9 MB]
Fetched 39.9 MB in 16s (2,523 kB/s)                                                          
Selecting previously unselected package emqx.
(Reading database ... 96881 files and directories currently installed.)
Preparing to unpack .../archives/emqx_5.1.6_arm64.deb ...
Unpacking emqx (5.1.6) ...
Setting up emqx (5.1.6) ...
 emqx
    State: degraded
     Jobs: 0 queued
   Failed: 1 units
    Since: Thu 1970-01-01 01:00:04 BST; 53 years 8 months ago
   CGroup: /
           ├─user.slice 
           │ └─user-1000.slice 
           │   ├─user@1000.service …
           │   │ ├─app.slice 
           │   │ │ ├─gvfs-goa-volume-monitor.service 
           │   │ │ │ └─1005 /usr/libexec/gvfs-goa-volume-monitor
           │   │ │ ├─pulseaudio.service 
           │   │ │ │ └─687 /usr/bin/pulseaudio --daemonize=no --log-target=journal
           │   │ │ ├─gvfs-daemon.service 
           │   │ │ │ ├─ 844 /usr/libexec/gvfsd
           │   │ │ │ ├─ 849 /usr/libexec/gvfsd-fuse /run/user/1000/gvfs -f
           │   │ │ │ └─1021 /usr/libexec/gvfsd-trash --spawner :1.7 /org/gtk/gvfs/exec_spaw/0
           │   │ │ ├─gvfs-udisks2-volume-monitor.service 
           │   │ │ │ └─988 /usr/libexec/gvfs-udisks2-volume-monitor
           │   │ │ ├─gvfs-gphoto2-volume-monitor.service 
           │   │ │ │ └─1009 /usr/libexec/gvfs-gphoto2-volume-monitor
           │   │ │ ├─pipewire.service 
           │   │ │ │ ├─686 /usr/bin/pipewire
           │   │ │ │ └─730 /usr/bin/pipewire-media-session
           │   │ │ ├─dbus.service 
           │   │ │ │ └─715 /usr/bin/dbus-daemon --session --address=systemd: --nofork --nopid…
           │   │ │ ├─gvfs-mtp-volume-monitor.service 
           │   │ │ │ └─995 /usr/libexec/gvfs-mtp-volume-monitor
           │   │ │ └─gvfs-afc-volume-monitor.service 
           │   │ │   └─1013 /usr/libexec/gvfs-afc-volume-monitor
           │   │ └─init.scope 
           │   │   ├─625 /lib/systemd/systemd --user
           │   │   └─654 (sd-pam)
           │   ├─session-3.scope 
           │   │ ├─563 /bin/login -f
           │   │ └─708 -bash
           │   ├─session-4.scope 
           │   │ ├─ 815 sshd: emqx [priv]
           │   │ ├─1136 sshd: emqx@pts/0
           │   │ ├─1137 -bash
           │   │ ├─2478 sudo apt-get install emqx
           │   │ ├─2479 apt-get install emqx
           │   │ ├─2520 /usr/bin/dpkg --status-fd 32 --configure --pending
           │   │ ├─2521 /bin/sh /var/lib/dpkg/info/emqx.postinst configure
           │   │ └─2535 systemctl status --no-pager
           │   └─session-1.scope 
           │     ├─615 lightdm --session-child 13 16
           │     ├─703 /usr/bin/lxsession -s LXDE-pi -e LXDE -w openbox-lxde-pi
           │     ├─789 /usr/bin/ssh-agent x-session-manager
           │     ├─857 openbox --config-file /home/emqx/.config/openbox/lxde-pi-rc.xml
           │     ├─861 lxpolkit
           │     ├─863 lxpanel --profile LXDE-pi
           │     ├─865 pcmanfm --desktop --profile LXDE-pi
           │     ├─877 /usr/bin/ssh-agent -s
           │     ├─881 /usr/bin/python3 /usr/share/system-config-printer/applet.py
           │     ├─885 xcompmgr -aR
           │     └─997 /usr/lib/menu-cache/menu-cached /run/user/1000/menu-cached-:0
           ├─init.scope 
           │ └─1 /sbin/init splash
           └─system.slice 
             ├─packagekit.service 
             │ └─1123 /usr/libexec/packagekitd
             ├─systemd-udevd.service 
             │ └─174 /lib/systemd/systemd-udevd
             ├─triggerhappy.service 
             │ └─445 /usr/sbin/thd --triggers /etc/triggerhappy/triggers.d/ --socket /run/thd…
             ├─cron.service 
             │ └─352 /usr/sbin/cron -f
             ├─polkit.service 
             │ └─371 /usr/libexec/polkitd --no-debug
             ├─rtkit-daemon.service 
             │ └─700 /usr/libexec/rtkit-daemon
             ├─bluetooth.service 
             │ └─788 /usr/libexec/bluetooth/bluetoothd
             ├─wpa_supplicant.service 
             │ └─449 /sbin/wpa_supplicant -u -s -O /run/wpa_supplicant
             ├─lightdm.service 
             │ ├─540 /usr/sbin/lightdm
             │ └─562 /usr/lib/xorg/Xorg :0 -seat seat0 -auth /var/run/lightdm/root/:0 -nolist…
             ├─ModemManager.service 
             │ └─493 /usr/sbin/ModemManager
             ├─systemd-journald.service 
             │ └─139 /lib/systemd/systemd-journald
             ├─ssh.service 
             │ └─590 sshd: /usr/sbin/sshd -D [listener] 0 of 10-100 startups
             ├─hciuart.service 
             │ └─746 /usr/bin/hciattach /dev/serial1 bcm43xx 3000000 flow - b8:27:eb:b8:c8:d0
             ├─rsyslog.service 
             │ └─417 /usr/sbin/rsyslogd -n -iNONE
             ├─dhcpcd.service 
             │ ├─436 /usr/sbin/dhcpcd -b -q
             │ └─553 wpa_supplicant -B -c/etc/wpa_supplicant/wpa_supplicant.conf -iwlan0
             ├─rng-tools-debian.service 
             │ └─513 /usr/sbin/rngd -r /dev/hwrng
             ├─cups-browsed.service 
             │ └─592 /usr/sbin/cups-browsed
             ├─cups.service 
             │ └─523 /usr/sbin/cupsd -l
             ├─udisks2.service 
             │ └─447 /usr/libexec/udisks2/udisksd
             ├─dbus.service 
             │ └─354 /usr/bin/dbus-daemon --system --address=systemd: --nofork --nopidfile --…
             ├─systemd-timesyncd.service 
             │ └─282 /lib/systemd/systemd-timesyncd
             ├─avahi-daemon.service 
             │ ├─345 avahi-daemon: running [emqx.local]
             │ └─363 avahi-daemon: chroot helper
             └─systemd-logind.service 
               └─442 /lib/systemd/systemd-logind
Created symlink /etc/systemd/system/multi-user.target.wants/emqx.service → /lib/systemd/system/emqx.service.


emqx@emqx:~/ $ sudo systemctl start emqx

启动EMQX 服务后,你可以通过浏览器访问 http://emqx.local:18083/  来登录 EMQX Dashboard 管理控制台,进行设备连接与相关指标监控管理,默认用户名及密码:admin /public 。

61c5715e9360643242cd7ce2087824ad.png

EMQX 系统登录页面

2c1e17ccc87fed7ae7c6b63682f320bd.png

EMQX 管理控制台概览

03

配置和验证 EMQX 

设备通过 MQTT 协议接入 EMQX 平台需要有合法身份认证信息,因此你需要在控制台配置客户端认证信息。

首先,接入客户端认证页面,选择Password Based认证方式,用内置数据库 Mnesia 作为数据源,配置参数采用默认方式。

61979b1be65e2fada06b0de89170955e.png

其次,你需要在内置数据中添加一个用户身份(username/password)。在用户管理里可以查看到已添加的用户。

1f7503cd1046c10e5d94eb307a4137ba.png

MQTTX 工具

25b994d1a3dc43cefccc17da8c7cb9d5.gif

MQTTX 是由 EMQ 开发的一款开源跨平台 MQTT 5.0 桌面客户端,它兼容 macOS,Linux 以及 Windows 系统。

MQTTX 的用户界面 UI 采用聊天式设计,使得操作逻辑更加简明直观。它支持用户快速创建和保存多个 MQTT 连接,便于测试 MQTT/MQTTS 连接,以及 MQTT 消息的订阅和发布。

  • 采用聊天界面设计,使得操作更加简单明了

  • 跨平台兼容,支持在 Windows,macOS,Linux 系统上运行

  • 100% 兼容 MQTT v5.0,v3.1.1 和 v3.1 协议

  • 订阅的 MQTT 主题支持自定义颜色标签

  • 支持单向和双向 SSL 认证,同时支持 CA 和自签名证书

  • 支持通过 WebSocket 连接 MQTT 服务器

  • 支持 Hex, Base64, JSON, Plaintext 等 Payload 格式转换

  • 自定义脚本支持模拟 MQTT 发布/订阅测试

  • 提供完整的日志记录功能

  • 多语言支持:简体中文、英语、日语、土耳其语及匈牙利语

  • 自由切换 Light、Dark、Night 三种主题模式

打开 MQTTX 客户端进入创建页面,首先,你需要填写客户端的相关信息,包括clientId,MQTT服务器地址,用户名和密码。然后,点击右上角连接按钮建立MQTT连接。

03ccaf8771dff477a99985b144e76bb8.png

你可以给指定的Topic发送一条消息。

45a75b4a1f4a9933dff61bc242c3328b.png

你也可以订阅指定的Topic。

c087713dde2ffc2a0000fe9212b87df4.png

回到EMQX 控制台,你会看到当前连接的客户端Id、用户名、状态、以及 MQTT CONNECT 报文配置参数。

45e68a82ba5e0f377a83bdb7b50f9d7f.png

进入设备详情页面,你可以查看消息发送和接收情况,当前订阅消息主题列表。

4aefe6b12f1694031f60f8eeab605f33.jpeg

至此,你已经成功的在树莓派上部署了 EMQX 服务,并通过 MQTTX 工具模拟了物联网设备和云端 MQTT 服务器通信的过程。

最后,你可以使用如下命令,将树莓派服务器关机。

emqx@emqx:~/ $ sudo shutdown now

8d6a05ba62c64762190b64ae41449f99.jpeg

往期推荐

0c5791d4874efd8890f9d28108e860fc.png

☞ 高德地图: 红绿灯倒计时大揭秘

☞ 高速“车牌付”会取代 ETC 吗?

☞ 国内七大 IoT 物联网平台对比

☞ 我为什么放弃中移物联OneNET平台

☞ 这苦逼的IoT物联网我竟坚持了十年

☞ 打工人上班摸鱼, AI 监控老板行踪

0e4561528862819fa7d99f5a815f6e56.png

5199d63f550588e2310ea76a2f703b4e.png

ccc6abfb25221873be5a0608ddbc131c.gif

fa1ec0f85354ba1a911e6eafa070b9e2.gif

52674146c3ebcccf931456647294755e.gif

eb198237885999e637d67418b15c7532.gif

Logo

腾讯云面向开发者汇聚海量精品云计算使用和开发经验,营造开放的云计算技术生态圈。

更多推荐