2018-02-04

Messaging API 應用,雲端數據即時傳遞

Messaging API 應用 : 雲端數據即時傳遞
=================================
    日前完成 Arduino 雲端無線環境觀測站,基本架構就是將 感應 Sensor 數據信號透過無線 2.4G Wireless 模組傳遞到 2.4G Wireless 基地台;2.4G Wireless 基地台接收到 Sensor 數據,再將數據透過 W5100 Ethernet 模組轉存到本地資料庫 Local Database 或 雲端資料庫 Cloud Database,這些數據收集後的結果,都需要 “被動的” 透過 網路瀏覽器 Internet browser 或 手機 APP 瀏覽數據收集的結果。 (如下圖)



    上述 “被動的” 瀏覽查看數據的結果,感覺上總是覺得美中不足缺少了什麼?沒錯,就是缺少了 “主動通知” 的機制。於是,如何在現有的被動機制下,發展出主動的機制呢。。。接下來就是本篇的說明。

    有一天老闆突然要我們由南部出發,要去北部出差。接下來我們的行動是什麼呢?
1. 趕緊拿起書本與榔頭,開始準備 打造交通工具
2. 上網規劃行程與訂購車票?
3. ???

找對方法是很重要的~

    當然,有很多種方法可以達到老闆的要求目的與目標,在現今科技進步資訊爆炸的年代,我們怎麼站在巨人的肩膀上看世界。執行方法與對策有很多種,如何找到 “合適” 的方法就格外重要了。接下來介紹使用 IFTTT 的一種應用範例。

    什麼是 IFTTT,IFTTT 是一個新生的網絡服務平台,通過其他不同平台的條件來決定是否執行下一條命令。即對網絡服務通過其他網絡服務作出反應。 雲端應用 IFTTT 能達到整合應用的效果!所謂的 IFTTT 指的是「If This Then That」,意指你可以定義一個 Recipe(食譜),其中包含了 Trigger(觸發條件) Action(執行動作),當 Trigger 的條件成立時會執行 Action 的動作。




    運用前端的 感應 Sensor 上傳量測後的數據到 Cloud Database ThingSpeak 上, 在 ThingSpeak  WebHTTP 設定觸發條件。例如當 溫度低於設定值;或是煙霧 / 一氧化碳等感應器的量測數值高於設定值,ThingSpeak  WebHTTP 觸發條件成立後,將觸發內容傳送到 IFTTT 的 WebHooks 應用介面上,IFTTT 收到(觸發信號)後,經過應用程式處理後,轉發到 IFTTT Webhooks 設定的 (執行動作)上。例如:執行動作為,將信息內容轉發到 Line Notify 上,即如下列範例照片,在 Line Notify 上收到 感應 Sensor 的即時數據內容。透過上述的動作,完成異常訊息立即傳遞的機制了。

硬體架構與應用軟體的整合 


    所以,我們應用 IFTTT 的 WebHooks 功能。IFTTT 的詳細操作設定就不在這裡贅述,網路上有非常多且詳細的操作設定介紹。這裡在說明有什麼工具可以快速的完成我們的需求,我們就不需要大費周章的 “敲磚蓋樓” ,直接找到合適的應用來整合,這就是所謂的 “站在巨人的肩膀上看世界” 的道理~

IFTTT 的 Webhooks




ThingSpeak WebHTTP ( 觸發設定 )





IFTTT 的 Webhooks 設定





IFTTT 的 Webhooks 最終的 Action:將信息傳送到 Line Notify 上

 or 







2017-12-01

Arduino 雲端無線環境觀測站

Arduino 雲端無線環境觀測站
=======================
近日常常聽到  AI 人工智慧(Artificial Intelligence)vs. Cloud Database 雲端資料庫 vs. IOT ( Internet of Things ) 物聯網  的新聞與應用。
想想,好像還不錯耶~,弄個最近比較夯的應用試試。。。


雲端環境觀測站( Cloud  + IOT ):
Arduino + 2.4G Wireless Sensor + Arduino Ethernet Shield W5100 乙太網路擴充板 + NAS + Database Server + ThingSpeak(IOT)+ Android APP... = 雲端無線環境觀測站 (溫濕度 / 大氣壓力 / 煙霧,瓦斯,CO 一氧化碳 Sensor 感應器)

雲端環境觀測站 架構圖:

Part I :
無線 Sensor 感應器發射模組(無線傳輸發射 Sensor 狀態)遠端收集數據,透過無線方式傳輸資料到 無線 Sensor 感應器接收模組(無線傳輸接收 Sensor 狀態),透過 無線接收模組 內的 W5100 Ethernet 網路模組將數據存儲於 Local 本地端 NAS 內的 Database Server 中處理分析,及將數據透過 Internet 傳輸到 Internet 網際網路 的 Cloud 雲端 ThingSpeak(IOT)資料庫材料分析;手機可以透過 Android 安卓 APP 連上  Internet 網際網路 的 Cloud 雲端 ThingSpeak(IOT)資料庫做顯示分析。


應用實物照片如下:

無線 Sensor 感應器發射模組(無線傳輸發射 Sensor 狀態):


無線 Sensor 感應器發射模組(模組穿上衣服的狀態):



無線 Sensor 感應器接收模組(無線傳輸接收 Sensor 狀態):
 

顯示 Sensor 狀態:溫濕度


顯示 Sensor 狀態:煙霧,瓦斯,非可燃 CO 一氧化碳,可燃 CO 一氧化碳


顯示 Sensor 狀態:大氣壓力 (絕對壓力 / 相對壓力 )/ 海拔高度 / 溫度



運用 Arduino Ethernet Shield W5100 乙太網路擴充板 直接連結 Database Server
(以往論壇都是運用 W5100 連結 Web Server,透過 Web Server 的 PHP 語法再轉拋數據到資料庫。本次直接跨域 Web Server + PHP 直接連結 DataBase Server )



參考資料:http://www.arduinolibraries.info/libraries/my-sql-connector-arduino

/*
  MySQL Connector/Arduino Example : connect by hostname

*/

#include <Ethernet.h>
#include <MySQL_Connection.h>
#include <MySQL_Cursor.h>

byte mac_addr[] = { 0x12, 0x34, 0x56, 0x78, 0x9A, 0xBC };


// IP of the MySQL *server* here 資料庫 Server 位址

IPAddress server_addr(192,168,1,123);  
char user[] = "root";              // MySQL user login username 使用者名稱
char password[] = "123456";        // MySQL user login password 使用者密碼

// ****** Sample query ******

// char INSERT_SQL[] = "INSERT INTO 資料庫名稱.資料表名稱 (message) VALUES ('Hello, Arduino!')";
char INSERT_SQL[] = "INSERT INTO test_arduino.hello_arduino (message) VALUES ('Hello, Arduino!')";

EthernetClient client;

MySQL_Connection conn((Client *)&client);

void setup() {

  Serial.begin(115200);
  while (!Serial); // wait for serial port to connect
  Ethernet.begin(mac_addr);
  Serial.println("Connecting...");
  // conn.connect(資料庫位址, 資料庫 Port Number, 使用者名稱, 使用者密碼)
  if (conn.connect(server_addr, 3306, user, password)) {
    delay(1000);
  }
  else
    Serial.println("Connection failed.");
}


上傳 Cloud 雲端 ThingSpeak 資料庫:




NAS:Network Attached Storage(網路連接儲存設備)- DS111


顯示 Local Database Server 本地資料庫 狀態:




Cloud 雲端 ThingSpeak(IOT):Night Eagle's Weather Station ( 雲端無線環境觀測站 )

ThingSpeak:溫濕度狀態


ThingSpeak:煙霧,瓦斯,非可燃 CO 一氧化碳,可燃 CO 一氧化碳 狀態


ThingSpeak:大氣壓力 (絕對壓力 / 相對壓力 )






Part II:
上述 Database 資料庫再加上 PHP + Web Server 做 Local 本地資料分析;再加上 Messenger API 將及時訊息傳遞到社群軟體中(Line / FB / twitter... )......續待 

希望透過上述無線數據的接收與轉發,再透過 Ethernet & Internet 將資料儲存於資料庫後,做最終資料庫數據的分析與應用,以達到 IOT ( Internet of Things ) 物聯網  的思維應用。

目前一般工廠的應用狀況大概是,熟悉生產設備的熟悉生產設備;熟悉 IT 數據程式應用的熟悉 IT 領域;最大的問題應該是在,如何讓生產設備的數據轉化成 IT 可以處理的數據,接下來的就是如何運用這些數據,提供更具價值的 Action Plan。。。



< 上一篇