Socket通信的原理還是比較簡單的, 它大致分為以下幾個步驟。 服務器端的步驟如下。 (1)建立服務器端的Socket,開始偵聽整個網(wǎng)絡中的連接請求。 (2)當檢測到來自客戶端的連接請求時,向客戶端發(fā)送收到連接請求的信息,并建立與客戶端之間的...
目前成都創(chuàng)新互聯(lián)已為近1000家的企業(yè)提供了網(wǎng)站建設、域名、雅安服務器托管、網(wǎng)站托管、企業(yè)網(wǎng)站設計、團風網(wǎng)站維護等服務,公司將堅持客戶導向、應用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
目前websocket技術已經(jīng)很成熟,選型Go語言,當然是為了節(jié)省成本以及它強大的高并發(fā)性能。我使用的是第三方開源的websocket庫即gorilla/websocket。
由于我們線上推送的量不小,推送后端需要部署多節(jié)點保持高可用,所以需要自己做集群,具體架構方案如圖:
Auth Service:鑒權服務,根據(jù)Token驗證用戶權限。
Collect Service:消息采集服務,負責收集業(yè)務系統(tǒng)消息,存入MongoDB后,發(fā)送給消息分發(fā)服務。
Dispatch Service:消息分發(fā)服務,根據(jù)路由規(guī)則分發(fā)至對應消息推送服務節(jié)點上。
Push Service:消息推送服務,通過websocket將消息推送給用戶。
集群推送的關鍵點在于,web端與服務端建立長連接之后,具體跟哪個推送節(jié)點保持長連接的,如果我們能夠找到對應的連接節(jié)點,那么我們就可以將消息推送出去。下面講解一下集群的大致流程:
1. web端用戶登錄之后,帶上token與后端推送服務(Push Service)保持長連接。
2. 推送服務收到連接請求之后,攜帶token去鑒權服務(Auth Service)驗證此token權限,并返回用戶ID。
3. 把返回的用戶ID與長連接存入本地緩存,保持用戶ID與長連接綁定關系。
4. 再將用戶ID與本推送節(jié)點IP存入redis,建立用戶(即長連接)與節(jié)點綁定關系,并設置失效時間。
5. 采集服務(Collect Service)收集業(yè)務消息,首先存入mongodb,然后將消息透傳給分發(fā)服務(Dispatch Service)。
6. 分發(fā)服務收到消息之后,根據(jù)消息體中的用戶ID,從redis中獲取對應的推送服務節(jié)點IP,然后轉發(fā)給對應的推送節(jié)點。
7. 推送服務節(jié)點收到消息之后,根據(jù)用戶ID,從本地緩存中取出對應的長連接,將消息推送給客戶端。
其他注意事項:
Go作為Google2009年推出的語言,其被設計成一門應用于搭載 Web 服務器,存儲集群或類似用途的巨型中央服務器的系統(tǒng)編程語言。
對于高性能分布式系統(tǒng)領域而言,Go 語言無疑比大多數(shù)其它語言有著更高的開發(fā)效率。它提供了海量并行的支持,這對于 游戲 服務端的開發(fā)而言是再好不過了。
到現(xiàn)在Go的開發(fā)已經(jīng)是完全開放的,并且擁有一個活躍的社區(qū)。
=================================
哪些大公司在使用Go語言:
1、Google
這個不用多做介紹,作為開發(fā)Go語言的公司,當仁不讓。Google基于Go有很多優(yōu)秀的項目,比如: ,大家也可以在Github上 查看更多Google的Go開源項目。
2、Facebook
Facebook也在用,為此他們還專門在Github上建立了一個開源組織facebookgo,大家可以通過 訪問查看facebook開源的項目,比如著名的是平滑升級的grace。
3、騰訊
騰訊作為國內的大公司,還是敢于嘗試的,尤其是Docker容器化這一塊,他們在15年已經(jīng)做了docker萬臺規(guī)模的實踐,具體可以參考
4、百度
目前所知的百度的使用是在運維這邊,是百度運維的一個BFE項目,負責前端流量的接入。他們的負責人在2016年有分享,大家可以看下這個
5、阿里
阿里巴巴具體的項目不太清楚,不過聽說其系統(tǒng)部門、CDN等正在招Go方面的人。
6、京東
京東云消息推送系統(tǒng)、云存儲,以及京東商城等都有使用Go做開發(fā)。
7、小米
小米對Golang的支持,莫過于運維監(jiān)控系統(tǒng)的開源,也就是
此外,小米互娛、小米商城、小米視頻、小米生態(tài)鏈等團隊都在使用Golang。
8、360
360對Golang的使用也不少,一個是開源的日志搜索系統(tǒng)Poseidon,托管在Github上,
==================================
Go適合做什么?為何這么多人偏愛Go語言?
Go強大的開發(fā)團隊
1、自由高效:組合的思想、無侵入式的接口
Go語言可以說是開發(fā)效率和運行效率二者的完美融合,天生的并發(fā)編程支持。Go語言支持當前所有的編程范式,包括過程式編程、面向對象編程以及函數(shù)式編程。程序員們可以各取所需、自由組合、想怎么玩就怎么玩。
2、強大的標準庫
這包括互聯(lián)網(wǎng)應用、系統(tǒng)編程和網(wǎng)絡編程。Go里面的標準庫基本上已經(jīng)是非常穩(wěn)定了,特別是我這里提到的三個,網(wǎng)絡層、系統(tǒng)層的庫非常實用。
3、部署方便:二進制文件、Copy部署
我相信這一點是很多人選擇Go的最大理由,因為部署太方便了,所以現(xiàn)在也有很多人用Go開發(fā)運維程序。
4、簡單的并發(fā)
它包含了降低心智的并發(fā)和簡易的數(shù)據(jù)同步,我覺得這是Go最大的特色。之所以寫正確的并發(fā)、容錯和可擴展的程序如此之難,是因為我們用了錯誤的工具和錯誤的抽象,Go可以說這一塊做的相當簡單。
5、穩(wěn)定性
Go擁有強大的編譯檢查、嚴格的編碼規(guī)范和完整的軟件生命周期工具,具有很強的穩(wěn)定性,穩(wěn)定壓倒一切。那么為什么Go相比于其他程序會更穩(wěn)定呢?這是因為Go提供了軟件生命周期(開發(fā)、測試、部署、維護等等)的各個環(huán)節(jié)的工具,如go tool、gofmt、go test。
================================
我們?yōu)槭裁催x擇GO語言
選擇GO語言,主要是基于兩方面的考慮
1. 執(zhí)行性能 縮短API的響應時長,解決批量請求訪問超時的問題。在Uwork的業(yè)務場景下,一次API批量請求,往往會涉及對另外接口服務的多次調用,而在之前的PHP實現(xiàn)模式下,要做到并行調用是非常困難的,串行處理卻不能從根本上提高處理性能。而GO語言不一樣,通過協(xié)程可以方便的實現(xiàn)API的并行處理,達到處理效率的最大化。 依賴Golang的高性能HTTP Server,提升系統(tǒng)吞吐能力,由PHP的數(shù)百級別提升到數(shù)千里甚至過萬級別。
2. 開發(fā)效率 GO語言使用起來簡單、代碼描述效率高、編碼規(guī)范統(tǒng)一、上手快。 通過少量的代碼,即可實現(xiàn)框架的標準化,并以統(tǒng)一的規(guī)范快速構建API業(yè)務邏輯。 能快速的構建各種通用組件和公共類庫,進一步提升開發(fā)效率,實現(xiàn)特定場景下的功能量產(chǎn)。
Go語言近兩年的發(fā)展速度還是非??斓?,一方面Go語言有強大的行業(yè)背書,另一方面Go語言在設計時充分考慮了當前的編程環(huán)境,加強了大數(shù)據(jù)量、高并發(fā)等應用場景的處理能力,強調編程語言自身對于處理性能的追求,相信Go語言在未來大數(shù)據(jù)和人工智能相關技術逐漸落地應用的背景下,會有一個較為廣闊的發(fā)展空間。