[更新]跨平臺物聯網通信框架 ServerSuperIO v1.2(SSIO),增長數據分發控制模式

1.【開源】C#跨平臺物聯網通信框架ServerSuperIO(SSIO)html

2.應用SuperIO(SIO)和開源跨平臺物聯網框架ServerSuperIO(SSIO)構建系統的總體方案git

3.C#工業物聯網和集成系統解決方案的技術路線(數據源、數據採集、數據上傳與接收、ActiveMQ、Mongodb、WebApi、手機App)github

4.開源地址:https://github.com/wxzz/ServerSuperIO緩存

 

1.SSIO更新內容:網絡

    增長數據分發模式(DeliveryMode),在網絡通信異步通信時,接收到數據後,能夠按設備IP或設備地址把數據分發給該設備,從而驅動設備運行。架構

    原來只能按設備IP進行數據分發,可是考慮到設備終端有多是GPRS模塊等,IP自己不固定,因此增長了按設備地址把數據分發給設備。併發

    /// <summary>
    /// 分發數據模式
    /// </summary>
    public enum DeliveryMode
    {
        [EnumDescription("設備IP分發數據")]
        DeviceIP,
        [EnumDescription("設備地址分發數據")]
        DeviceAddress
    }

 

 2.SSIO特色:框架

1)   輕型高性能通訊框架,適用於多種應用場,輪詢模式、自控模式、併發模式和單例模式。異步

2)   設備驅動、IO通道、控制模式場景協調統一。性能

3)   設備驅動內軒命令驅動器、命令緩存器、自定義參數和實時數據元素。

4)   框架平臺支持按設備命令優先級別進行調度,保證高級別命令及時發送。

5)   一個設備驅動同時支持串口和網絡兩種通信方式,能夠監視IO通道數據。

6)   一個設備驅動,在網絡通信時能夠支持TCP Server和TCP Client兩種工做模式。

7)   內置顯示視圖接口,知足不一樣顯示需求。

8)   內置服務組件接口,能夠自定義完成OPC服務、4-20mA輸出、LED大屏顯示、短信服務、以及多功能網關服務。

9)   能夠建立多服務實例,完成不一樣業務的拆分。

10) 支持跨平臺部署,能夠運行在Linux和Windows系統。

 

3.SSIO概述

    SSIO通訊框架的設計思想是在SuperIO(SIO)基礎上發展而來,並無高大上的技術,主要是工做經驗的積累,適合於不一樣應用場景的物聯網的數據 採集與交互。SSIO和SIO並非簡單的對IO高性能的操做,而是設備驅動、IO通道、控制模式和實際硬件設備之間的協調機制,各方面之間無縫銜接和運 行,也是爲了解決現實工做和應用場景的一些痛點。

  軟硬件之間的數據交互,而且面臨着複雜的現場環境:

(1)複雜的、多樣的通信協議。有標準的協議,例如:Modbus等,也有不少根據標準協議修改的協議格式、以及自定義協議格式,而且千差萬別。對於很差的軟件架構,疲於應對,增長設備或協議要對整個軟件進行梳理,每每在此過程當中出現新的問題或BUG。

(2)針對不一樣用戶對軟件界面或功能的要求有很大不一樣,使之知足不一樣用戶的顯示要求,能夠自定義數據顯示界面。那麼就須要提供顯示視圖接口,與設備驅動進行交互。

(3)既然現場設備的數據被採集上來,那麼就須要對其進行處理,不單單是保存、查詢、報表等,還有:數據轉發、數據輸出(OPC、模擬量、大屏等)等。那麼就須要提供服務性的接口,與設備驅動進行交互。

(4)通信鏈路的多種性,對於同一個設備可能要支持RS232/RS485/RS42二、RJ4五、3G/4G等通信方式,因此對於一個設備要對應多種通信方式(串口和網絡),也給咱們的開發形成很大的障礙。

(5)設備驅動、IO通道和實際的現場硬件終端之間鏈路複雜,有可能:一個設備驅動對應一個IO通道、一個設備驅動對應多個IO通道、多個設備驅動對應一個IO通道等狀況。

(6)既然設備與服務端進行數據交互,那麼就應該對設備的通信狀態、IO狀態、以及設備自己的狀態進行監控,這樣設備才處於可維護狀態。

(7)軟件各版本、以及軟件與硬件之間的兼容性不好,管理起來錯綜複雜。在框架平臺穩定的狀況下,只須要更新設備驅動。

   爲了解決以上諸多問題,開發一個軟件框架,支持二次開發。在不對軟件框架改動的狀況下,可以很方便的接入設備、維護設備、集成設備、處理設備業務數據等。軟件框架相對穩定,把容易變化的部分進行靈活設計。

 

相關文章
相關標籤/搜索