लंबे समय तक चलने वाला कनेक्शन
सर्वर-सेंटेड इवेंट्स (SSE) एक लंबे समय तक चलने वाला HTTP कनेक्शन ** है, इसलिए शुरुआत के लिए हमें इसकी आवश्यकता है:
proxy_http_version 1.1;
proxy_set_header Connection "";
नोट: HTTP / 1.1 में टीसीपी कनेक्शन डिफ़ॉल्ट रूप से लगातार हैं, इसलिए कनेक्शन हेडर को खाली करने के लिए सही काम करता है और यह निग्नेक्स सुझाव है।
चंवर ट्रांसफर-एन्कोडिंग
अब एक तरफ; SSE प्रतिक्रियाओं ने एक सामग्री-लंबाई शीर्षलेख सेट नहीं किया है क्योंकि वे नहीं जान सकते हैं कि कितना डेटा भेजा जाएगा, इसके बजाय उन्हें स्थानांतरण-एन्कोडिंग हेडर [0] [1] का उपयोग करने की आवश्यकता है, जो स्ट्रीमिंग कनेक्शन के लिए अनुमति देता है। यह भी नोट करें: यदि आप एक कंटेंट-लेंथ नहीं जोड़ते हैं तो अधिकांश HTTP सर्वर Transfer-Encoding: chunked;
आपके लिए सेट हो जाएंगे । अजीब बात है, HTTP chunking के खिलाफ चेतावनी दी और भ्रम का कारण बनता है।
W3 EventSource विवरण के नोट्स अनुभाग में कुछ अस्पष्ट चेतावनी से भ्रम पैदा होता है:
लेखकों को यह भी चेतावनी दी जाती है कि HTTP चूनिंग से इस प्रोटोकॉल की विश्वसनीयता पर अप्रत्याशित नकारात्मक प्रभाव पड़ सकता है। जहां तक संभव हो, जब तक संदेशों की दर इतनी अधिक न हो, तब तक घटना की धाराओं के लिए चूनिंग को अक्षम किया जाना चाहिए।
जिससे विश्वास हो सके कि Transfer-Encoding: chunked;
SSE के लिए एक बुरी बात है। हालाँकि: यह जरूरी नहीं है, यह केवल एक समस्या है, जब आपका वेबसर्वर आपके लिए चैंकिंग कर रहा है (आपके डेटा के बारे में जानकारी नहीं)। इसलिए, जबकि अधिकांश पोस्ट यह सुझाव देंगे कि chunked_transfer_encoding off;
यह विशिष्ट मामले में आवश्यक नहीं है [3]।
बफरिंग (वास्तविक समस्या)
जहाँ सबसे अधिक समस्याएँ आती हैं, उनमें ऐप सर्वर और क्लाइंट के बीच किसी भी प्रकार की बफरिंग होती है। डिफ़ॉल्ट रूप से [४], निग्नेक्स का उपयोग करता है
proxy_buffering on
( अपने आवेदन पर uwsgi_buffering
और fastcgi_buffering
उसके आधार पर भी एक नज़र डालें ) और उन चुनिन्दाओं को बफर करने का विकल्प चुन सकता है जिन्हें आप अपने ग्राहक से बाहर निकालना चाहते हैं। यह एक बुरी बात है क्योंकि SSE का रियल टाइम नेचर टूट जाता है।
हालांकि, proxy_buffering off
सब कुछ के लिए मुड़ने के बजाय , यह वास्तव में सबसे अच्छा है (यदि आप कर रहे हैं) तो X-Accel-Buffering: no
अपने आवेदन सर्वर कोड में एक प्रतिक्रिया हैडर के रूप में जोड़ने के लिए केवल एसएसई आधारित प्रतिक्रिया के लिए बफरिंग बंद करें और आपके ऐप से आने वाली सभी प्रतिक्रियाओं के लिए नहीं। सर्वर। बोनस: यह भी के लिए काम करेंगे uwsgi
और fastcgi
।
समाधान
और इसलिए वास्तव में महत्वपूर्ण सेटिंग्स वास्तव में ऐप-सर्वर प्रतिक्रिया हेडर हैं:
Content-Type: text/event-stream;
Cache-Control: no-cache;
X-Accel-Buffering: no;
और संभावित रूप से कुछ पिंग तंत्र के कार्यान्वयन ताकि कनेक्शन बहुत लंबे समय तक निष्क्रिय न रहे। इस का खतरा यह है कि keepalive
सेटिंग का उपयोग करके Nginx निष्क्रिय कनेक्शन को बंद कर देगा ।
[०] https://tools.ietf.org/html/rfc2616#section-3.6
[१] https://en.wikipedia.org/wiki/Chunked_transfer_encoding
[२] https://www.w3.org/TR / 2009 / WD-eventource-20091029 / # टेक्स्ट-इवेंट-स्ट्रीम
[3] https://github.com/whatwg/html/issues/515
[4] http://nginx.org/en/docs/http/ ngx_http_proxy_module.html #xy_buffering
[5] https://tools.ietf.org/html/rfc7230#section-6.3
[6] https://gist.github.com/ChCDragonkai/6bfade6431e9ffb7fe88