আমার উবুন্টু সার্ভার 10.04 এ আমি একটি উদাহরণ নোড.জেএস অ্যাপ চালাচ্ছি:
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 "হ্যালো ওয়ার্ল্ড" প্রেরণ করুন
লক্ষ্য ছিল এই অ্যাপটিকে অ্যাপাচি 2 এর সাথে সহাবস্থান করা। সুতরাং কিছু গবেষণার পরে আমি এইভাবে ডিফল্ট ফাইল ( / ইত্যাদি / অ্যাপাচি 2 / সাইটগুলি উপলব্ধ / ডিফল্ট ) সম্পাদনা করেছি:
<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/
, আপাচি অনুরোধটির প্রক্স করে, নোড.জেএস প্রসেসিং করে এবং ব্যবহারকারী একটি "হ্যালো ওয়ার্ল্ড" ফিরে পায়।
একটি মাত্র সমস্যা রয়েছে: এতে কিছুটা সময় লাগে, আসুন একে 'লোড' প্রক্সি বলুন, অন্য কথায়, আমি এই বার্তাগুলি ব্রাউজারে পাই:
<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
তবুও, ত্রুটি.লগ আমাকে বলে:
[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 : লগলভিলকে ডিবাগ-এ সংশোধন করার পরে, এই বিলম্বগুলির মধ্যে একটির সময় আমি অনুরোধ অনুযায়ী এটি পেয়েছি:
[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)