亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

java - 面試題,10w臺設備要求查詢在線狀態,應該用什么技術?

瀏覽:72日期:2023-12-18 16:54:57

問題描述

對于高并發不太了解,這種應該怎么處理?高并發有什么入門書籍嗎

問題解答

回答1:

直接用TCP 長連接~ 智能家居一般 MQTT 協議比較多~~長連接比輪詢省太多資源了~單機情況下還是可以實現的,當然,算上數據庫就另說了。

回答2:

這里想考察你對分布式架構的認識,就這個問題應該是想考察你對于服務發現(service discovery)的認識。分布式就是把一個大型項目進行模塊化拆分,然后各模塊在做集群部署,前端有一個路由服務器來對到達的請求進行分發,把到達的請求路由到能夠提供服務的服務端,而哪臺服務器能夠提供服務這就是服務發現所要做的事情,而在集群環境下能夠提供相等服務的服務器肯定不止一臺,那到底該由那臺服務器對用戶的請求進行處理并響應呢?這就又引出了負載均衡,由負載均衡層通過特定的算法來判斷應該由那臺服務器提供服務,目的就是均勻的把請求分發給各個服務端。服務發現可以了解下Apache的zookeeper或者Netflix的Eureka。微服務這塊spring cloud提供了全套的解決方案,還有阿里的dubbo

回答3:

分布式session管理

回答4:

我出個簡單一點方案給設備安裝一個代理進程,設備啟動時啟動該進程,然后由進程主動定時向服務器上報設備狀態,如果超過一定周期沒上報就認為該設備已經離線

回答5:

高并發,異步通信。java 的話。。。 經典的 netty ?個人意見,按目前的單機性能,100k并發單機能撐住,分布式處理不是必選項,當然要是算上數據庫存儲什么的就另說了。

回答6:

假如不考慮長連接的話,有個思路 利用redis設置一個每個設備上線flag并設置其一個有效時間 客戶端每次做上行請求的時候刷新該有效時間 每次統計redis在線狀態設備數量就好了 這里關鍵是這個時間的長度怎么來定 因為一直是做后端的 不清楚這里客戶端不活躍的情況下能保持在線多久 是否有類似守護進程之類的

回答7:

把數據存儲在redis里面,存取相對于db快

回答8:

是我的話,我會這樣做:新建一個MySQL內存表(ENGINE=MEMORY):online(user_id, update_time)用update_time記錄用戶最近訪問時間.比如可以假設在5分鐘以內的用戶都認為在線.

回答9:

可以分層實現,舉個例子,比如10w臺機器,分別向10臺機器上報本機狀況,10w臺怎么對應10臺,可以通過hash映射的方式,然后這10臺機器再把出現故障的機器向一個固定的主機上報情況,大概意思就是10w-->10-->1,上述例子可能存在單點故障,可以通過改變上層機器數解決單點故障

標簽: java
相關文章:
主站蜘蛛池模板: 亚洲一区二区三区免费视频 | 日本精品久久久久中文字幕2 | 久久综合色婷婷 | 国产做爰一区二区 | 成年女人视频在线观看免费 | 日本二级毛片免费 | 青草国产精品久久久久久 | 久久综合婷婷香五月 | 国产在线观看第一页 | 免费特黄一级欧美大片 | 色花五月色婷婷 | 日韩字幕一中文在线综合 | 久久久亚洲精品国产 | 亚洲午夜久久久久影院 | 欧美三级毛片 | 国产成人高清 | 1024国产高清精品推荐 | a级毛片免费 | 久久久久久久九九九九 | 女人毛片 | 亚洲丶国产丶欧美一区二区三区 | 国产亚洲精品国看不卡 | 超级碰碰青草久热国产 | 国产精品久久二区三区色裕 | 免费看美女午夜大片 | 亚洲色大成网站www久久九九 | 一级黄色片欧美 | 亚洲成人一区 | 香蕉香蕉国产片一级一级毛片 | 黄色xxxxxx| 热久久综合网 | 亚洲欧美国产五月天综合 | 久久99精品久久久久久三级 | 韩国女主播精品一区二区 | 国产精品一区二区四区 | 真人女人一级毛片免费视频观看 | 日本免费大片免费视频 | 色片免费 | yiren22开心综合成人网 | 最新国产视频 | 永久免费看黄在线播放 |