अपाचे के प्रॉक्सी अनुरोध को एक नोड.जेएस ऐप से कनेक्ट करने के लिए आगे की देरी


12

मेरे Ubuntu सर्वर 10.04 में मैं एक उदाहरण node.js ऐप चला रहा हूं:

var http = require("http");

function onRequest(request, response) {

        console.log("Request received.");
        response.writeHead(200, {"Content-Type": "text/html"});
        response.write("Hello World");
        response.end();

}

http.createServer(onRequest).listen(3000);

यह केवल पोर्ट 3000 पर अनुरोधों को सुनता है, इस अनुरोध को सांत्वना में लॉग इन करें और क्लाइंट को एक HTTP "हैलो वर्ल्ड" भेजें।

लक्ष्य यह एप Apache2 के साथ सह-अस्तित्व बनाने का था। इसलिए कुछ शोध के बाद मैंने डिफ़ॉल्ट फ़ाइल ( / etc / apache2 / sites-available / default ) को इस तरह संपादित किया :

<VirtualHost *:80>
        ServerAdmin haj@myserver.com
        ServerName dev.myserver.com

        <Location /node>

                ProxyPassReverse http://127.0.0.1:3000/
                ProxyPass http://127.0.0.1:3000/

        </Location>

        <Proxy>
                Allow from all
        </Proxy>

        DocumentRoot /home/haj/www/http_home

        <Directory />
                Options FollowSymLinks
                AllowOverride None
        </Directory>

        <Directory /home/haj/www/http_home/>
                Options Indexes FollowSymLinks MultiViews
                AllowOverride None
                Order allow,deny
                allow from all
        </Directory>

        ErrorLog /home/haj/www/log/error.log

        # Possible values include: debug, info, notice, warn, error, crit,
        # alert, emerg.
        LogLevel warn

        CustomLog /home/haj/www/log/access.log combined


</VirtualHost>

इसलिए, जब कोई उपयोगकर्ता कॉल करता है http://dev.myserver.com/nodeया करता है http://dev.myserver.com/node/, तो Apache अनुरोध को प्रॉक्सी करता है, Node.js प्रोसेसिंग करता है, और उपयोगकर्ता को "हैलो वर्ल्ड" वापस मिलता है।

बस एक समस्या है: इसमें कुछ समय लगता है, इसे 'प्रॉक्सी' लोड करना कहते हैं, दूसरे शब्दों में, मुझे ये संदेश ब्राउज़र पर मिलते हैं:

<503 Service Temporarily Unavailable>

Service Temporarily Unavailable

The server is temporarily unable to service your request due to maintenance downtime or capacity problems. Please try again later.

Apache/2.2.14 (Ubuntu) Server at dev.neosource.cl Port 80

इसके अलावा, error.log मुझे बताता है:

[Thu Apr 21 01:02:10 2011] [error] proxy: HTTP: disabled connection for (127.0.0.1)
[Thu Apr 21 01:02:10 2011] [error] proxy: HTTP: disabled connection for (127.0.0.1)
[Thu Apr 21 01:02:10 2011] [error] proxy: HTTP: disabled connection for (127.0.0.1)

फिर अचानक, यह काम करता है, बस ऐसे ही। कोई अनुरोध नहीं, कोई समय नहीं, कोई पैटर्न नहीं।

आम आदमी की शर्तों में, सेवा को 'लोड' करना पड़ता है, यही वह धारणा है जो इसे देती है, लेकिन, मैं जानना चाहूंगा कि क्या इस देरी को कम करने का कोई तरीका है। या मुझे नहीं पता होगा कि ऊपर उल्लिखित विन्यास में क्या गलत है।

संपादित करें 1 : LogLevel को डीबग करने के बाद, इनमें से एक देरी के दौरान मुझे यह प्रति अनुरोध प्राप्त होता है:

[Thu Apr 21 02:30:40 2011] [debug] mod_proxy_http.c(56): proxy: HTTP: canonicalising URL //127.0.0.1:3000/
[Thu Apr 21 02:30:40 2011] [debug] proxy_util.c(1494): [client 200.xxx.yyy.zzz] proxy: http: found worker http://127.0.0.1:3000/ for http://127.0.0.1:3000/
[Thu Apr 21 02:30:40 2011] [debug] mod_proxy.c(993): Running scheme http handler (attempt 0)
[Thu Apr 21 02:30:40 2011] [debug] mod_proxy_http.c(1940): proxy: HTTP: serving URL http://127.0.0.1:3000/
[Thu Apr 21 02:30:40 2011] [debug] proxy_util.c(1937): proxy: HTTP: retrying the worker for (127.0.0.1)
[Thu Apr 21 02:30:40 2011] [error] proxy: HTTP: disabled connection for (127.0.0.1)
[Thu Apr 21 02:30:40 2011] [debug] mod_deflate.c(615): [client 200.xxx.yyy.zzz] Zlib: Compressed 405 to 273 : URL /node

... और जब यह फिर से सही है:

[Thu Apr 21 02:35:16 2011] [debug] mod_proxy_http.c(56): proxy: HTTP: canonicalising URL //127.0.0.1:3000/
[Thu Apr 21 02:35:16 2011] [debug] proxy_util.c(1494): [client 200.xxx.yyy.zzz] proxy: http: found worker http://127.0.0.1:3000/ for http://127.0.0.1:3000/
[Thu Apr 21 02:35:16 2011] [debug] mod_proxy.c(993): Running scheme http handler (attempt 0)
[Thu Apr 21 02:35:16 2011] [debug] mod_proxy_http.c(1940): proxy: HTTP: serving URL http://127.0.0.1:3000/
[Thu Apr 21 02:35:16 2011] [debug] proxy_util.c(1999): proxy: HTTP: has acquired connection for (127.0.0.1)
[Thu Apr 21 02:35:16 2011] [debug] proxy_util.c(2055): proxy: connecting http://127.0.0.1:3000/ to 127.0.0.1:3000
[Thu Apr 21 02:35:16 2011] [debug] proxy_util.c(2153): proxy: connected / to 127.0.0.1:3000
[Thu Apr 21 02:35:16 2011] [debug] proxy_util.c(2244): proxy: HTTP: backend socket is disconnected.
[Thu Apr 21 02:35:16 2011] [debug] proxy_util.c(2308): proxy: HTTP: fam 2 socket created to connect to 127.0.0.1
[Thu Apr 21 02:35:16 2011] [debug] proxy_util.c(2414): proxy: HTTP: connection complete to 127.0.0.1:3000 (127.0.0.1)
[Thu Apr 21 02:35:16 2011] [debug] mod_proxy_http.c(1723): proxy: start body send
[Thu Apr 21 02:35:16 2011] [debug] mod_deflate.c(615): [client 200.xxx.yyy.zzz] Zlib: Compressed 11 to 13 : URL /node
[Thu Apr 21 02:35:16 2011] [debug] mod_proxy_http.c(1816): proxy: end body send
[Thu Apr 21 02:35:16 2011] [debug] proxy_util.c(2017): proxy: HTTP: has released connection for (127.0.0.1)

मध्यस्थों के लिए: मुझे यकीन नहीं है कि यह स्टैकओवरफ़्लो प्रश्न या सर्वरफ़ॉल्ट प्रश्न है, इसलिए मैंने दोनों साइट पोस्ट की हैं।
हरमन

1
क्रॉस पोस्टिंग एक बुरा विचार है जब तक कि आपको जवाब नहीं मिलता है, तो उनके बीच लिंक को भी पार करना सुनिश्चित करें! यदि आप गलत जगह पर पोस्ट करते हैं तो मॉडरेटर इसे सही स्थान पर माइग्रेट करने में मदद करेंगे, लेकिन कृपया शुरू से ही हमारे प्रयासों की नकल न करें!
कालेब

क्षमा करें @ कालेब, शुरुआत की गलती। फिर से नहीं होगा।
हरमन

कोई चिंता नहीं, यह एक सीख है क्योंकि आप जगह पर जाते हैं।
कालेब

जवाबों:


10

बदलने के LogLevelलिए debugआपको error.log में अधिक जानकारी दी जाएगी। कृपया ऐसा करें और परिणाम पोस्ट करें। उस जानकारी के बिना, मेरा अनुमान है कि आपकी प्रॉक्सी लाइन बदलने से ProxyPass http://127.0.0.1:3000/ retry=0मदद मिल सकती है। सामान्य तौर पर, अपाचे mod_proxy प्रलेखन में आपके लिए उपलब्ध मापदंडों पर अधिक विवरण होता है।


धन्यवाद @justarobert, अब मैं एक "उलटा मर्फी" अनुभव कर रहा हूं, क्योंकि मैं त्रुटि को दोहराने की कोशिश कर रहा हूं, और सब कुछ ठीक हो जाता है! मैंने शर्त लगाई कि उत्पादन में फिर से मेरी यही स्थिति होगी ... जैसे ही मेरे पास डेटा होगा, मैं इसे यहां भरने जा रहा हूं। एक बार फिर धन्यवाद।
हरमन

वह आकड़ें! सुनिश्चित करें कि LogLevel debugउत्पादन में उपयोग न करें ।
justarobert

जबरदस्त हंसी। मैंने अभी अपना प्रश्न संपादित किया है।
हरमन

1
अपाचे लॉग इंगित करता है कि आपकी नोड.जेएस प्रक्रिया देरी के दौरान अनुमानित अनुरोधों का जवाब नहीं दे रही है। क्या आपको उस समय अपने नोड.जेएस लॉग से कुछ भी मिलता है? क्या आप अपने ब्राउज़र में सीधे नोड.जेएस सर्वर पर जा सकते हैं जब अपाचे आपको देरी दे रहा है? उपयोग करने पर विचार करें ProxyPass http://127.0.0.1:3000/ retry=0 timeout=10, बस टाइमआउट को स्पष्ट करने के लिए। इसके अलावा, पर चर्चा को देखें news.ycombinator.com/item?id=2037328 तुम क्यों node.js. के सामने अपाचे डाल करने के लिए नहीं चाहते हो सकता है के लिए
justarobert

2

इसे खोदना। मैं इस मुद्दे पर SELOS सक्षम के साथ CentOS पर था। Httpd को नेटवर्क कनेक्शन बनाने की अनुमति देने के लिए मुझे बस इतना करना चाहिए:

/usr/sbin/setsebool httpd_can_network_connect 1

(और httpd को पुनरारंभ करें)

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.