Last modified by Kilight Cao on 2025/07/23 16:27
Summary
-
Page properties (1 modified, 0 added, 0 removed)
-
Attachments (0 modified, 48 added, 0 removed)
- image-20230807233631-1.png
- image-20230807233631-2.png
- image-20230808105217-1.png
- image-20230808105300-2.png
- image-20230808105329-3.png
- image-20230808162301-1.png
- image-20230808162342-2.png
- image-20230808162421-3.png
- image-20230808162727-4.png
- image-20230808163035-5.png
- image-20230808163049-6.png
- image-20230808163612-7.png
- image-20230808170051-8.png
- image-20230808170548-9.png
- image-20230808205045-1.png
- image-20230809165928-1.png
- image-20230809170225-2.png
- image-20230809170532-3.png
- image-20230809173127-4.png
- image-20230809173310-5.png
- image-20230809173438-6.png
- image-20230809173800-7.png
- image-20230809173835-8.png
- image-20230809174053-9.png
- image-20230809180523-10.png
- image-20230810083934-1.png
- image-20230810084048-2.png
- image-20230816201942-1.png
- image-20240129170024-1.png
- image-20240129170216-2.png
- image-20240129170539-3.png
- image-20240129171029-4.png
- image-20240129171113-5.png
- image-20240129171236-6.png
- image-20240129172056-7.png
- image-20240129172136-8.png
- image-20240129173116-9.png
- image-20240129173541-10.png
- image-20240129174518-11.png
- image-20240129174657-12.png
- image-20240129174840-13.png
- image-20240202111546-1.png
- image-20240207002003-1.png
- image-20240207002129-2.png
- image-20240208001740-1.png
- image-20240208102804-1.png
- image-20240226111928-1.png
- image-20240229233154-1.png
Details
- Page properties
-
- Content
-
... ... @@ -1,9 +1,13 @@ 1 -(% class="wikigeneratedid" %) 1 +(% class="wikigeneratedid" id="HTableofContents:" %) 2 2 **Table of Contents:** 3 3 4 4 {{toc/}} 5 5 6 6 7 + 8 + 9 + 10 + 7 7 = 1. The use of this guideline = 8 8 9 9 ... ... @@ -10,22 +10,59 @@ 10 10 This configure instruction is for Dragino NB-IoT models with -NB or -NS suffix, for example DDS75-NB. These models use the same NB-IoT Module **[[BC660K-GL>>https://www.quectel.com/product/lpwa-bc660k-gl-nb2]]** and has the same software structure. The have the same configure instruction to different IoT servers. Use can follow the instruction here to see how to configure to connect to those servers. 11 11 12 12 13 -= 2. Network Connection=17 += 2. Attach Network = 14 14 19 +== 2.1 General Configure to attach network == 15 15 21 + 22 +To attache NB-IoT sensors to NB-IoT Network, You need to: 23 + 24 +1. Get a NB-IoT SIM card from Service Provider. (Not the same as the SIM card we use in mobile phone) 25 +1. Power Off End Node ( See below for the power off/on position) 26 +1. Insert the SIM card to Sensor. ( See below for direction) 27 +1. Power On End Node 28 +1. [[Configure APN>>http://wiki.dragino.com/xwiki/bin/view/Main/How%20to%20configure%20APN%20in%20the%20node/]] in the sensor (AT+APN=<APN>) 29 + 30 +[[image:image-20240208102804-1.png||height="286" width="696"]] 31 + 32 +[[image:image-20230808205045-1.png||height="293" width="438"]] 33 + 34 +After doing above, the NB-IoT Sensors should be able to attach to NB-IoT network . 35 + 16 16 The -NB and -NS models support (% style="color:blue" %)**LTE Cat NB2**(%%), with below frequency band: multiple frequency bands of (% style="color:blue" %)**B1/B2/B3/B4/B5/B8/B12/B13/B14/B17/B18/B19/B20/B25/B28/B66/B70/B85**(%%) . Make sure you use a the NB-IoT SIM card. 17 17 18 -(% border="1" cellspacing="4" style="background-color:#f2f2f2; width: 510px" %)19 -|(% style="background-color:#4f81bd; color:white" %)**SIM Provider**|(% style="background-color:#4f81bd; color:white" %)**APN**|(% style="background-color:#4f81bd; color:white" %)**NB-IoT Coverage**|(% style="background-color:#4f81bd; color:white" %)**Comments** 20 -|1NCE| ||21 - |ChinaMobile| | |38 +(% border="1" cellspacing="4" style="background-color:#f2f2f2; width:878px" %) 39 +|(% style="background-color:#4f81bd; color:white; width:117px" %)**SIM Provider**|(% style="background-color:#4f81bd; color:white; width:151px" %)**AT+APN=**|(% style="background-color:#4f81bd; color:white; width:474px" %)**NB-IoT Coverage**|(% style="background-color:#4f81bd; color:white; width:135px" %)**Comments** 40 +|(% style="width:117px" %)**[[1NCE>>https://1nce.com]]**|(% style="width:151px" %)iot.1nce.net|(% style="width:474px" %)((( 41 +**[[Coverage Reference Link>>https://1nce.com/en-ap/1nce-connect]]** 22 22 43 +Austria, Belgium, Bulgaria, Croatia, Czech Republic, Denmark, Finland, Germany, Great Britain, Greece, Hungary, Ireland, Italy, Latvia, Malta, Netherlands, Norway, Puerto Rico, Russia, Slovak , Republic, Slovenia, Spain, Sweden, Switzerland, Taiwan, USA, US Virgin Islands 44 +)))|(% style="width:135px" %) 45 +|(% style="width:117px" %)China Mobile|(% style="width:151px" %)No need configure|(% style="width:474px" %)China Mainland, HongKong|(% style="width:135px" %) 46 +|(% style="width:117px" %)China Telecom|(% style="width:151px" %)ctnb|(% style="width:474px" %)China Mainland|(% style="width:135px" %) 23 23 48 +== 2.2 Speed Up Network Attach time == 24 24 25 -== 2.1 1NCE SIM Card. == 26 26 51 +BC660K-GL supports multi bands (% style="color:blue" %)**B1/B2/B3/B4/B5/B8/B12/B13/B14/B17/B18/B19/B20/B25/B28/B66/B70/B85. **(%%) It will search one by one and try to attach, this will take a lot of time and even cause attach fail and show Signal Strenght:99. User can lock the band to specify band for its operator to make this faster. 27 27 53 +(% style="color:#037691" %)**AT+QBAND? **(%%) ~/~/ Check what is the current used frequency band 28 28 55 +(% style="color:#037691" %)**AT+QBAND=1,4 **(%%) ~/~/ Set to use 1 frequency band. Band4 56 + 57 +(% style="color:#037691" %)**Europe General**(%%) **AT+QBAND=2,8,20 ** ~/~/ Set to use 2 frequency bands. Band 8 and Band 20 58 + 59 +(% style="color:#037691" %)**Verizon**(%%)** ** AT+QBAND=1,13 60 +(% style="color:#037691" %)**AT&T**(%%) AT+QBAND=3,12,4,2 61 +(% style="color:#037691" %)**Telstra**(%%) AT+QBAND=1,28 62 +(% style="color:#037691" %)**Softband**(%%) AT+QBAND=2,3,8 63 + 64 +After connection is successful, user can use (% style="color:#037691" %)**AT+QENG=0 **(%%) to check which band is actually in used. 65 + 66 + 67 +See bands used for different provider:** [[NB-IoT Deployment , Bands, Operator list>>http://wiki.dragino.com/xwiki/bin/view/Main/NB-IoT%20Deployment%20%2C%20Bands%2C%20Operator%20list/]]** 68 + 69 + 29 29 = 3. Configure to connect to different servers = 30 30 31 31 == 3.1 General UDP Connection == ... ... @@ -39,7 +39,7 @@ 39 39 40 40 We can use PC tool to simulate UDP connection to make sure server works ok. 41 41 42 -[[image:image-20230802112413-1.png]] 83 +[[image:image-20230802112413-1.png||height="468" width="1024"]] 43 43 44 44 45 45 === 3.1.2 Configure NB-IoT Sensor === ... ... @@ -53,8 +53,6 @@ 53 53 54 54 * (% style="color:#037691" %)**AT+SERVADDR=120.24.4.116,5601** (%%) ~/~/ Set UDP server address and port 55 55 56 -* (% style="color:#037691" %)**AT+CFM=1** (%%) ~/~/ If the server does not respond, this command is unnecessary 57 - 58 58 [[image:image-20230802112413-2.png]] 59 59 60 60 ... ... @@ -89,7 +89,7 @@ 89 89 90 90 [[image:image-20230802112413-4.png]] 91 91 92 -[[image:image-20230802112413-5.png]] 131 +[[image:image-20230802112413-5.png||height="530" width="987"]] 93 93 94 94 (% style="color:red" %)**Notice: MQTT protocol has a much higher power consumption compare with UDP/CoAP protocol. Please check the power analyze document and adjust the uplink period to a suitable interval.** 95 95 ... ... @@ -101,7 +101,7 @@ 101 101 102 102 [[ThingSpeak>>url:https://thingspeak.com/]] connection uses MQTT Connection. So we need to get MQTT Credentials first. You need to point MQTT Devices to ThingSpeak Channel as well. 103 103 104 -[[image:image-20230802112413-6.png]] 143 +[[image:image-20230802112413-6.png||height="336" width="925"]] 105 105 106 106 [[image:image-20230802112413-7.png]] 107 107 ... ... @@ -125,8 +125,6 @@ 125 125 126 126 * (% style="color:#037691" %)**Password:**(%%) <Your ThingSpeak MQTT Password> 127 127 128 - 129 - 130 130 ==== 3.3.2.2 Publish Data to ThingSpeak Channel ==== 131 131 132 132 ... ... @@ -134,6 +134,7 @@ 134 134 135 135 [[image:image-20230802112413-10.png]] 136 136 174 + 137 137 (% style="color:blue" %)**In MQTT.fx, we can publish below info:** 138 138 139 139 * (% style="color:#037691" %)**Topic:**(%%) channels/YOUR_CHANNEL_ID/publish ... ... @@ -145,7 +145,7 @@ 145 145 146 146 (% style="color:blue" %)**Result: ** 147 147 148 -[[image:image-20230802112413-11.png]] 186 +[[image:image-20230802112413-11.png||height="539" width="901"]] 149 149 150 150 151 151 === 3.3.3 Configure NB-IoT Sensor for connection === ... ... @@ -167,11 +167,10 @@ 167 167 168 168 * (% style="color:blue" %)**AT+SUBTOPIC=<YOUR_CHANNEL_ID>** 169 169 170 - 171 171 ==== 3.3.3.2 Uplink Examples ==== 172 172 173 173 174 - For S31-NB211 +[[image:image-20230816201942-1.png]] 175 175 176 176 For SE01-NB 177 177 ... ... @@ -202,186 +202,213 @@ 202 202 When NB-IoT sensor upload to ThingSpeak. The payload already specify which fileds related to which sensor value. Use need to create fileds in Channels Settings. with name so to see the value correctly. 203 203 204 204 205 -[[image:image-20230802112413-12.png]] 242 +[[image:image-20230802112413-12.png||height="504" width="1011"]] 206 206 207 -[[image:image-20230802112413-13.png]] 244 +[[image:image-20230802112413-13.png||height="331" width="978"]] 208 208 209 209 210 210 Below is the NB-IoT Product Table show the mapping. 211 211 212 -(% border="1" cellspacing="4" style="background-color:#f2f2f2; width:1386px" %) 213 -|(% style="background-color:#4f81bd; width:124px" %) |(% style="background-color:#4f81bd; color:white; width:91px" %)Field1|(% style="background-color:#4f81bd; color:white; width:102px" %)Field2|(% style="background-color:#4f81bd; color:white; width:159px" %)Field3|(% style="background-color:#4f81bd; color:white; width:153px" %)Field4|(% style="background-color:#4f81bd; color:white; width:152px" %)Field5|(% style="background-color:#4f81bd; color:white; width:148px" %)Field6|(% style="background-color:#4f81bd; color:white; width:164px" %)Field7|(% style="background-color:#4f81bd; color:white; width:152px" %)Field8|(% style="background-color:#4f81bd; color:white; width:66px" %)Field9|(% style="background-color:#4f81bd; color:white; width:66px" %)Field10 214 -|(% style="background-color:#4f81bd; color:white; width:124px" %)S31x-NB|(% style="width:91px" %)Temperature |(% style="width:102px" %)Humidity|(% style="width:159px" %)Battery|(% style="width:153px" %)RSSI|(% style="width:152px" %) |(% style="width:148px" %) |(% style="width:164px" %) |(% style="width:152px" %) |(% style="width:66px" %) |(% style="width:66px" %) 215 -|(% style="background-color:#4f81bd; color:white; width:124px" %)SE01-NB|(% style="width:91px" %)Temperature |(% style="width:102px" %)Humidity|(% style="width:159px" %)conduct|(% style="width:153px" %)dielectric_constant|(% style="width:152px" %)Battery|(% style="width:148px" %)RSSI|(% style="width:164px" %) |(% style="width:152px" %) |(% style="width:66px" %) |(% style="width:66px" %) 216 -|(% style="background-color:#4f81bd; color:white; width:124px" %)DDS20-NB|(% style="width:91px" %)distance|(% style="width:102px" %)Battery|(% style="width:159px" %)RSSI|(% style="width:153px" %) |(% style="width:152px" %) |(% style="width:148px" %) |(% style="width:164px" %) |(% style="width:152px" %) |(% style="width:66px" %) |(% style="width:66px" %) 217 -|(% style="background-color:#4f81bd; color:white; width:124px" %)DDS45-NB|(% style="width:91px" %)distance|(% style="width:102px" %)Battery|(% style="width:159px" %)RSSI|(% style="width:153px" %) |(% style="width:152px" %) |(% style="width:148px" %) |(% style="width:164px" %) |(% style="width:152px" %) |(% style="width:66px" %) |(% style="width:66px" %) 218 -|(% style="background-color:#4f81bd; color:white; width:124px" %)DDS75-NB|(% style="width:91px" %)distance|(% style="width:102px" %)Battery|(% style="width:159px" %)RSSI|(% style="width:153px" %) |(% style="width:152px" %) |(% style="width:148px" %) |(% style="width:164px" %) |(% style="width:152px" %) |(% style="width:66px" %) |(% style="width:66px" %) 219 -|(% style="background-color:#4f81bd; color:white; width:124px" %)NMDS120-NB|(% style="width:91px" %)distance|(% style="width:102px" %)Battery|(% style="width:159px" %)RSSI|(% style="width:153px" %) |(% style="width:152px" %) |(% style="width:148px" %) |(% style="width:164px" %) |(% style="width:152px" %) |(% style="width:66px" %) |(% style="width:66px" %) 220 -|(% rowspan="1" style="background-color:#4f81bd; color:white; width:124px" %)SPH01-NB|(% style="width:91px" %)ph|(% style="width:102px" %)Temperature|(% style="width:159px" %)Battery|(% style="width:153px" %)RSSI|(% style="width:152px" %) |(% style="width:148px" %) |(% style="width:164px" %) |(% style="width:152px" %) |(% style="width:66px" %) |(% colspan="1" rowspan="1" style="width:66px" %) 221 -|(% style="background-color:#4f81bd; color:white; width:124px" %)NLM01-NB|(% style="width:91px" %)Humidity|(% style="width:102px" %)Temperature|(% style="width:159px" %)Battery|(% style="width:153px" %)RSSI|(% style="width:152px" %) |(% style="width:148px" %) |(% style="width:164px" %) |(% style="width:152px" %) |(% style="width:66px" %) |(% style="width:66px" %) 222 -|(% style="background-color:#4f81bd; color:white; width:124px" %)NMDS200-NB|(% style="width:91px" %)distance1|(% style="width:102px" %)distance2|(% style="width:159px" %)Battery|(% style="width:153px" %)RSSI|(% style="width:152px" %) |(% style="width:148px" %) |(% style="width:164px" %) |(% style="width:152px" %) |(% style="width:66px" %) |(% style="width:66px" %) 223 -|(% style="background-color:#4f81bd; color:white; width:124px" %)CPN01-NB|(% style="width:91px" %)alarm|(% style="width:102px" %)count|(% style="width:159px" %)door open duration|(% style="width:153px" %)calc flag|(% style="width:152px" %)Battery|(% style="width:148px" %)RSSI|(% style="width:164px" %) |(% style="width:152px" %) |(% style="width:66px" %) |(% style="width:66px" %) 224 -|(% colspan="1" rowspan="1" style="background-color:#4f81bd; color:white; width:124px" %)DS03A-NB|(% colspan="1" rowspan="1" style="width:91px" %)level|(% colspan="1" rowspan="1" style="width:102px" %)alarm|(% colspan="1" rowspan="1" style="width:159px" %)pb14door open num|(% colspan="1" rowspan="1" style="width:153px" %)pb14 last open time|(% colspan="1" rowspan="1" style="width:152px" %)pb15 level status|(% colspan="1" rowspan="1" style="width:148px" %)pb15 alarm status|(% colspan="1" rowspan="1" style="width:164px" %)pb15 door open num|(% colspan="1" rowspan="1" style="width:152px" %)pb15 last open time|(% colspan="1" rowspan="1" style="width:66px" %)Battery|(% colspan="1" rowspan="1" style="width:66px" %)RSSI 225 -|(% colspan="1" rowspan="1" style="background-color:#4f81bd; color:white; width:124px" %)SN50V3-NB|(% colspan="1" rowspan="1" style="width:91px" %) |(% colspan="1" rowspan="1" style="width:102px" %) |(% colspan="1" rowspan="1" style="width:159px" %) |(% colspan="1" rowspan="1" style="width:153px" %) |(% colspan="1" rowspan="1" style="width:152px" %) |(% colspan="1" rowspan="1" style="width:148px" %) |(% colspan="1" rowspan="1" style="width:164px" %) |(% colspan="1" rowspan="1" style="width:152px" %) |(% colspan="1" rowspan="1" style="width:66px" %) |(% colspan="1" rowspan="1" style="width:66px" %) 226 -|(% colspan="1" rowspan="1" style="background-color:#4f81bd; color:white; width:124px" %)mod1|(% colspan="1" rowspan="1" style="width:91px" %)mod|(% colspan="1" rowspan="1" style="width:102px" %)Battery|(% colspan="1" rowspan="1" style="width:159px" %)RSSI|(% colspan="1" rowspan="1" style="width:153px" %)DS18B20 Temp|(% colspan="1" rowspan="1" style="width:152px" %)exit_state/input PA4|(% colspan="1" rowspan="1" style="width:148px" %)adc0|(% colspan="1" rowspan="1" style="width:164px" %)Temperature |(% colspan="1" rowspan="1" style="width:152px" %)Humidity|(% colspan="1" rowspan="1" style="width:66px" %) |(% colspan="1" rowspan="1" style="width:66px" %) 227 -|(% colspan="1" style="background-color:#4f81bd; color:white; width:124px" %)mod2|(% colspan="1" style="width:91px" %)mod|(% colspan="1" style="width:102px" %)Battery|(% colspan="1" style="width:159px" %)RSSI|(% colspan="1" style="width:153px" %)DS18B20 Temp|(% colspan="1" style="width:152px" %)exit_state/input PA4|(% colspan="1" style="width:148px" %)adc0|(% colspan="1" style="width:164px" %)distance|(% colspan="1" style="width:152px" %) |(% colspan="1" style="width:66px" %) |(% colspan="1" style="width:66px" %) 228 -|(% colspan="1" style="background-color:#4f81bd; color:white; width:124px" %)mod3|(% colspan="1" style="width:91px" %)mod|(% colspan="1" style="width:102px" %)Battery|(% colspan="1" style="width:159px" %)RSSI|(% colspan="1" style="width:153px" %)adc0|(% colspan="1" style="width:152px" %)exit_state/input PA4|(% colspan="1" style="width:148px" %)adc1|(% colspan="1" style="width:164px" %)Temperature|(% colspan="1" style="width:152px" %)Humidity|(% colspan="1" style="width:66px" %)adc4|(% colspan="1" style="width:66px" %) 229 -|(% colspan="1" style="background-color:#4f81bd; color:white; width:124px" %)mod4|(% colspan="1" style="width:91px" %)mod|(% colspan="1" style="width:102px" %)Battery|(% colspan="1" style="width:159px" %)RSSI|(% colspan="1" style="width:153px" %)DS18B20 Temp|(% colspan="1" style="width:152px" %)adc0|(% colspan="1" style="width:148px" %)exit_state/input PA4|(% colspan="1" style="width:164px" %)DS18B20 Temp2|(% colspan="1" style="width:152px" %)DS18B20 Temp3|(% colspan="1" style="width:66px" %) |(% colspan="1" style="width:66px" %) 230 -|(% colspan="1" style="background-color:#4f81bd; color:white; width:124px" %)mod5|(% colspan="1" style="width:91px" %)mod|(% colspan="1" style="width:102px" %)Battery|(% colspan="1" style="width:159px" %)RSSI|(% colspan="1" style="width:153px" %)DS18B20 Temp|(% colspan="1" style="width:152px" %)adc0|(% colspan="1" style="width:148px" %)exit_state/input PA4|(% colspan="1" style="width:164px" %)Weight|(% colspan="1" style="width:152px" %) |(% colspan="1" style="width:66px" %) |(% colspan="1" style="width:66px" %) 231 -|(% colspan="1" style="background-color:#4f81bd; color:white; width:124px" %)mod6|(% colspan="1" style="width:91px" %)mod|(% colspan="1" style="width:102px" %)Battery|(% colspan="1" style="width:159px" %)RSSI|(% colspan="1" style="width:153px" %)count|(% colspan="1" style="width:152px" %) |(% colspan="1" style="width:148px" %) |(% colspan="1" style="width:164px" %) |(% colspan="1" style="width:152px" %) |(% colspan="1" style="width:66px" %) |(% colspan="1" style="width:66px" %) 249 +(% border="1" cellspacing="4" style="background-color:#f2f2f2; width:1424px" %) 250 +|(% style="background-color:#4f81bd; width:143px" %) |(% style="background-color:#4f81bd; color:white; width:103px" %)Field1|(% style="background-color:#4f81bd; color:white; width:102px" %)Field2|(% style="background-color:#4f81bd; color:white; width:157px" %)Field3|(% style="background-color:#4f81bd; color:white; width:154px" %)Field4|(% style="background-color:#4f81bd; color:white; width:153px" %)Field5|(% style="background-color:#4f81bd; color:white; width:151px" %)Field6|(% style="background-color:#4f81bd; color:white; width:160px" %)Field7|(% style="background-color:#4f81bd; color:white; width:152px" %)Field8|(% style="background-color:#4f81bd; color:white; width:67px" %)Field9|(% style="background-color:#4f81bd; color:white; width:69px" %)Field10 251 +|(% style="background-color:#4f81bd; color:white; width:143px" %)S31x-NB|(% style="width:103px" %)Temperature |(% style="width:102px" %)Humidity|(% style="width:157px" %)Battery|(% style="width:154px" %)RSSI|(% style="width:153px" %) |(% style="width:151px" %) |(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% style="width:69px" %) 252 +|(% style="background-color:#4f81bd; color:white; width:143px" %)SE01-NB|(% style="width:103px" %)Temperature |(% style="width:102px" %)Humidity|(% style="width:157px" %)conduct|(% style="width:154px" %)dielectric_constant|(% style="width:153px" %)Battery|(% style="width:151px" %)RSSI|(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% style="width:69px" %) 253 +|(% style="background-color:#4f81bd; color:white; width:143px" %)DDS20-NB|(% style="width:103px" %)distance|(% style="width:102px" %)Battery|(% style="width:157px" %)RSSI|(% style="width:154px" %) |(% style="width:153px" %) |(% style="width:151px" %) |(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% style="width:69px" %) 254 +|(% style="background-color:#4f81bd; color:white; width:143px" %)DDS45-NB|(% style="width:103px" %)distance|(% style="width:102px" %)Battery|(% style="width:157px" %)RSSI|(% style="width:154px" %) |(% style="width:153px" %) |(% style="width:151px" %) |(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% style="width:69px" %) 255 +|(% style="background-color:#4f81bd; color:white; width:143px" %)DDS75-NB|(% style="width:103px" %)distance|(% style="width:102px" %)Battery|(% style="width:157px" %)RSSI|(% style="width:154px" %) |(% style="width:153px" %) |(% style="width:151px" %) |(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% style="width:69px" %) 256 +|(% style="background-color:#4f81bd; color:white; width:143px" %)NMDS120-NB|(% style="width:103px" %)distance|(% style="width:102px" %)Battery|(% style="width:157px" %)RSSI|(% style="width:154px" %) |(% style="width:153px" %) |(% style="width:151px" %) |(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% style="width:69px" %) 257 +|(% rowspan="1" style="background-color:#4f81bd; color:white; width:143px" %)SPH01-NB|(% style="width:103px" %)ph|(% style="width:102px" %)Temperature|(% style="width:157px" %)Battery|(% style="width:154px" %)RSSI|(% style="width:153px" %) |(% style="width:151px" %) |(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% colspan="1" rowspan="1" style="width:69px" %) 258 +|(% style="background-color:#4f81bd; color:white; width:143px" %)NLM01-NB|(% style="width:103px" %)Humidity|(% style="width:102px" %)Temperature|(% style="width:157px" %)Battery|(% style="width:154px" %)RSSI|(% style="width:153px" %) |(% style="width:151px" %) |(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% style="width:69px" %) 259 +|(% style="background-color:#4f81bd; color:white; width:143px" %)NMDS200-NB|(% style="width:103px" %)distance1|(% style="width:102px" %)distance2|(% style="width:157px" %)Battery|(% style="width:154px" %)RSSI|(% style="width:153px" %) |(% style="width:151px" %) |(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% style="width:69px" %) 260 +|(% style="background-color:#4f81bd; color:white; width:143px" %)CPN01-NB|(% style="width:103px" %)alarm|(% style="width:102px" %)count|(% style="width:157px" %)door open duration|(% style="width:154px" %)calc flag|(% style="width:153px" %)Battery|(% style="width:151px" %)RSSI|(% style="width:160px" %) |(% style="width:152px" %) |(% style="width:67px" %) |(% style="width:69px" %) 261 +|(% colspan="1" rowspan="1" style="background-color:#4f81bd; color:white; width:143px" %)DS03A-NB|(% colspan="1" rowspan="1" style="width:103px" %)level|(% colspan="1" rowspan="1" style="width:102px" %)alarm|(% colspan="1" rowspan="1" style="width:157px" %)pb14door open num|(% colspan="1" rowspan="1" style="width:154px" %)pb14 last open time|(% colspan="1" rowspan="1" style="width:153px" %)pb15 level status|(% colspan="1" rowspan="1" style="width:151px" %)pb15 alarm status|(% colspan="1" rowspan="1" style="width:160px" %)pb15 door open num|(% colspan="1" rowspan="1" style="width:152px" %)pb15 last open time|(% colspan="1" rowspan="1" style="width:67px" %)Battery|(% colspan="1" rowspan="1" style="width:69px" %)RSSI 262 +|(% colspan="1" rowspan="1" style="background-color:#4f81bd; color:white; width:143px" %)SN50V3-NB mod1|(% colspan="1" rowspan="1" style="width:103px" %)mod|(% colspan="1" rowspan="1" style="width:102px" %)Battery|(% colspan="1" rowspan="1" style="width:157px" %)RSSI|(% colspan="1" rowspan="1" style="width:154px" %)DS18B20 Temp|(% colspan="1" rowspan="1" style="width:153px" %)exit_state/input PA4|(% colspan="1" rowspan="1" style="width:151px" %)adc0|(% colspan="1" rowspan="1" style="width:160px" %)Temperature |(% colspan="1" rowspan="1" style="width:152px" %)Humidity|(% colspan="1" rowspan="1" style="width:67px" %) |(% colspan="1" rowspan="1" style="width:69px" %) 263 +|(% colspan="1" style="background-color:#4f81bd; color:white; width:143px" %)SN50V3-NB mod2|(% colspan="1" style="width:103px" %)mod|(% colspan="1" style="width:102px" %)Battery|(% colspan="1" style="width:157px" %)RSSI|(% colspan="1" style="width:154px" %)DS18B20 Temp|(% colspan="1" style="width:153px" %)exit_state/input PA4|(% colspan="1" style="width:151px" %)adc0|(% colspan="1" style="width:160px" %)distance|(% colspan="1" style="width:152px" %) |(% colspan="1" style="width:67px" %) |(% colspan="1" style="width:69px" %) 264 +|(% colspan="1" style="background-color:#4f81bd; color:white; width:143px" %)SN50V3-NB mod3|(% colspan="1" style="width:103px" %)mod|(% colspan="1" style="width:102px" %)Battery|(% colspan="1" style="width:157px" %)RSSI|(% colspan="1" style="width:154px" %)adc0|(% colspan="1" style="width:153px" %)exit_state/input PA4|(% colspan="1" style="width:151px" %)adc1|(% colspan="1" style="width:160px" %)Temperature|(% colspan="1" style="width:152px" %)Humidity|(% colspan="1" style="width:67px" %)adc4|(% colspan="1" style="width:69px" %) 265 +|(% colspan="1" style="background-color:#4f81bd; color:white; width:143px" %)SN50V3-NB mod4|(% colspan="1" style="width:103px" %)mod|(% colspan="1" style="width:102px" %)Battery|(% colspan="1" style="width:157px" %)RSSI|(% colspan="1" style="width:154px" %)DS18B20 Temp|(% colspan="1" style="width:153px" %)adc0|(% colspan="1" style="width:151px" %)exit_state/input PA4|(% colspan="1" style="width:160px" %)DS18B20 Temp2|(% colspan="1" style="width:152px" %)DS18B20 Temp3|(% colspan="1" style="width:67px" %) |(% colspan="1" style="width:69px" %) 266 +|(% colspan="1" style="background-color:#4f81bd; color:white; width:143px" %)SN50V3-NB mod5|(% colspan="1" style="width:103px" %)mod|(% colspan="1" style="width:102px" %)Battery|(% colspan="1" style="width:157px" %)RSSI|(% colspan="1" style="width:154px" %)DS18B20 Temp|(% colspan="1" style="width:153px" %)adc0|(% colspan="1" style="width:151px" %)exit_state/input PA4|(% colspan="1" style="width:160px" %)Weight|(% colspan="1" style="width:152px" %) |(% colspan="1" style="width:67px" %) |(% colspan="1" style="width:69px" %) 267 +|(% colspan="1" style="background-color:#4f81bd; color:white; width:143px" %)SN50V3-NB mod6|(% colspan="1" style="width:103px" %)mod|(% colspan="1" style="width:102px" %)Battery|(% colspan="1" style="width:157px" %)RSSI|(% colspan="1" style="width:154px" %)count|(% colspan="1" style="width:153px" %) |(% colspan="1" style="width:151px" %) |(% colspan="1" style="width:160px" %) |(% colspan="1" style="width:152px" %) |(% colspan="1" style="width:67px" %) |(% colspan="1" style="width:69px" %) 232 232 233 -== 3.4 Datacake == 269 +== 3.4 [[Datacake>>https://datacake.co/]] == 234 234 235 -== 3.4.1 Define Product == 236 236 272 +(% class="wikigeneratedid" %) 273 +Dragino NB-IoT sensors has its template in **[[Datacake>>https://datacake.co/]]** Platform. There are two version for NB Sensor, 237 237 238 -Firstly, we need to set the MQTT mode to datacake, and we need to run(% style="color:blue" %)** AT+PRO=3,2**(%%). This command is set to datacake. After running the command, the device automatically sets the server address, port. 239 239 240 -By chosing to add the device under a (% style="color:blue" %)**"New Product"**(%%) you are required to give a name for this product. You can name it something like (% style="color:blue" %)**"My First MQTT Product"**. 276 +(% class="wikigeneratedid" %) 277 +As example for S31B-NB. there are two versions: **S31B-NB-1D and S31B-NB-GE.** 241 241 242 - [[image:image-20230802112413-14.png]]279 +* (% style="color:blue" %)**S31B-NB-1D**(%%): This version have pre-configure DataCake connection. User just need to Power on this device, it will auto connect send data to DataCake Server. 243 243 281 +* (% style="color:blue" %)**S31B-NB-GE**(%%): This verson doesn't have pre-configure Datacake connection. User need to enter the AT Commands to connect to Datacake. See below for instruction. 244 244 245 -=== 3.4. 2 Create Device ===283 +=== 3.4.1 For device Already has template === 246 246 285 +==== 3.4.1.1 Create Device ==== 247 247 248 - Inthesecond step youhavetodefine thedevicewhich should beaddedto theproduct.287 +(% style="color:blue" %)**Add Device**(%%) in DataCake. 249 249 250 -[[image:image-2023080 2112413-15.png]]289 +[[image:image-20230808162301-1.png||height="453" width="952"]] 251 251 252 -Enter a name here (such as "My First MQTT Device") and complete the creation of the device by clicking on the (% style="color:blue" %)**"Next"**(%%) button. 253 253 292 +[[image:image-20230808162342-2.png||height="541" width="952"]] 254 254 255 -=== 3.4.3 Create Database Fields === 256 256 295 +(% style="color:blue" %)**Choose the correct model**(%%) from template. 257 257 258 - After creatingthedevice, it is listed in the tableof the fleet view.Now openthe device by clickingon the entry in the list.297 +[[image:image-20230808162421-3.png]] 259 259 260 -You will then see a device view with an empty dashboard. Now, the first thing we want to do is navigate to the Device configuration. To do this, use the tab bar and click on (% style="color:blue" %)**"Configuration"**. 261 261 262 - [[image:image-20230802112413-16.png]]300 +(% style="color:blue" %)**Fill Device ID**(%%). The device ID needs to be filled in with IMEI, and a prefix of(% style="color:blue" %)** 'f' **(%%)needs to be added. 263 263 264 -[[image:image-2023080 2112413-17.png]]302 +[[image:image-20230808163612-7.png||height="549" width="952"]] 265 265 266 - To create a first databasefield, please click on the (% style="color:blue" %)**"Add Field"**(%%) button asmarked in the screenshot above.304 +[[image:image-20230808163035-5.png]] 267 267 268 - This will openanothermodal askingfor somerequired inputfor your first field.306 +[[image:image-20230808163049-6.png||height="544" width="926"]] 269 269 270 -[[image:image-20230802112413-18.png]] 271 271 272 - [[image:image-20230802112413-19.png]]309 +=== 3.4.2 For Device already registered in DataCake before shipped === 273 273 311 +==== 3.4.2.1 Scan QR Code to get the device info ==== 274 274 275 -=== 3.4.4 Set up Broker === 276 276 314 +Users can use their phones or computers to scan QR codes to obtain device data information. 277 277 278 - The brokeris running onmqtt.datacake.co on ports (% style="color:blue" %)**1883and8883**(%%). Port1883 is unsecured and should not beusedin production environments. Port 8883 uses a CA signedserver certificate.316 +[[image:image-20230808170051-8.png||height="255" width="259"]] 279 279 280 - You will needan access token to loginto theDatacakeMQTT Broker.You can use your ownpersonal token or create a token explicitly for individual devices orgroups of devices.318 +[[image:image-20230808170548-9.png]] 281 281 282 -View your Personal Access Token 283 283 284 - You can view your own tokenvia the User-Settings-Menu. Youcan reachthis menu by clickingon (%style="color:blue"%)**"Edit Profile"**(%%) at the end of the listusingthe Workspace Selector:321 +==== 3.4.2.2 Claim Device to User Account ==== 285 285 286 -[[image:image-20230802112413-20.png]] 287 287 288 - (%style="color:blue"%)**MQTTClient-ID**324 +By Default, the device is registered in Dragino's DataCake Account. User can Claim it to his account. 289 289 290 -The Datacake Broker manages the client IDs internally. You do not need to worry about a client ID. If your client optionally supports the specification of a client ID, please leave this specification blank. Your client then creates a randomly generated ID. 291 291 292 - (%style="color:blue"%)**AT+CLIENT=“Any value”**327 +=== 3.4.3 Manual Add Decoder in DataCake ( don't use the template in DataCake) === 293 293 294 -(% style="color:blue" %)**AT+UNAME=Token** 295 295 296 - (% style="color:blue"%)**AT+PWD=Token**330 +**Step1: Add a device** 297 297 298 -[[image:image-202 30802112413-21.png]]332 +[[image:image-20240129170024-1.png||height="330" width="900"]] 299 299 300 300 301 - ===3.4.5CreateyourfirstSubscription===335 +**Step2: Choose your device type,please select dragino NB-IOT device** 302 302 337 +[[image:image-20240129170216-2.png||height="534" width="643"]] 303 303 304 -(% style="color:blue" %)**Subscribe** 305 305 306 - Data ispublished accordingto thefollowing structure:340 +**Step3: Choose to create a new device** 307 307 308 - dtck~/~//342 +[[image:image-20240129170539-3.png||height="459" width="646"]] 309 309 310 -Subscribe to topics using this structure to receive messages via MQTT when readings (via API or MQTT) arrive in the Datacake Cloud. Messages are published whenever there is a change to a corresponding database field. 311 311 345 +**Step4: Fill in the device ID of your NB device** 312 312 313 -[[image:image-202 30802112413-22.png]]347 +[[image:image-20240202111546-1.png||height="378" width="651"]] 314 314 315 315 316 - [[image:image-20230802112413-23.png]]350 +**Step5: Please select your device plan according to your needs and complete the creation of the device** 317 317 352 +[[image:image-20240129171236-6.png||height="450" width="648"]] 318 318 319 -[[image:image-20230802112413-24.png]] 320 320 355 +**Step6: Please add the decoder at the payload decoder of the device configuration.** 321 321 322 - (%style="color:blue" %)**example:**357 +**Decoder location:**[[dragino-end-node-decoder/Datacake-Dragino_NB at main · dragino/dragino-end-node-decoder (github.com)>>url:https://github.com/dragino/dragino-end-node-decoder/tree/main/Datacake-Dragino_NB]] 323 323 324 - AT+PUBTOPIC=dtck-pub/nbmattest/936c0db6-e9a5-4353-9fdb-3f63c8bfce7e/Temperature359 +[[image:image-20240129172056-7.png||height="457" width="816"]] 325 325 326 -[[image:image-202 30802112413-25.png]]361 +[[image:image-20240129173116-9.png||height="499" width="814"]] 327 327 328 328 329 - === 3.4.6 Define PublishTopic===364 +**Step7: Add the output of the decoder as a field** 330 330 366 +[[image:image-20240129173541-10.png||height="592" width="968"]] 331 331 332 -(% style="color:blue" %)**Publish** 333 333 334 - To upload datainto theDatacake Cloudinto aspecific device, you publish thedatao theespectivetopicstructure.369 +**Step8: Customize the dashboard and use fields as parameters of the dashboard** 335 335 336 - Dueto the natureof MQTT, theopic prefixdiffers as follows:371 +[[image:image-20240129174518-11.png||height="147" width="1042"]] 337 337 338 - dtck-pub~/~//373 +[[image:image-20240129174657-12.png||height="538" width="916"]] 339 339 340 - (% style="color:blue" %)**example:**375 +[[image:image-20240129174840-13.png||height="536" width="750"]] 341 341 342 -AT+SUBTOPIC=dtck/nbmattest/936c0db6-e9a5-4353-9fdb-3f63c8bfce7e/Temperature 343 343 378 +=== 3.4.4 For device have not configured to connect to DataCake === 344 344 345 -=== 3.4.7 upload data === 346 346 381 +(% class="lead" %) 382 +Use AT command for connecting to DataCake 347 347 348 - [[image:image-20230802112413-26.png]]384 +(% style="color:blue" %)**AT+PRO=2,0** 349 349 350 - [[image:image-20230802112413-27.png]]386 +(% style="color:blue" %)**AT+SERVADDR=67.207.76.90,4445** 351 351 352 -[[image:image-20230802112413-28.png]] 353 353 354 - 355 355 == 3.5 Node-Red (via MQTT) == 356 356 357 -=== 3.5.1 Configure Node-Red === 391 +=== 3.5.1 Configure [[Node-Red>>http://wiki.dragino.com/xwiki/bin/view/Main/Node-RED/]] === 358 358 359 -[[image:image-20230802112413-29.png]] 360 360 361 - [[image:image-20230802112413-30.png]]394 +Take S31-NB UDP protocol as an example. 362 362 396 +Dragino provides input flow examples for the sensors. 363 363 364 - ===3.5.2 SimulateConnection===398 +User can download the required JSON file through Dragino Node-RED input flow template. 365 365 400 +Download sample JSON file link: [[https:~~/~~/www.dropbox.com/sh/mduw85jcuwsua22/AAAvwPhg9z6dLjJhmZjqBf_ma?dl=0>>url:https://www.dropbox.com/sh/mduw85jcuwsua22/AAAvwPhg9z6dLjJhmZjqBf_ma?dl=0]] 366 366 367 - [[image:image-20230802112413-31.png]]402 +We can directly import the template. 368 368 404 +The templates for S31-NB and NB95S31B are the same. 369 369 370 -=== 3.5.3 Configure NB-IoT Sensors === 371 371 407 +[[image:image-20230809173127-4.png]] 372 372 373 -* (% style="color:blue" %)**AT+PRO=3,0(hex format) or 3,5(json format)**(%%) ~/~/Set to mqtt Server and Payload 374 374 375 - *(%style="color:blue"%)**AT+CLIENT=any value**410 +Please select the NB95S31B template. 376 376 377 - * (% style="color:blue"%)**AT+UNAME=any value**412 +[[image:image-20230809173310-5.png||height="558" width="926"]] 378 378 379 - * (% style="color:blue" %)**AT+PWD=any value**414 +[[image:image-20230809173438-6.png]] 380 380 381 - * (% style="color:blue" %)**AT+PUBTOPIC=any value**416 +[[image:image-20230809173800-7.png]] 382 382 383 -* (% style="color:blue" %)**AT+SUBTOPIC=any value** 384 384 419 +Successfully imported template. 420 + 421 +[[image:image-20230809173835-8.png||height="515" width="860"]] 422 + 423 + 424 +Users can set UDP port. 425 + 426 +[[image:image-20230809174053-9.png]] 427 + 428 + 429 +=== 3.5.2 Simulate Connection === 430 + 431 + 432 +We have completed the configuration of UDP. We can try sending packets to node red. 433 + 434 +[[image:image-20230810083934-1.png]] 435 + 436 +[[image:image-20230810084048-2.png||height="535" width="1052"]] 437 + 438 + 439 +=== 3.5.3 Configure NB-IoT Sensors === 440 + 441 + 442 +* (% style="color:#037691" %)**AT+PRO=3,0 or 3,5 ** (%%) **~/~/ hex format or json format** 443 +* (% style="color:#037691" %)**AT+SUBTOPIC=<device name>or User Defined** 444 +* (% style="color:#037691" %)**AT+PUBTOPIC=<device name>or User Defined** 445 +* (% style="color:#037691" %)**AT+CLIENT=<device name> or User Defined** 446 +* (% style="color:#037691" %)**AT+UNAME=<device name> or User Defined** 447 +* (% style="color:#037691" %)**AT+PWD=“Your device token”** 448 + 385 385 == 3.6 ThingsBoard.Cloud (via MQTT) == 386 386 387 387 === 3.6.1 Configure ThingsBoard === ... ... @@ -388,20 +388,22 @@ 388 388 389 389 ==== 3.6.1.1 Create Device ==== 390 390 391 -Create a New Device in [[ThingsBoard>>url:https://thingsboard.cloud/]]. 392 392 393 -[[i mage:image-20230802112413-32.png]]456 +Create a New Device in [[ThingsBoard>>url:https://thingsboard.cloud/]]. Record Device Name which is used for MQTT connection. 394 394 458 +[[image:image-20230802112413-32.png||height="583" width="1066"]] 395 395 460 + 396 396 ==== 3.6.1.2 Create Uplink & Downlink Converter ==== 397 397 463 + 398 398 (% style="color:blue" %)**Uplink Converter** 399 399 400 400 The purpose of the decoder function is to parse the incoming data and metadata to a format that ThingsBoard can consume. deviceName and deviceType are required, while attributes and telemetry are optional. Attributes and telemetry are flat key-value objects. Nested objects are not supported. 401 401 402 -To create an uplink converter go to the Integrations center -> Data converters page and click “plus” 468 +To create an uplink converter go to the (% style="color:blue" %)**Integrations center**(%%) -> (% style="color:blue" %)**Data converters**(%%) page and click (% style="color:blue" %)**“plus”** (%%)button. Name it (% style="color:blue" %)**“MQTT Uplink Converter”**(%%) and select type (% style="color:blue" %)"**Uplink"**(%%). Use debug mode for now. 403 403 404 -[[image:image-20230802112413-33.png]] 470 +[[image:image-20230802112413-33.png||height="597" width="1061"]] 405 405 406 406 407 407 (% style="color:blue" %)**Downlink Converter** ... ... @@ -408,39 +408,41 @@ 408 408 409 409 The Downlink converter transforming outgoing RPC message and then the Integration sends it to external MQTT broke 410 410 411 -[[image:image-20230802112413-34.png]] 477 +[[image:image-20230802112413-34.png||height="598" width="1063"]] 412 412 413 -(% style="color:red" %)**Note:Our device payload is already human readable data. Therefore, users do not need to write decoders. Simply create by default.** 479 +(% style="color:red" %)**Note: Our device payload is already human readable data. Therefore, users do not need to write decoders. Simply create by default.** 414 414 415 415 416 416 ==== 3.6.1.3 MQTT Integration Setup ==== 417 417 418 418 419 -Go to the Integrations center -> Integrations 485 +Go to the (% style="color:blue" %)**Integrations center**(%%) **->** (% style="color:blue" %)**Integrations page**(%%) and click **“(% style="color:blue" %)plus(%%)”** icon to add a new integration. Name it (% style="color:blue" %)**“MQTT Integration”**(%%), select type (% style="color:blue" %)**MQTT**; 420 420 421 -[[image:image-20230802112413-35.png]] 487 +[[image:image-20230802112413-35.png||height="597" width="1062"]] 422 422 489 + 423 423 * The next steps is to add the recently created uplink and downlink converters; 424 424 425 -[[image:image-20230802112413-36.png]] 492 +[[image:image-20230802112413-36.png||height="598" width="1062"]] 426 426 427 -[[image:image-20230802112413-37.png]] 494 +[[image:image-20230802112413-37.png||height="598" width="1064"]] 428 428 496 + 429 429 (% style="color:blue" %)**Add a topic filter:** 430 430 499 +Consistent with the theme of the node setting. 431 431 432 -tb/mqtt-integration-tutorial/sensors~/~/temperature ~-~-> Temperature 固定的? 对的。 433 - 434 434 You can also select an MQTT QoS level. We use MQTT QoS level 0 (At most once) by default; 435 435 436 -[[image:image-20230802112413-38.png]] 503 +[[image:image-20230802112413-38.png||height="598" width="1064"]] 437 437 438 438 439 439 === 3.6.2 Simulate with MQTT.fx === 440 440 508 + 441 441 [[image:image-20230802112413-39.png]] 442 442 443 -[[image:image-20230802112413-40.png]] 511 +[[image:image-20230802112413-40.png||height="525" width="980"]] 444 444 445 445 446 446 === 3.6.3 Configure NB-IoT Sensor === ... ... @@ -448,28 +448,25 @@ 448 448 449 449 (% style="color:blue" %)**AT Commands** 450 450 451 -* (% style="color:#037691" %)**AT+PRO=3,3 **(%%)** **~/~/ Use MQTT to connect to ThingsBoard. 519 +* (% style="color:#037691" %)**AT+PRO=3,3 **(%%)** **~/~/ Use MQTT to connect to ThingsBoard. Payload Type set to 3. 452 452 453 -* (% style="color:#037691" %)**AT+SUBTOPIC=device name** (%%) ~-~-> 只需要 Device Name 吗?对的521 +* (% style="color:#037691" %)**AT+SUBTOPIC=<device name>** 454 454 455 -* (% style="color:#037691" %)**AT+PUBTOPIC=device name** (%%) ~-~-> 只需要 Device Name 吗?对的523 +* (% style="color:#037691" %)**AT+PUBTOPIC=<device name>** 456 456 457 - Users do notneed to fill in theient, username, and password. But theconfiguration information of the devicerequires setting the client, username, and password, which can beentered freely. (软件自动填充为DeviceName 吧).这边不用提示了,客户不需要输入。(大部分客户还是会自己去设置这个的,提高安全性)525 +* (% style="color:#037691" %)**AT+CLIENT=<device name> or User Defined** 458 458 459 -(% style="color: blue" %)**CLIENT:“Anyvalue”**527 +* (% style="color:#037691" %)**AT+UNAME=<device name> or User Defined** 460 460 461 -(% style="color: blue" %)**UserName:“Any value”**529 +* (% style="color:#037691" %)**AT+PWD=<device name> or User Defined** 462 462 463 -(% style="color:blue" %)**Password:“Any value”** 464 - 465 - 466 466 Test Uplink by click the button for 1 second 467 467 468 -[[image:image-20230802112413-41.png]] 533 +[[image:image-20230802112413-41.png||height="496" width="828"]] 469 469 470 470 [[image:image-20230802112413-42.png]] 471 471 472 -[[image:image-20230802112413-43.png]] 537 +[[image:image-20230802112413-43.png||height="407" width="825"]] 473 473 474 474 475 475 == 3.7 [[Tago.io>>url:https://admin.tago.io/]] (via MQTT) == ... ... @@ -489,72 +489,193 @@ 489 489 [[image:image-20230802112413-46.png]] 490 490 491 491 492 - On theConnectionProfilewindow,set thefollowinginformation: (这边加一个截图)557 +The device needs to enable the TLS mode and set the (% style="color:blue" %)**AT+TLSMOD=1,0**(%%) command. 493 493 494 - *(% style="color:blue" %)**ProfileName:“Anyname”**559 +(% style="color:blue" %)**On the Connection Profile window, set the following information:** 495 495 496 -* (% style="color: blue" %)**BrokerAddress:mqtt.tago.io**561 +* (% style="color:#037691" %)**Profile Name: “Any name”** 497 497 498 -* (% style="color: blue" %)**BrokerPort:1883**563 +* (% style="color:#037691" %)**Broker Address: mqtt.tago.io** 499 499 500 -* (% style="color: blue" %)**ClientID:“Any value”**565 +* (% style="color:#037691" %)**Broker Port: 8883** 501 501 502 - Onthesection Usercredentials,setthe followinginformation:(这边加一个截图)567 +* (% style="color:#037691" %)**Client ID: “Any value”** 503 503 504 - ***UserName:“Any value”**Tago validatesyouruserbythetoken only569 +(% style="color:blue" %)**On the section User credentials, set the following information:** 505 505 506 -* ** Password: “Yourdevice token”**571 +* (% style="color:#037691" %)**User Name: “Any value”** (%%) **~/~/ Tago validates your user by the token only** 507 507 508 -* **P UBTOPIC: “Anyvalue”**573 +* (% style="color:#037691" %)**Password: “Your device token”** 509 509 510 -* ** SUBTOPIC: “Any value”**575 +* (% style="color:#037691" %)**PUBTOPIC: “Any value”** 511 511 577 +* (% style="color:#037691" %)**SUBTOPIC: “Any value”** 578 + 579 +(% style="color:blue" %)**AT command:** 580 + 581 +* (% style="color:#037691" %)**AT+PRO=3,0 or 3,5 ** (%%) **~/~/ hex format or json format** 582 + 583 +* (% style="color:#037691" %)**AT+SUBTOPIC=<device name>or User Defined** 584 + 585 +* (% style="color:#037691" %)**AT+PUBTOPIC=<device name>or User Defined** 586 + 587 +* (% style="color:#037691" %)**AT+CLIENT=<device name> or User Defined** 588 + 589 +* (% style="color:#037691" %)**AT+UNAME=<device name> or User Defined** 590 + 591 +* (% style="color:#037691" %)**AT+PWD=“Your device token”** 592 + 512 512 === 3.7.2 Simulate with MQTT.fx === 513 513 514 514 515 -[[image:image-20230802112413- 47.png]]596 +[[image:image-20230802112413-52.png]] 516 516 517 -[[image:image-20230802112413-48.png]] 518 518 519 - Users can run theAT+PRO=3,5command, and thepayload will be convertedo JSON format.599 +[[image:image-20230808105300-2.png||height="553" width="1026"]] 520 520 521 -[[image:image-20230802112413-49.png]] 522 522 602 +Users can run the (% style="color:blue" %)**AT+PRO=3,5**(%%) command, and the payload will be converted to **JSON format**. 523 523 604 +[[image:image-20230808105217-1.png||height="556" width="1031"]] 605 + 606 +[[image:image-20230808105329-3.png]] 607 + 608 + 524 524 === 3.7.3 tago data === 525 525 526 526 527 -[[image:image-20230802112413-50.png]] 612 +[[image:image-20230802112413-50.png||height="242" width="1037"]] 528 528 529 -[[image:image-20230802112413-51.png]] 614 +[[image:image-20230802112413-51.png||height="184" width="696"]] 530 530 531 531 532 -== =3.7.4TLS mode ===617 +== 3.8 TCP Connection == 533 533 534 534 535 - Users can choose to use(% style="color:blue" %)**SSL/TLS**(%%) mode.620 +(% style="color:blue" %)**AT command:** 536 536 537 - OntheSSL/TLSction,checktheoption**Enable SSL/TLS**, and click OK.622 +* (% style="color:#037691" %)**AT+PRO=4,0 ** (%%) ~/~/ Set to use TCP protocol to uplink(HEX format) 538 538 539 - The device needs to enable the TLS mode and set the(% style="color:blue" %)**AT+TLSMOD=1,0**(%%)mand.624 +* (% style="color:#037691" %)**AT+PRO=4,1 ** (%%) ~/~/ Set to use TCP protocol to uplink(JSON format) 540 540 541 -* (% style="color: blue" %)**ProfileName: “Any name”**626 +* (% style="color:#037691" %)**AT+SERVADDR=120.24.4.116,5600 ** (%%) ~/~/ to set TCP server address and port 542 542 543 - *(% style="color:blue" %)**BrokerAddress: mqtt.tago.io**628 +(% style="color:blue" %)**Sensor Console Output when Uplink:** 544 544 545 - * (% style="color:blue" %)**Broker Port:8883**630 +[[image:image-20230807233631-1.png]] 546 546 547 -* (% style="color:blue" %)**Client ID: “Any value”** 548 548 549 - *(% style="color:blue" %)**UserName: “Any value”**(%%)ago validates youruserby the token only633 +(% style="color:blue" %)**See result in TCP Server:** 550 550 551 - * (% style="color:blue" %)**Password: “Your device token”**635 +[[image:image-20230807233631-2.png]] 552 552 553 -* (% style="color:blue" %)**PUBTOPIC: “Any value”** 554 554 555 - * (% style="color:blue"%)**SUBTOPIC: “Any value”**638 += 4. FAQ = 556 556 557 - [[image:image-20230802112413-52.png]]640 +== 4.1 What is the usage of Multi Sampling and One Uplink? == 558 558 559 559 643 +The NB series has the feature for Multi Sampling and one uplink. See one of them 644 + 645 +[[http:~~/~~/wiki.dragino.com/xwiki/bin/view/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/SN50v3-NB_BN-IoT_Sensor_Node_User_Manual/#H2.5Multi-SamplingsandOneuplink>>http://wiki.dragino.com/xwiki/bin/view/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/SN50v3-NB_BN-IoT_Sensor_Node_User_Manual/#H2.5Multi-SamplingsandOneuplink]] 646 + 647 +User can use this feature for below purpose: 648 + 649 +1. **Reduce power consumption**. The NB-IoT transmit power is much more higher than the sensor sampling power. To save battery life, we can sampling often and send in one uplink. 650 +1. Give more sampling data points. 651 +1. Increase reliable in transmission. For example. If user set 652 +1*. **AT+TR=1800** ~/~/ The unit is seconds, and the default is to record data once every 1800 seconds (30 minutes, the minimum can be set to 180 seconds) 653 +1*. **AT+NOUD=24** ~/~/ The device uploads 24 sets of recorded data by default. Up to 32 sets of record data can be uploaded. 654 +1*. **AT+TDC=7200** ~/~/ Uplink every 2 hours. 655 +1*. this will mean each uplink will actually include the 6 uplink data (24 set data which cover 12 hours). So if device doesn;t lost 6 continue data. There will not data lost. 656 + 657 + 658 + 659 +== 4.2 Why the uplink JSON format is not standard? == 660 + 661 + 662 +The json format in uplink packet is not standard Json format. Below is the example. This is to make the payload as short as possible, due to NB-IoT transmit limition, a standard Json is not able to include 32 sets of sensors data with timestamp. 663 + 664 +[[image:image-20240229233154-1.png]] 665 + 666 + 667 += 5. Trouble Shooting: = 668 + 669 +== 5.1 Checklist for debuging Network Connection issue. Signal Strenght:99 issue. == 670 + 671 + 672 +There are many different providers provide NB-IoT service in the world. They might use different band, different APN & different operator configuration. Which makes connection to NB-IoT network is complicate. 673 + 674 +If end device successfully attached NB-IoT Network, User can normally see the signal strengh as below (between 0~~31) 675 + 676 +[[image:image-20240207002003-1.png]] 677 + 678 + 679 +If fail to attach network, it will shows signal 99. as below: 680 + 681 +[[image:image-20240207002129-2.png]] 682 + 683 + 684 +(% class="lead" %) 685 +When see this issue, below are the checklist: 686 + 687 +* Does your SIM card support NB-IoT network? If SIM card doesn't not specify support NB-IoT clearly, normally it doesn't support. You need to confirm with your operator. 688 +* Do you configure the correct APN? [[Check here for APN settings>>http://wiki.dragino.com/xwiki/bin/view/Main/General%20Configure%20to%20Connect%20to%20IoT%20server%20for%20-NB%20%26%20-NS%20NB-IoT%20models/#H2.1GeneralConfiguretoattachnetwork]]. 689 +* Do you lock the frequency band? This is the most case we see. [[Explain and Instruction>>http://wiki.dragino.com/xwiki/bin/view/Main/General%20Configure%20to%20Connect%20to%20IoT%20server%20for%20-NB%20%26%20-NS%20NB-IoT%20models/#H2.2SpeedUpNetworkAttachtime]]. 690 +* Check if the device is attached to Carrier network but reject. (need to check with operator). 691 +* Check if the antenna is connected firmly. 692 + 693 +If you have check all above and still fail. please send console log files (as many as possible) to [[support@dragino.com>>mailto:support@dragino.com]] so we can check. 694 + 695 + 696 +== 5.2 Issue: "NBIOT did not respond" == 697 + 698 + 699 +(% class="box errormessage" %) 700 +((( 701 +11:24:22.397 [44596]NBIOT did not respond. 702 +11:24:24.315 [46530]NBIOT did not respond. 703 +11:24:26.256 [48464]NBIOT did not respond. 704 +11:24:28.196 [50398]NBIOT did not respond. 705 +11:24:30.115 [52332]NBIOT did not respond. 706 +11:24:32.127 [54266]NBIOT did not respond. 707 +11:24:32.127 [54299]Restart the module... 708 +11:24:39.181 [61332]No response when shutting down 709 +))) 710 + 711 +This issue might due to initiate issue for NB-IoT module. In this case, please try: 712 + 713 +1) Open Enclosure 714 + 715 +2) Power off device by pull out the power on Jumper 716 + 717 +3) Power on device by connect back the power jumper. 718 + 719 +4) push reset button. 720 + 721 +[[image:image-20240208001740-1.png]] 722 + 723 + 724 +== 5.3 Issue: "Failed to readI MSI number" == 725 + 726 + 727 +(% class="box errormessage" %) 728 +((( 729 +[18170]Failed to read IMSI:1umber. 730 +[20109]Failed to read IMSI numoer. 731 +[22048]Failed to read IMSI number. 732 +[29842lRestart the module... 733 +))) 734 + 735 +Make sure that the SIM card is insert in correct direction and device is power off/on during insert. Here is reference link: [[Insert SIM Card>>||anchor="H2.1GeneralConfiguretoattachnetwork"]]. 736 + 737 + 738 +== 5.4 Why sometime the AT Command is slow in reponse? == 739 + 740 + 741 +When the MCU is communicating with the NB-IoT module, the MCU response of AT Command will become slower, it might takes several seconds to response. 742 + 743 +[[image:image-20240226111928-1.png]] 744 + 745 + 560 560
- image-20230807233631-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Edwin - Size
-
... ... @@ -1,0 +1,1 @@ 1 +21.9 KB - Content
- image-20230807233631-2.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Edwin - Size
-
... ... @@ -1,0 +1,1 @@ 1 +9.6 KB - Content
- image-20230808105217-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +68.5 KB - Content
- image-20230808105300-2.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +70.1 KB - Content
- image-20230808105329-3.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +21.1 KB - Content
- image-20230808162301-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +76.9 KB - Content
- image-20230808162342-2.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +63.8 KB - Content
- image-20230808162421-3.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +59.2 KB - Content
- image-20230808162727-4.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +54.2 KB - Content
- image-20230808163035-5.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +71.6 KB - Content
- image-20230808163049-6.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +61.5 KB - Content
- image-20230808163612-7.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +53.4 KB - Content
- image-20230808170051-8.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +21.5 KB - Content
- image-20230808170548-9.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +54.1 KB - Content
- image-20230808205045-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Edwin - Size
-
... ... @@ -1,0 +1,1 @@ 1 +373.9 KB - Content
- image-20230809165928-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +74.4 KB - Content
- image-20230809170225-2.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +39.9 KB - Content
- image-20230809170532-3.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +38.7 KB - Content
- image-20230809173127-4.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +82.5 KB - Content
- image-20230809173310-5.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +51.9 KB - Content
- image-20230809173438-6.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +41.0 KB - Content
- image-20230809173800-7.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +46.8 KB - Content
- image-20230809173835-8.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +88.8 KB - Content
- image-20230809174053-9.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +58.0 KB - Content
- image-20230809180523-10.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +91.9 KB - Content
- image-20230810083934-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +85.1 KB - Content
- image-20230810084048-2.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.David - Size
-
... ... @@ -1,0 +1,1 @@ 1 +63.7 KB - Content
- image-20230816201942-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Edwin - Size
-
... ... @@ -1,0 +1,1 @@ 1 +99.8 KB - Content
- image-20240129170024-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Bei - Size
-
... ... @@ -1,0 +1,1 @@ 1 +52.3 KB - Content
- image-20240129170216-2.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Bei - Size
-
... ... @@ -1,0 +1,1 @@ 1 +56.0 KB - Content
- image-20240129170539-3.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Bei - Size
-
... ... @@ -1,0 +1,1 @@ 1 +55.0 KB - Content
- image-20240129171029-4.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Bei - Size
-
... ... @@ -1,0 +1,1 @@ 1 +36.1 KB - Content
- image-20240129171113-5.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Bei - Size
-
... ... @@ -1,0 +1,1 @@ 1 +47.2 KB - Content
- image-20240129171236-6.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Bei - Size
-
... ... @@ -1,0 +1,1 @@ 1 +49.8 KB - Content
- image-20240129172056-7.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Bei - Size
-
... ... @@ -1,0 +1,1 @@ 1 +69.8 KB - Content
- image-20240129172136-8.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Bei - Size
-
... ... @@ -1,0 +1,1 @@ 1 +80.4 KB - Content
- image-20240129173116-9.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Bei - Size
-
... ... @@ -1,0 +1,1 @@ 1 +110.8 KB - Content
- image-20240129173541-10.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Bei - Size
-
... ... @@ -1,0 +1,1 @@ 1 +95.4 KB - Content
- image-20240129174518-11.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Bei - Size
-
... ... @@ -1,0 +1,1 @@ 1 +23.2 KB - Content
- image-20240129174657-12.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Bei - Size
-
... ... @@ -1,0 +1,1 @@ 1 +141.9 KB - Content
- image-20240129174840-13.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Bei - Size
-
... ... @@ -1,0 +1,1 @@ 1 +92.9 KB - Content
- image-20240202111546-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Bei - Size
-
... ... @@ -1,0 +1,1 @@ 1 +33.3 KB - Content
- image-20240207002003-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Edwin - Size
-
... ... @@ -1,0 +1,1 @@ 1 +22.3 KB - Content
- image-20240207002129-2.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Edwin - Size
-
... ... @@ -1,0 +1,1 @@ 1 +17.9 KB - Content
- image-20240208001740-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Edwin - Size
-
... ... @@ -1,0 +1,1 @@ 1 +487.1 KB - Content
- image-20240208102804-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Edwin - Size
-
... ... @@ -1,0 +1,1 @@ 1 +507.6 KB - Content
- image-20240226111928-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Edwin - Size
-
... ... @@ -1,0 +1,1 @@ 1 +52.0 KB - Content
- image-20240229233154-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Edwin - Size
-
... ... @@ -1,0 +1,1 @@ 1 +39.5 KB - Content