Show last authors
1 **~ Table of Contents:**
2
3 {{toc/}}
4
5
6
7 = 1.  Introduction =
8
9
10 (((
11 In this chapter, we set up a CoAP/ MQTT server by using Open Source MQTT Broker : [[EMQX.IO>>url:https://www.emqx.io/]]. And show how to communicate it with CoAP and MQTT.
12 )))
13
14 (((
15 Below is the network structure. The end device use CoAP to connect our Emqx server via NB-IoT network. EMQ X broker will further process the data for the actually application.
16
17
18 )))
19
20 [[image:image-20220530084843-1.png]]
21
22 Network structure
23
24
25 = 2.  Install CoAP server =
26
27
28 Set up example in Ubuntu 18.04
29
30 (% class="box" %)
31 (((
32 sudo apt-get update
33 sudo apt-get upgrade
34 wget [[https:~~/~~/www.emqx.io/downloads/broker/v3.2.7/emqx-ubuntu18.04-v3.2.7_amd64.deb>>url:https://www.emqx.io/downloads/broker/v3.2.7/emqx-ubuntu18.04-v3.2.7_amd64.deb]]  #download the installation package.
35 sudo dpkg –i emqx-ubuntu18.04-v3.2.4_amd64.deb  #install EMQX
36 emqx start            # Start EMQX service
37 emqx_ctl status   #check if EMQX is running
38 ./bin/emqx_ctl plugins load emqx_coap # Run COAP service
39 )))
40
41 (((
42 (% style="color:red" %)**Notice: CoAP default port use 5683, if you install EMQX in a cloud server, make sure you open the UDP port 5683. So can receive the packets from NB-IoT.**
43
44
45 )))
46
47 = 3.  Test CoAP Server =
48
49 == 3.1  Install Copper in Chrome ==
50
51
52 (((
53 (% style="color:blue" %)**1. Download Copper4Cr from [[https:~~/~~/github.com/mkovatsc/Copper4Cr>>url:https://github.com/mkovatsc/Copper4Cr]] and unpack it.**
54 )))
55
56 (((
57 (% style="color:blue" %)**2. Run install.bat in the directory.**
58
59
60 [[image:image-20220530085327-2.png]]
61 )))
62
63 Run install.bat
64
65
66 (% style="color:blue" %)**3. Load the unpacked CoAP APP in Google Chrome:**
67
68 [[image:image-20220530085423-3.png||height="241" width="1250"]]
69
70 Install Copper APP
71
72
73 [[image:image-20220530085531-4.png]]
74
75 Install APP Successful
76
77
78 (% style="color:blue" %)**4. Load the unpacked CoAP extension in Google Chrome:**
79
80 [[image:image-20220530085638-5.png||height="338" width="1320"]]
81
82 Install Copper Extension
83
84
85 [[image:image-20220530090104-7.png||height="389" width="1282"]]
86
87 Install Extension Successful
88
89
90 (% style="color:blue" %)**5. Replace the appID in file extension\endpoint\ClientPortChrome.js to Copper (Cu4Cr) Application ID**
91
92 [[image:image-20220530090444-10.png]]
93
94 Replace ID
95
96
97 (% style="color:blue" %)**6. Open the Copper extension. If you see below message, means install successfully.**
98
99 [[image:image-20220530090404-9.png||height="658" width="1238"]]
100
101 Install Finished
102
103
104 == 3.2  Test CoAP connection ==
105
106
107 (((
108 Use Chrome Copper externsion to connect to the CoAP server. Input coap:~/~/COAP_SERVER_IP/mqtt/topic0?c=t1 to connect to the MQTT topic0 in CoAP server. Replace COAP_SERVER_IP with your COAP Server IP address, and refer [[here>>url:https://github.com/emqx/emqx-coap]] for the CoAP detail in EMQX. When connection ok, you can see below window.
109
110
111 [[image:image-20220530090848-13.png||height="616" width="1154"]]
112 )))
113
114 Connect to CoAP server
115
116
117 == 3.3  Test CoAP Uplink ==
118
119
120 (((
121 Try to use MQTT.fx to subscribe a the topic (topic0) in the server. And use CoAP to send a message to this topic, we can see the message arrive the topic0 and shown in MQTT.fx.
122
123
124 [[image:image-20220530090939-14.png]]
125 )))
126
127 Use MQTT.fx to subscribe the topic
128
129
130 [[image:image-20220530091358-18.png||height="549" width="1035"]]
131
132 Use CoAP Exension to send a update to CoAP server
133
134
135 [[image:image-20220530091237-17.png]]
136
137 MQTT.fx get the update of this topic on CoAP server
138
139
140 == 3.4  Test CoAP Downlink ==
141
142
143 (((
144 Try to use MQTT.fx to publish a message to the topic (topic0) in the server. CoAP extension will see this incomming message.
145
146
147 )))
Copyright ©2010-2024 Dragino Technology Co., LTD. All rights reserved
Dragino Wiki v2.0