新閣教育喜科堂不得不說,工業圈是個比較奇怪的圈子,各種各樣的項目需求都有,有的人就希望價格低,功能實現即可,有的人又不在乎價格,就要界面好看。最近有一個小伙伴又提出了這樣的需求,用最簡單的方式,最低的成本,最少的代碼,實現本地的PLC數據上雲。我想了一下,如果想實現這種需求,我們就要站在巨人的肩膀上,用現成的輪子,將它們進行組裝,變成自己的東西。那么這次,我們就采用S7.NET+Log4Net+SQLSugar+MySQL來實現一個西門子PLC數據上雲的案例。
1、框架實現
關於這4個組件,有一個共同點,那就是開源免費,這樣我們就不用擔心價格和授權的問題了,我們先對這4個組件做一個簡單的介紹:
這個實現過程分為兩部分,首先在阿里雲服務器中部署一個MySQL數據庫,一側通過S7.NET采集西門子PLC,然后使用Log4Net直接插入到阿里雲服務器中,另一側通過SQLSugar從數據庫進行查詢解析,再進行顯示。

2、Iot傳輸實現
- 首先在PLC中准備好需要傳輸的數據,最好提前都數據到放到同一個存儲區中,並且是連續的N個字節,這里以一個結構體為例,里面包含25個浮點數,占100個字節,如下圖所示:

- 然后創建一個DB塊,取名為IotDB,DB號為DB1,添加一個Iot結構體變量,如下圖所示:

- 創建一個控制台應用程序,取名為thinger.cn.IotDataTransfer,該項目用於和PLC通信,並將數據傳輸到阿里雲服務器中的MySQL數據中,這里為了方便,直接將讀取的字節數組轉換16進制字符串進行傳輸。
- 首先在Nuget服務器中搜索S7netplus,添加到項目中,如下圖所示:

- 接着搜索log4net,添加到項目中,如下圖所示:

- 最后再搜索mysql,添加到項目中,如下圖所示:

- 添加完成之后,初始化PLC對象,然后連接PLC,連接成功后,開啟一個定時器,編寫程序如下所示:【公眾號dotNet工控上位機:thinger_swj】

- 定時器定時讀取PLC數據,然后通過Log4Net直接存儲到數據中,如下圖所示:

- 運行程序后,結果如下所示:

- 使用SQLyog查看服務器數據庫數據, 如下所示:

- 通過這種方式,我們可以很輕松實現PLC數據讀取並存儲到雲端數據庫中,初步實現了數據上雲,接下來我們可以通過創建一個上位機程序,實現數據的查詢、解析及顯示。
3、Iot接收實現
- 創建一個Windows窗體應用程序,取名為thinger.cn.IotDataReceiver,該項目用於從雲服務器的MySQL數據庫中查詢數據,並將數據解析成需要的數值,然后進行顯示。
- 由於參數類型各種情況都有,因此針對參數創建了一個參數實體類,如下所示:

- UI界面設計如下圖所示:

- 這里采用多線程的方式,持續從數據庫中進行數據查詢,如果查詢到數據,進行解析賦值,否則進行狀態顯示,代碼如下所示:

- 最終運行結果如下所示:


4、整體總結
隨着越來越多的設備開始加入IIoT 網絡(Industrial Internet of Things,工業物聯網簡稱IIoT),誕生了很多向前發展的機會。IT與OT的融合將為工廠自動化、資產管理和生產制造執行系統提供開箱即用的集成解決方案。按目前的趨勢發展下去,IT與OT之間的界限將逐漸消失,直到成為一個或相同的系統為止。本文主要從電氣工程師的角度出發,讓大家學會使用開源組件來搭建一個簡單的物聯網平台。
為了便於大家更好地學習, 新閣教育喜科堂將通過免費直播課的方式演示整個項目的部署及開發,通過完整的項目分析及編寫,即使你是上位機初學者,也能帶你實現項目所有功能,希望能給大家學習帶來一些幫助。【公眾號dotNet工控上位機:thinger_swj】