本篇文章給大家分享的是有關(guān)docker-compose中怎么部署ChirpStack,小編覺得挺實用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
成都創(chuàng)新互聯(lián)公司堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站制作、成都網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的安義網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
1. Git(非必須,可以先下載源碼)
2. Docker
3. Docker-compose
關(guān)于LoraWan Server
在講LoraWan Server之前需要先了解一下LoraWan協(xié)議,LoraWan是一種物聯(lián)網(wǎng)遠(yuǎn)距離傳輸協(xié)議。引用一句官方的介紹是這樣的:LoRaWAN開放規(guī)范是基于LoRa技術(shù)的低功耗廣域網(wǎng)(LPWAN)協(xié)議。
協(xié)議棧也引用官方的圖:
數(shù)據(jù)是如何從傳感器發(fā)送到服務(wù)器并且被相應(yīng)的應(yīng)用處理的呢?可以看下下面的圖,依然是來自官方:
最上面的是傳感器,然后通過LoraWan協(xié)議將數(shù)據(jù)傳輸給了網(wǎng)關(guān),網(wǎng)關(guān)通過網(wǎng)絡(luò)傳輸?shù)骄W(wǎng)絡(luò)服務(wù)器(NS),NS將數(shù)據(jù)分發(fā)給對應(yīng)的應(yīng)用服務(wù)器(AS)。
舉個栗子:一個智慧廁所當(dāng)中的洗手液盒和紙巾盒里面都裝有LoraWan的傳感器,并且是由兩個廠商分別提供設(shè)備。他們分別將余量數(shù)據(jù)(還剩下多少皂液/還剩下多少紙巾)上傳到了(當(dāng)然包含了網(wǎng)關(guān)傳輸?shù)牟糠?網(wǎng)絡(luò)服務(wù)器,網(wǎng)絡(luò)服務(wù)器就將紙巾盒的數(shù)據(jù)分發(fā)給紙巾盒廠商的應(yīng)用服務(wù)器,將皂液盒的數(shù)據(jù)分發(fā)給皂液盒廠商的應(yīng)用服務(wù)器。
這樣在大家都遵循LoraWan協(xié)議的前提下就達(dá)到了廠商中立的情況,哪一種設(shè)備不好我都可以找符合LoraWan規(guī)范的廠商進(jìn)行替代,不需要擔(dān)心廠商鎖定的問題。
在這個過程中,網(wǎng)絡(luò)服務(wù)器就起著一個相當(dāng)重要的作用了,下面來看看當(dāng)前有哪一些開源的網(wǎng)絡(luò)服務(wù)器。
開源的LoraWan Server
當(dāng)前開源的LoraWan Server主要有三個:
1. [chirpstack]https://www.chirpstack.io/
2. [lorawan-server]https://github.com/gotthardp/lorawan-server)
3. [ttn]https://github.com/TheThingsNetwork/ttn
其中`chirpStack`和`ttn`是Golang實現(xiàn),`lorawan-server`是Erlang實現(xiàn).
我只接觸過前兩者,本文只講述chirpStack,也是我司正在使用的LoraWanServer技術(shù)棧,嘗試過`ttn`的部署,上手簡易度沒有chirpStack好,所以沒有再繼續(xù)研究`ttn`.
部署ChirpStack
ChirpStack的部署相當(dāng)簡單,這里使用`docker-compose`部署作為例子。
1. 下載源碼
> git clone https://github.com/brocaar/chirpstack-docker.git
2. 用docker-compose部署
> cd chirpstack-docker > docker-compose up -d
下面是我執(zhí)行部署命令后的一個輸出:
[root@node123 chirpstack-docker]# docker-compose up -dCreating network "chirpstack-docker_default" with the default driverCreating chirpstack-docker_chirpstack-gateway-bridge_1 ... doneCreating chirpstack-docker_chirpstack-geolocation-server_1 ... doneCreating chirpstack-docker_chirpstack-network-server_1 ... doneCreating chirpstack-docker_mosquitto_1 ... doneCreating chirpstack-docker_redis_1 ... doneCreating chirpstack-docker_chirpstack-application-server_1 ... doneCreating chirpstack-docker_postgresql_1 ... done
現(xiàn)在打開`IP:8080`應(yīng)該就可以看到ChirpStack自帶的Application Server的頁面了,我這里的IP是`192.168.3.123`, 打開后可以看到登陸頁面:
默認(rèn)的帳號密碼是`admin/admin`,能夠登陸就已經(jīng)說明部署成功了。
當(dāng)然這個時候還不能接收傳感器數(shù)據(jù)的(指的是網(wǎng)絡(luò)服務(wù)器的配置問題),默認(rèn)的用的頻段是`EU868`,我們在國內(nèi)需要使用`CN_470_510`,修改`configuration/chirpstack-network-server/chirpstack-network-server.toml`文件中的`network_server.band`為`CN_470_510`
[network_server.band]name="CN_470_510"
將下面的`network_server.network_settings`配置注釋掉:
[network_server.network_settings]# [[network_server.network_settings.extra_channels]]# frequency=867100000# min_dr=0# max_dr=5# [[network_server.network_settings.extra_channels]]# frequency=867300000# min_dr=0# max_dr=5# [[network_server.network_settings.extra_channels]]# frequency=867500000# min_dr=0# max_dr=5# [[network_server.network_settings.extra_channels]]# frequency=867700000# min_dr=0# max_dr=5# [[network_server.network_settings.extra_channels]]# frequency=867900000# min_dr=0# max_dr=5`
以上就是docker-compose中怎么部署ChirpStack,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降?。希望你能通過這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。