精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

服務(wù)器推送事件:一種從服務(wù)器流式推送事件的簡易方法

開發(fā) 服務(wù)器
今天我要繼續(xù)著手實現(xiàn)服務(wù)器推送事件,因為昨天一整天我都沉浸在上述這些錯誤里。好在我學(xué)到了一個以前從未聽說過的易學(xué)易用的網(wǎng)絡(luò)技術(shù),心里還是很高興的。

哈嘍!昨天我見識到了一種我以前從沒見過的從服務(wù)器推送事件的炫酷方法:服務(wù)器推送事件server-sent events!如果你只需要讓服務(wù)器發(fā)送事件,相較于 Websockets,它們或許是一個更簡便的選擇。

我會聊一聊它們的用途、運作原理,以及我昨日在試著運行它們的過程中遇到的幾個錯誤。

問題:從服務(wù)器流式推送更新

現(xiàn)在,我有一個啟動虛擬機的 Web 服務(wù),客戶端輪詢服務(wù)器,直到虛擬機啟動。但我并不想使用輪詢方式。

相反,我想讓服務(wù)器流式推送更新。我跟 Kamal 說我要用 Websockets 來實現(xiàn)它,而他建議使用服務(wù)器推送事件不失為一個更簡便的選擇!

我登時就愣住了——那什么玩意???聽起來像是些我從來沒見過的稀罕玩意兒。于是乎我就查了查。

服務(wù)器推送事件就是個 HTTP 請求協(xié)議

下文便是服務(wù)器推送事件的運作流程。我-很-高-興-地了解到它們就是個 HTTP 請求協(xié)議。

1.客戶端提出一個 GET 請求(舉個例子)https://yoursite.com/events 2.客戶端設(shè)置 Connection: keep-alive,這樣我們就能有一個長連接 3.服務(wù)器設(shè)置設(shè)置一個 Content-Type: text/event-stream 響應(yīng)頭 4.服務(wù)器開始推送事件,就比如下文這樣:

event: status
data: one

舉個例子,這里是當(dāng)我借助 curl 發(fā)送請求時,一些服務(wù)器推送事件的樣子:

$ curl -N 'http://localhost:3000/sessions/15/stream'
event: panda
data: one
event: panda
data: two
event: panda
data: three
event: elephant
data: four

服務(wù)器可以根據(jù)時間推移緩慢推送事件,并且客戶端也能夠在它們到來時讀取它們。你也可以將 JSON 或任何你想要的東西放在事件當(dāng)中,就比如 data: {'name': 'ahmed'}

線路協(xié)議真的很簡單(只需要設(shè)置 event: 和 data:,或者如果你愿意,可設(shè)置為 id: 和 retry:),所以你并不需要任何花里胡哨的服務(wù)器庫來實現(xiàn)服務(wù)器推送事件。

JavaScript 的代碼也超級簡單(僅使用 EventSource)

以下是用于流式服務(wù)器推送事件的瀏覽器 JavaScript 的代碼。(我從 服務(wù)器推送事件的 MND 頁面 得到的這個范例)

你可以訂閱所有事件,也可以為不同類型的事件使用不同的處理程序。這里我有一個只接受類型為 panda 的事件的處理程序(就像我們的服務(wù)器在上一節(jié)中推送的那樣)。

const evtSource = new EventSource("/sessions/15/stream", { withCredentials: true })
evtSource.addEventListener("panda", function(event) {
  console.log("status", event)
});

客戶端在中途不能推送更新

不同于 Websockets,服務(wù)器推送事件不允許大量的來回事件通訊。(這體現(xiàn)在它的字眼中 —— 服務(wù)器 推送所有事件)。初始的時候客戶端發(fā)出一個請求,然后服務(wù)器發(fā)出一連串響應(yīng)。

如果 HTTP 連接結(jié)束,它會自動重連

使用 EventSource 發(fā)出的 HTTP 請求和常規(guī) HTTP 請求有一個很大的區(qū)別,MDN 文檔中對此有所說明:

默認(rèn)情況下,如果客戶端和服務(wù)器之間的連接斷開,則連接會重啟。請使用 .close() 方法來終止連接。

很奇怪,一開始我真的被它嚇到了:我打開了一個連接,然后在服務(wù)器端將其關(guān)閉,然后兩秒過后客戶端向我的傳送終端發(fā)送了另一條請求!

我覺得這里可能是因為連接在完成之前意外斷開了,所以客戶端自動重新打開了它以防止類似情況再發(fā)生。

所以如果你不想讓客戶端繼續(xù)重試,你就得通過調(diào)用 .close() 直截了當(dāng)?shù)仃P(guān)閉連接。

這里還有些其它特性

你還能在服務(wù)器推送事件中設(shè)置 id: 和 retry: 字段。似乎,如果你在服務(wù)器推送事件上設(shè)置,那么當(dāng)重新連接時,客戶端將發(fā)送一個 Last-Event-ID 響應(yīng)頭,帶有它收到的最后一個 ID。酷!

我發(fā)現(xiàn) W3C 的服務(wù)器推送事件頁面 令人驚訝地容易理解。

在設(shè)置服務(wù)器推送事件的時候我遇到了兩個錯誤

我在 Rails 中使用服務(wù)器推送事件時遇到了幾個問題,我認(rèn)為這些問題挺有趣的。其中一個緣于 Nginx,另一個是由 Rails 引起的。

問題一:我不能在事件推送的過程中暫停

這個奇怪的錯誤是在我做以下操作時出現(xiàn)的:

def handler
    # SSE is Rails' built in server-sent events thing
    sse = SSE.new(response.stream, event: "status")
    sse.write('event')
    sleep 1
    sse.write('another event')
end

它會寫入第一個事件,但不能寫入第二個事件。我對此-非-常-困-惑,然后放開腦洞,試著理解 Ruby 中的 sleep 是如何運作的。但是 Cass 將我引領(lǐng)到一個與我有著相同困惑的 Stack Overflow 問答帖,而這里包含了讓我為之震驚的回答!

事實證明,問題出在我的 Rails 服務(wù)器位于 Nginx 之后,似乎 Nginx 默認(rèn)使用 HTTP/1.0 向上游服務(wù)器發(fā)起請求(為啥?都 2021 年了,還這么干?我相信這其中一定有合乎情理的解釋,也許是為了向下兼容之類的)。

所以客戶端(Nginx)會在服務(wù)器推送第一個事件之后直接關(guān)閉連接。我覺得如果在我推送第二個事件的過程中 沒有 暫停,它繼續(xù)正常工作,基本上就是服務(wù)器在連接關(guān)閉之前和客戶端在爭速度,爭著推送第二部分響應(yīng),如果我這邊推送速度足夠快,那么服務(wù)器就會贏得比賽。

我不確定為什么使用 HTTP/1.0 會使客戶端的連接關(guān)閉(可能是因為服務(wù)器在每個事件結(jié)尾寫入了兩個換行符?),但因為服務(wù)器推送事件是一個比較新的玩意兒,HTTP/1.0 (這種老舊協(xié)議)不支持它一點都會不意外。

設(shè)置 proxy_http_version 1.1 從而解決那個麻煩。好欸!

問題二:事件被緩沖

這個事情解決完,第二個麻煩接踵而至。不過這個問題實際上非常好解決,因為 Cass 已經(jīng)建議將 stackoverflow 里另一篇帖的回答 作為前一個問題的解決方案,雖然它并沒有是導(dǎo)致問題一出現(xiàn)的源頭,但它-確-實-解-釋-了問題二。

問題在這個示例代碼中:

def handler
    response.headers['Content-Type'] = 'text/event-stream'
    # Turn off buffering in nginx
    response.headers['X-Accel-Buffering'] = 'no'
    sse = SSE.new(response.stream, event: "status")
    10.times do
        sse.write('event')
        sleep 1
    end
end

我本來期望它每秒返回 1 個事件,持續(xù) 10 秒,但實際上它等了 10 秒才把 10 個事件一起返回。這不是我們想要的流式傳輸方式!

原來這是因為 Rack ETag 中間件想要計算 ETag(響應(yīng)的哈希值),為此它需要整個響應(yīng)為它服務(wù)。因此,我需要禁用 ETag 生成。

Stack Overflow 的回答建議完全禁用 Rack ETag 中間件,但我不想這樣做,于是我去看了 鏈接至 GitHub 上的議題

那個 GitHub 議題建議我可以針對僅流式傳輸終端應(yīng)用一個解決方法,即 Last-Modified 響應(yīng)頭,顯然,這么做可以繞過 ETag 中間件。

所以我設(shè)置為:

headers['Last-Modified'] = Time.now.httpdate

然后它起作用了!!!

我還通過設(shè)置響應(yīng)頭 X-Accel-Buffering: no 關(guān)閉了位于 Nginx 中的緩沖區(qū)。我并沒有百分百確定我要那樣做,但這么做似乎更安全。

Stack Overflow 很棒

起初,我全身心致力于從頭開始調(diào)試這兩個錯誤。Cass 為我指向了那兩個 Stack Overflow 帖子,一開始我對那些帖下提出的解決方案持懷疑態(tài)度(我想:“我沒有使用 HTTP/1.0 啊!ETag 響應(yīng)頭什么玩意,跟這一切有關(guān)系嗎??”)。

但結(jié)果證明,我確實無意中使用  HTTP/1.0,并且 Rack ETag 中間件確實給我?guī)砹藛栴}。

因此,也許這個故事告訴我,有時候計算機就是會以奇怪的方式相互作用,其它人在過去也遇到過計算機以完全相同的奇怪方式相互作用的問題,而 Stack Overflow 有時會提供關(guān)于為什么會發(fā)生這些情況的答案 : )

我認(rèn)為重要的是不要隨意從 Stack Overflow 中嘗試各種解決方案(當(dāng)然,在這種情況下不會有人建議這樣做!)。對于這兩個問題,我確實需要去仔細(xì)思考,了解發(fā)生了什么,還有為什么更改這些設(shè)置會起作用。

就是這樣!

今天我要繼續(xù)著手實現(xiàn)服務(wù)器推送事件,因為昨天一整天我都沉浸在上述這些錯誤里。好在我學(xué)到了一個以前從未聽說過的易學(xué)易用的網(wǎng)絡(luò)技術(shù),心里還是很高興的。

責(zé)任編輯:龐桂玉 來源: Linux中國
相關(guān)推薦

2020-03-09 08:24:06

TengineWeb代理服務(wù)器

2011-04-22 10:36:09

Server Push推送技術(shù)

2009-12-07 10:25:52

服務(wù)器安全服務(wù)器事件查看器

2012-02-16 11:35:34

ibmdw

2011-12-08 13:04:06

JavaNIO

2013-12-24 13:59:03

2009-12-07 10:19:16

2018-06-07 10:29:34

SDN服務(wù)器負(fù)載均衡

2024-04-07 09:41:18

SignalR實時通信開發(fā)

2021-03-18 09:31:56

微軟Exchange攻擊

2020-03-20 10:00:12

服務(wù)器網(wǎng)絡(luò)攻擊黑客

2022-09-14 12:01:35

服務(wù)器入侵篡改,

2016-09-08 22:54:14

2013-12-23 09:38:11

2025-03-26 00:00:00

Spring服務(wù)器推送技術(shù)

2013-04-26 11:42:00

2010-03-02 17:43:05

APC服務(wù)器機房

2009-10-27 16:24:22

APC服務(wù)器機房解決方

2010-09-13 10:53:09

2012-02-22 14:26:17

服務(wù)器云計算
點贊
收藏

51CTO技術(shù)棧公眾號

亚洲毛片网站| 二区三区精品| 国产视频在线观看一区二区三区| 91av视频在线播放| 久久亚洲AV成人无码国产野外 | 国产福利亚洲| 亚洲日本va在线观看| 亚洲影影院av| 中文字幕亚洲精品一区| 国产欧美日韩精品高清二区综合区| 色噜噜久久综合| 国产精品一区二区三区观看| 黄网在线观看视频| 红桃成人av在线播放| 欧美日韩高清一区二区| 日韩欧美一级在线| 色欲av永久无码精品无码蜜桃 | 黄色免费视频大全| www 日韩| 成人妖精视频yjsp地址| 日本aⅴ大伊香蕉精品视频| 亚洲欧美va天堂人熟伦| 成人噜噜噜噜| 日韩欧美在线网址 | 欧美黄色免费| 日韩av在线一区| 91亚洲免费视频| 99riav视频在线观看| 国产欧美一区二区精品性色| 99视频免费观看蜜桃视频| 国产在线观看黄色| 亚洲影视一区二区三区| 亚洲精品视频网上网址在线观看| 亚洲精品自拍网| 韩国精品一区| 亚洲乱码精品一二三四区日韩在线| 国产免费高清一区| 91久久久久国产一区二区| 在线综合亚洲| 欧美国产高跟鞋裸体秀xxxhd| 少妇大叫太粗太大爽一区二区| 亚洲影视资源| 欧洲精品中文字幕| 成熟丰满熟妇高潮xxxxx视频| 青青青青在线| 国产视频视频一区| 国产精品99久久久久久久| 在线中文字幕网站| 可以免费看不卡的av网站| 久久久久久久激情视频| 久久爱一区二区| 国产一区二区三区电影在线观看| 欧美一区二区久久久| 色哟哟精品视频| 日韩av影片| 亚洲国产一区二区三区| 国产又粗又硬又长| 伊人免费在线| 欧美极品aⅴ影院| 欧美精品尤物在线| 人人妻人人澡人人爽精品日本 | 亚洲精华一区二区三区| 日韩欧美综合一区| 中文字幕久久av| 国产黄色精品| 欧美少妇bbb| 亚洲视频免费一区| 小日子的在线观看免费第8集| 欧美天堂视频| 日韩欧美精品网站| 久色视频在线播放| 国产桃色电影在线播放| 国产精品久线观看视频| 午夜精品亚洲一区二区三区嫩草| 免费在线看v| 久久精品人人做| 欧美日韩一区二区三区免费| 午夜小视频免费| 99久久er热在这里只有精品66| 国产精品一区二区你懂得| 狠狠综合久久av一区二区| 国产麻豆成人传媒免费观看| 91精品在线国产| 97超碰人人草| 国产精品1024| 国产chinese精品一区二区| www.激情五月.com| 高清不卡一二三区| 国产伦视频一区二区三区| 日韩中文字幕综合| 97精品国产97久久久久久久久久久久| 96成人在线视频| 亚洲精品国产精品乱码不卡| 国产福利91精品一区二区三区| 99视频免费观看蜜桃视频| 国产18精品乱码免费看| 91麻豆产精品久久久久久| 欧美欧美一区二区| 在线观看黄av| 一区二区免费在线| 黑人糟蹋人妻hd中文字幕| 亚洲承认视频| 91精品国产91久久久久久一区二区 | 国偷自产视频一区二区久| 日韩av一区在线观看| 亚洲成人黄色av| 99久久综合| 欧美激情亚洲自拍| 一区二区三区在线观看av| 日韩黄色在线观看| 亚洲精品免费av| 人妻无码一区二区三区久久99 | 中文视频一区| 91成品人片a无限观看| 日韩综合在线观看| 国产精品亚洲人在线观看| 国产在线观看一区| 日韩三级影院| 亚洲国产一区在线观看| 韩国日本美国免费毛片| 日韩高清一区| 亚洲天堂成人在线| 九九视频免费在线观看| 久久精品电影| 国产在线观看精品一区二区三区| 黄色av网站免费在线观看| 久久精品一区蜜桃臀影院| 久久大片网站| 国产精品久久久久久福利| 亚洲福利视频导航| mm131亚洲精品| 欧美黄色网视频| 久久影视电视剧免费网站| 亚洲黄色免费观看| 高清国产一区二区三区| 亚洲综合网中心| 亚洲啊v在线| 欧美一级在线观看| 国产99在线 | 亚洲| 最新日韩在线| 亚洲最大的av网站| 日韩黄色影院| 91久久一区二区| 国产精品一区二区人妻喷水| 99国产精品一区二区| 欧美精品国产精品日韩精品| 国产成人免费看| 丁香婷婷综合五月| 秋霞在线一区二区| 国产极品久久久久久久久波多结野| 亚洲第一区在线| 69av视频在线| 黄一区二区三区| 色999五月色| 免费电影日韩网站| 亚洲精品国产福利| 精品无码黑人又粗又大又长| 精品系列免费在线观看| 亚洲日本精品一区| 精品网站在线| 亚洲国产另类 国产精品国产免费| 日韩在线中文字幕视频| 精品一区二区三区免费观看| 日韩久久久久久久| 香蕉成人影院| 最近2019年好看中文字幕视频| 日本中文字幕在线| 91浏览器在线视频| 看av免费毛片手机播放| 欧美自拍视频| 欧美性在线视频| 性xxxxbbbb| 红桃视频成人在线观看| 久久福利小视频| 最新国产乱人伦偷精品免费网站| 亚洲影院色无极综合| 影音先锋中文在线视频| 日韩欧美视频一区| 国产精品a成v人在线播放| av不卡免费电影| 日韩欧美在线播放视频| 怕怕欧美视频免费大全| 国产精品777| 最新国产在线观看| 欧美丰满美乳xxx高潮www| 欧美性生交大片| 国产麻豆精品theporn| 国产精品va在线观看无码| 国产精品对白久久久久粗| 97香蕉久久超级碰碰高清版| 空姐吹箫视频大全| 欧美视频在线视频| 五月天婷婷丁香网| 国产成人在线观看免费网站| 老子影院午夜伦不卡大全| 久久综合五月婷婷| 国产精品第一视频| 国产乱色在线观看| 亚洲国产精品久久久久久| 国产美女激情视频| 国产精品乱码一区二三区小蝌蚪| 欧美又黄又嫩大片a级| 亚洲高清电影| 日韩精品另类天天更新| 国产日韩在线观看视频 | 国产美女福利在线| 亚洲国产欧美一区| а中文在线天堂| 亚洲人午夜精品天堂一二香蕉| 日韩一区av| 亚洲成在人线在线播放| 一区二区不卡免费视频| 蜜臀a∨国产成人精品| 欧美a级黄色大片| 三级中文字幕在线观看| 成人自拍视频| 亚洲女在线观看| 精品人妻一区二区三区日产乱码| 亚洲电影一区二区| 亚洲 欧美 国产 另类| 成人黄色免费网站| 精品一区二区三区三区| 中文字幕在线观看你懂的| 一色屋精品亚洲香蕉网站| 不卡的一区二区| 在线日韩欧美| 亚洲图片小说在线| 福利片在线一区二区| 91av在线免费观看| 成人全视频高清免费观看| 欧美在线你懂的| 九九热国产精品视频| 中文字幕国产一区| 自拍视频一区二区| 国产在线国偷精品产拍免费yy| 各处沟厕大尺度偷拍女厕嘘嘘| 久久久久亚洲| 日韩欧美一区二区三区四区| 7m精品国产导航在线| 国产日韩欧美综合| 我爱我色成人网| 97色在线播放视频| 永久免费网站在线| 一区二区三区亚洲| 搡老岳熟女国产熟妇| 欧美一区二区啪啪| 欧美一级黄视频| 日韩欧美国产黄色| 日本三级中文字幕| 亚洲美女视频在线观看| 国产破处视频在线观看| 26uuu久久天堂性欧美| 亚洲香蕉中文网| 国产成都精品91一区二区三| 午夜剧场高清版免费观看| 日韩国产一区二| 国产91对白刺激露脸在线观看| 午夜精品久久久久99热蜜桃导演 | 亚洲三级毛片| 日韩成人手机在线| 欧美日韩岛国| 伊人网在线免费| 911精品美国片911久久久| 亚洲欧洲精品在线| 日韩免费高清| 亚洲成人自拍视频| 欧美色图国产精品| 日韩免费一区二区三区| 免费看成人哺乳视频网站| 国产精品一区二区三区观看 | 欧美精品亚洲二区| 亚洲天堂手机在线| 精品视频一区三区九区| 激情视频网站在线观看| 亚洲一区二区三区四区在线| 精品国产视频一区二区三区 | av最新在线观看| 欧美国产精品v| 精品丰满少妇一区二区三区| 国产精品高潮久久久久无| 黄色录像免费观看| 一区二区三区自拍| 久久久久久久9999| 福利视频导航一区| 91视频免费版污| 日韩vs国产vs欧美| 亚洲18在线看污www麻豆| 精品一区二区精品| 亚洲高清无码久久| 国产欧美日韩精品a在线观看| 永久免费观看片现看| 综合精品久久久| 午夜精品一区二区三级视频| 一区在线播放视频| 久久久久成人网站| 在线国产电影不卡| 国产女主播福利| 亚洲精品久久久一区二区三区 | 日本一级免费视频| 亚洲欧洲韩国日本视频| 国产精品久久国产精麻豆96堂| 欧美国产一区二区在线观看| 五月天免费网站| 亚洲成人自拍一区| 欧美成人精品网站| 欧美一级日韩不卡播放免费| 五月婷婷久久久| 日韩中文综合网| xxx在线免费观看| 国产成人激情视频| 亚洲国产欧美国产第一区| 精品一区二区三区免费毛片| 成人毛片在线| 污污污污污污www网站免费| 狠狠入ady亚洲精品| 欧美丰满熟妇xxxxx| 韩国理伦片一区二区三区在线播放| 精品1卡二卡三卡四卡老狼| 久久久久久影视| 久久久无码精品亚洲国产| 欧美在线小视频| 日本黄色免费视频| 国产一区二区三区直播精品电影| 97超碰人人在线| 欧美专区在线观看| 亚洲免费一区三区| 亚州欧美一区三区三区在线| 综合久久亚洲| 国产高潮免费视频| 99在线热播精品免费| 一级特黄曰皮片视频| 亚洲va欧美va天堂v国产综合| 在线观看国产小视频| 精品在线欧美视频| 蜜臀av在线播放| 成人做爽爽免费视频| 九九综合在线| 青青青青草视频| 国产伦精一区二区三区| 日韩毛片无码永久免费看| 一区二区三区免费网站| 国产女优在线播放| 亚洲日韩中文字幕| 密臀av在线播放| 国产成人看片| 在线中文字幕亚洲| 日本超碰在线观看| 国产欧美日韩综合精品一区二区| 国内偷拍精品视频| 在线日韩av片| 国产中文在线视频| 欧美最猛性xxxx| 日韩电影不卡一区| 国产欧美日韩网站| 成人动漫在线一区| 国产真人真事毛片| 日韩精品专区在线影院观看| 国产在线一区二区视频| 国产成人精品久久亚洲高清不卡| 开心激情综合| 韩国日本在线视频| 久久久亚洲精品石原莉奈 | 日韩精品一级二级| 免费观看特级毛片| 欧美一区二区三区系列电影| 丝袜在线观看| 久久香蕉综合色| 免费成人你懂的| 极品盗摄国产盗摄合集| 亚洲国产高潮在线观看| 都市激情亚洲综合| 中国成人在线视频| 国产91精品入口| 亚洲免费黄色网址| 日韩三级成人av网| 国产精品tv| 91n.com在线观看| 一区二区三区在线观看欧美| 午夜激情小视频| 国产主播欧美精品| 黄色亚洲免费| 亚洲性猛交xxxx乱大交| 欧美放荡的少妇| 碰碰在线视频| 香蕉精品视频在线| 99精品欧美一区二区蜜桃免费 | 日韩高清国产精品| 国产麻豆午夜三级精品| 91美女免费看| 久久精品成人动漫| 欧洲亚洲视频| 一起操在线视频| 欧美色视频日本高清在线观看| 天堂аⅴ在线地址8| 国产成人精品一区二区三区福利| 日韩vs国产vs欧美| 国产黄色片视频| 日韩中文在线观看| 日韩欧美影院| 古装做爰无遮挡三级聊斋艳谭|