5.Netty入門第五章——協(xié)議棧開發(fā)紀(jì)要

Netty的HTTP協(xié)議棧開發(fā)的客戶端和服務(wù)端具有Netty的天然優(yōu)勢(shì)——異步事件驅(qū)動(dòng)。所以以此開發(fā)的HTTP協(xié)議棧程序也是異步非阻塞的掂碱。本章節(jié)介紹如何利用Netty提供的基礎(chǔ)完成HTTP協(xié)議棧的開發(fā)怜姿。

1. Netty+XML 協(xié)議棧開發(fā)

HTTP僅僅是承載數(shù)據(jù)交換的通道,是載體而不是Web容器疼燥,沒(méi)有必要上Tomcat等重量型容器沧卢。

2. WebSocket開發(fā)

對(duì)于HTTP協(xié)議,開銷較大醉者,服務(wù)器只有收到請(qǐng)求才會(huì)應(yīng)答搏恤,不適合做低延遲應(yīng)用。Websocket將網(wǎng)絡(luò)套接字引入客戶端和服務(wù)端湃交。瀏覽器和服務(wù)器之間可以通過(guò)套接字建立持久的連接熟空。雙方都可以互發(fā)數(shù)據(jù)給對(duì)方。

2.1. HTTP協(xié)議的弊端:

  1. HTTP半雙工搞莺,兩端不能同事傳輸數(shù)據(jù)
  2. HTTP消息冗長(zhǎng)繁瑣息罗,包括消息頭、消息體才沧、換行符等迈喉,通常绍刮,基于文本傳輸方式,要比其他二進(jìn)制通信 協(xié)議繁瑣和冗長(zhǎng)挨摸。
  3. 針對(duì)服務(wù)器推送的黑客攻擊孩革,如長(zhǎng)輪詢。

目前得运,很多網(wǎng)站為了實(shí)現(xiàn)消息推送膝蜈,基本上都是采用長(zhǎng)輪詢(例如每秒1次HTTP Request),header冗長(zhǎng)熔掺,占用帶寬和服務(wù)器的資源饱搏。因此HTML5定義了WebSocket協(xié)議,更好的節(jié)省了服務(wù)器資源和帶寬實(shí)現(xiàn)實(shí)時(shí)通信置逻。
新的長(zhǎng)輪詢技術(shù)是Comet推沸,使用AJAX,可達(dá)到雙向通信券坞,但依然需要發(fā)送請(qǐng)求鬓催,切普遍采用了長(zhǎng)連接,也會(huì)消耗帶寬和資源恨锚。

2.2. WebSocket特點(diǎn):

  1. 瀏覽器與服務(wù)器只需做一個(gè)握手操作(與TCP握手不在同一層次宇驾,TCP握手后連接建立,WebSocket握手是指在TCP建立后告訴服務(wù)器這個(gè)一個(gè)WebSocket握手信息)眠冈,然后形成快速通道飞苇,WebSocket基于TCP的全雙工通訊菌瘫,相比HTTP的半雙工蜗顽,性能得到較大的提升。
  2. 對(duì)代理和防火墻透明
  3. 無(wú)Header雨让、Cookie和身份認(rèn)證
  4. 無(wú)安全開銷
  5. 通過(guò)"ping/pong"幀保持鏈路激活
  6. 服務(wù)器主動(dòng)推送到客戶端雇盖,無(wú)需客戶端的長(zhǎng)輪詢

2.3. WebSocket連接的建立和關(guān)閉

建立:需要客戶端或者瀏覽器發(fā)出握手請(qǐng)求,請(qǐng)求消息為HTTP請(qǐng)求栖忠,其中包含了附加的頭信息崔挖,如Upgrade: websocketConnection: Upgrade等。

GET ws://echo.websocket.org/?encoding=text HTTP/1.1
Host: echo.websocket.org
Connection: Upgrade
Pragma: no-cache
Cache-Control: no-cache
Upgrade: websocket
Origin: http://websocket.org
Sec-WebSocket-Version: 13
User-Agent: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.90 Safari/537.36
Accept-Encoding: gzip, deflate, sdch
Accept-Language: zh-CN,zh;q=0.8,de;q=0.6
Cookie: _ga=GA1.2.2145434661.1502418351; _gid=GA1.2.1865172317.1502418351; _gat=1
Sec-WebSocket-Key: VDY/9d/0RyXxpbW6YRd++Q==
Sec-WebSocket-Extensions: permessage-deflate; client_max_window_bits

服務(wù)器解析頭信息并做出應(yīng)答庵寞,包含附加字段如:Connection: UpgradeUpgrade: websocket

HTTP/1.1 101 Web Socket Protocol Handshake
Access-Control-Allow-Credentials: true
Access-Control-Allow-Headers: content-type
Access-Control-Allow-Headers: authorization
Access-Control-Allow-Headers: x-websocket-extensions
Access-Control-Allow-Headers: x-websocket-version
Access-Control-Allow-Headers: x-websocket-protocol
Access-Control-Allow-Origin: http://websocket.org
Connection: Upgrade
Date: Fri, 11 Aug 2017 02:41:01 GMT
Sec-WebSocket-Accept: 0xphShwDb6MpA6oZYZsYpiuJNhk=
Server: Kaazing Gateway
Upgrade: websocket

連接建立成功狸相。

關(guān)閉:
上述連接持續(xù)到某一端主動(dòng)關(guān)閉連接。
底層的TCP連接應(yīng)該首先由服務(wù)器關(guān)閉捐川,異常情況下脓鹃,可以由客戶端發(fā)起TCP Close。

3. 私有協(xié)議棧開發(fā)

廣義上古沥,通信協(xié)議可分為公有和私有協(xié)議瘸右。私有協(xié)議具有更好的靈活性娇跟,往往會(huì)在公司和組織內(nèi)部使用,按需定制太颤。絕大多數(shù)協(xié)議都是基于TCP/IP苞俘,所以利用Netty的NIO TCP協(xié)議棧可以非常方便進(jìn)行定制開發(fā)龄章。

大型系統(tǒng)往往會(huì)被拆分成多個(gè)模塊吃谣,各個(gè)模塊可能需要實(shí)現(xiàn)跨節(jié)點(diǎn)通信,在傳統(tǒng)的JAVA應(yīng)用中瓦堵,通常使用一下4種方式進(jìn)行跨節(jié)點(diǎn)通信:

  1. RMI遠(yuǎn)程服務(wù)調(diào)用
  2. Java的Socket+Java序列化方式
  3. 利用開源RPC框架基协,如Facebook的Thrift、Apache的Avro
  4. 利用標(biāo)準(zhǔn)的公有協(xié)議菇用,如HTTP+XML澜驮、RESTful+JSON、Webservice
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末惋鸥,一起剝皮案震驚了整個(gè)濱河市杂穷,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌卦绣,老刑警劉巖耐量,帶你破解...
    沈念sama閱讀 221,635評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異滤港,居然都是意外死亡廊蜒,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,543評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門溅漾,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)山叮,“玉大人,你說(shuō)我怎么就攤上這事添履∑ň螅” “怎么了?”我有些...
    開封第一講書人閱讀 168,083評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵暮胧,是天一觀的道長(zhǎng)锐借。 經(jīng)常有香客問(wèn)我,道長(zhǎng)往衷,這世上最難降的妖魔是什么钞翔? 我笑而不...
    開封第一講書人閱讀 59,640評(píng)論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮席舍,結(jié)果婚禮上布轿,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好驮捍,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,640評(píng)論 6 397
  • 文/花漫 我一把揭開白布疟呐。 她就那樣靜靜地躺著,像睡著了一般东且。 火紅的嫁衣襯著肌膚如雪启具。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,262評(píng)論 1 308
  • 那天珊泳,我揣著相機(jī)與錄音鲁冯,去河邊找鬼。 笑死色查,一個(gè)胖子當(dāng)著我的面吹牛薯演,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播秧了,決...
    沈念sama閱讀 40,833評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼跨扮,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了验毡?” 一聲冷哼從身側(cè)響起衡创,我...
    開封第一講書人閱讀 39,736評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎晶通,沒(méi)想到半個(gè)月后璃氢,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,280評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡狮辽,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,369評(píng)論 3 340
  • 正文 我和宋清朗相戀三年一也,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片喉脖。...
    茶點(diǎn)故事閱讀 40,503評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡椰苟,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出动看,到底是詐尸還是另有隱情尊剔,我是刑警寧澤爪幻,帶...
    沈念sama閱讀 36,185評(píng)論 5 350
  • 正文 年R本政府宣布菱皆,位于F島的核電站,受9級(jí)特大地震影響挨稿,放射性物質(zhì)發(fā)生泄漏仇轻。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,870評(píng)論 3 333
  • 文/蒙蒙 一奶甘、第九天 我趴在偏房一處隱蔽的房頂上張望篷店。 院中可真熱鬧,春花似錦、人聲如沸疲陕。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,340評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)蹄殃。三九已至携茂,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間诅岩,已是汗流浹背讳苦。 一陣腳步聲響...
    開封第一講書人閱讀 33,460評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留吩谦,地道東北人鸳谜。 一個(gè)月前我還...
    沈念sama閱讀 48,909評(píng)論 3 376
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像式廷,于是被迫代替她去往敵國(guó)和親咐扭。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,512評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容