專案是在不同的10個地方,設備通過網路發送資料到監控端,監控端對10個不同的資料進行實時處理、比對,存盤。
問題1:監控端如何滿足20個不同的IP同時訪問?用到什么技術?或者怎么實作?
問題2:對監控端操作、查詢資料,滿足回應時間小于5秒,這個如何保證?用到什么技術?
問題3:監控端有遠程控制的功能,可以控制10個地方的電腦,進行開關機等操作,這個用到什么技術?如何實作?
非常感謝感謝大神們,無論是一字一句,一個技術名詞,一個知識點,這都將對我有巨大的幫助,歡迎回復
uj5u.com熱心網友回復:
對萌新來說有些困難,你還沒有接觸到正式點的專案。現在來說,這種東西正式的專案,其實完全超出程式員的理解。當然你要手工打造其實也ok,當然你手工打造的,更正規專案至少差15年的水準
我們先來說現在正式專案的選擇
1. mqtt協議-------mqtt broke----------mqtt轉發插件(可選,主要是兼容其他資料流處理,比如轉發給spark,storm,flink)--------時序資料庫。
至于遠程控制這塊mqtt協議也可以支持。
這種方案其實就是目前,華為,小米,百度,騰訊的IOT物聯網的基礎方案
2.一些小型快速專案的選擇
比如Prometheus+Grafana 的,Prometheus負責資料抓取,Grafana負責展示控制(當然他們后面還有個時序資料)
選1,2主要看專案目標。
在來看你要完全手工打造的話
如果是15年前方式
1.資料采集---------webapi/tcp +json
2.資料存盤---------------sql
3.查詢----------sql
4.控制------------tcp
所以我們說,如果以當前的主流專案來看,如果只有15年前那種技術背景的人來看,完全就不是一個東西,很難講到一起去。
所以,如果你想繼續討論。請先定你們能接受的方式,不然這帖子很難統一討論
uj5u.com熱心網友回復:
我先談現在主流專案的設備端:mqttclient----------------對應你的10個不同的地方
訊息bus:mqttBroke-----------------對應你的“監控端”,當然監控端我打引號,因為他其實不是監控,而是訊息中心
資料流批處理spark,storm-----------對應的實時計算
時序資料庫-----------對應你的查詢和存盤
至于你的遠程控制-------如果你查閱mqtt資料,你會發現。他是訊息訂閱和發布機制的,所以你的每個mqttclient可以訂閱自己的訊息topic,所以反向控制操作本身,mqtt協議是支持的
現在主流專案為啥這么選,因為專業性、隔離性,各部分只處理各部分的事情。所以每個部分都可以更專業化,比如時序資料庫可以有更專業的聚合統計,抽樣功能,訊息bus則可以更加專業的處置高并發,高可用需求
同時每個部分都隔離,你會發現你的擴展性會更好。比如你可以隨時新增新的topic已適應新要求,也可以隨時新增新的spark批處理,進行新指標的實時計算
uj5u.com熱心網友回復:
1、既然有IP了,應該是TCP了,Socket,高級點Vert.X。2、資料查詢么,RDB,NOSQL都可以,回應時間么看你怎么優化了,以及查詢范圍怎么定了,
3、遠程控制么看你設備是什么樣的,能接受什么的遠程操作。Windows么可以遠程桌面,Powshell,Linux么可以NVC、SSH,也可以提供HTTP服務,通過WEB遠程控制,比如Centos的WEBConsole。
uj5u.com熱心網友回復:
你監控些什么東西呢?你的設備是一臺PC機或者服務器嗎?是做堡壘機軟體嗎?如果是只需要在服務器設日志訂閱就可以了向你的服務器報告日志訊息了,然后你自自己向庫插東。遠程操作就根據操作系來調rdp /ssh 來連.至于開關機的事是連上再說的。uj5u.com熱心網友回復:
訪問監控端bs模式,監控端遠程控制cs模式uj5u.com熱心網友回復:
你可以報預算了uj5u.com熱心網友回復:
這么多新名詞,真是太用心了,非常感謝感謝。我再去搜搜,想想,學學你說的這些,再次感謝uj5u.com熱心網友回復:
熟悉的ID,我感覺你曾幫我好幾次了,非常感謝感謝啊,根據你說的我再了解了解去。uj5u.com熱心網友回復:
要監控一臺電腦,資料每秒都發,10臺同時發,監控端接收。感謝感謝,我去搜搜rdp、ssh這些。
uj5u.com熱心網友回復:
“萌新寫檔案時”難道不是程式員?是產品經理?
看到二樓說的 mqtt,我們專案中也有用,想想確實可以實作你這些需求。其實需要的是某種訊息佇列,你客戶端訂閱訊息,收到后決議出是哪條指令,然后執行相應的動作,比如開關機。
轉載請註明出處,本文鏈接:https://www.uj5u.com/net/239839.html
標籤:C#
