搜尋
首頁php框架Swooleswoole都用在哪裡

swoole都用在哪裡

Dec 06, 2019 pm 02:10 PM
swoole

swoole都用在哪裡

應用程式場景簡介

與硬體設備連接通訊(定位設備)

IM系統(用於直播頁面的聊天通訊)                (推薦學習: swoole視頻教程

場景1 - 實時收集定位數據實時輸出(例滴滴司機行駛軌跡)

說明:

需要將所有的定位裝置即時的接收,將即時的軌跡記錄顯示在地圖上

注意點:

第一點:

web1伺服器連線的使用者1,2,3,web1廣播訊息時只能廣播使用者1,2,3,不能廣播web2連線的用戶4,5,6,假設場景是聊天,用戶1發送一訊息,只有web1 伺服器的用戶能看到,web2的用戶全部不能收到

swoole都用在哪裡

# #第二點:訊息的頻率控制,例:100個設備,100個用戶, 100個設備每秒上傳一條數據,需要即時廣播給每個用戶,就是每秒要100*100 = 1W次,所以可以將每秒資料廣播給所有使用者等等方法

場景2 - 只收集定位裝置入庫

說明:需要把所有的定位裝置上傳的資料入庫,設備7個,每秒一條數據,個人使用swoole 的task 函數(投遞一個異步的任務到task_worker池中,此函數是非阻塞的, worker進程數同樣可以配置) 後調用接口方式入庫

伺服器記憶體警報問題

原因: 在於swoole_server->task 函數

官方介紹task底層使用Unix Socket管道通信,是全記憶體的,沒有IO消耗。單一進程讀寫效能可達100萬/s,不同的進程使用不同的管道通信,可最大化利用多核心。

但這任務如果是呼叫程式介面時,由於網路的延遲,增加的任務大於消費的任務時,記憶體佔用會持續的增加,導致伺服器的記憶體被佔滿。

解決方法:訊息針對入任務的頻率控制,可以根據自己的業務場景定義這個時間與是否可延遲等情況,匯總1秒內的所有資料再調用程式介面(匯總時個人使用redis ),最好能直接入庫,不必呼叫介面

場景-IM系統

#參考官方github: webim系統.

官方wiki: swoole 框架wiki

好處

封裝了資料庫的model類,資料庫的ORM介面

redis的封裝,可以實作多實例存取

框架有一些常用的方法,像是log 等等(我只用到了log)

webim 官方有demon,可以參考

以上是swoole都用在哪裡的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。