【发布时间】:2013-04-22 16:17:57
【问题描述】:
服务器,位于德国
Windows Server 2008 / IIS 7
node.js 0.8.22
iisnode 0.2.2 x64
web.config
<configuration>
<system.webServer>
<handlers>
<add name="iisnode" path="server.js" verb="*" modules="iisnode" />
</handlers>
<rewrite>
<rules>
<rule name="DynamicContent">
<conditions>
<add input="{REQUEST_FILENAME}" matchType="IsFile" negate="True"/>
</conditions>
<action type="Rewrite" url="server.js"/>
</rule>
</rules>
</rewrite>
<iisnode watchedFiles="*.js;lib\*;node_modules\*;styles\*;ui\*;views\*" />
</system.webServer>
</configuration>
server.js
var port = process.env.NODE_ENV == 'production' ? process.env.PORT : 3000;
require('./lib/server').listen(port);
问题:
有时我得到 200 响应,但有时是 404(找不到文件或目录)。
如果我确实从俄罗斯、德国或美国提出请求,则响应为 200。
如果我确实从中国请求,有时响应是 404(取决于 ISP、时间,也许还有其他)。
404 响应看起来 iis 找不到 server.js
200 响应示例(使用 express Vpn,连接到美国):
2013-04-29 02:42:58 W3SVC1 LOFT4002 188.138.16.31 GET /zazaza - 80 - 180.150.157.51 HTTP/1.1 Mozilla/5.0+(Windows+NT+6.2;+WOW64)+AppleWebKit/537.31+(KHTML,+like+Gecko)+Chrome/26.0.1410.64+Safari/537.31 connect.sid=s%3ABHin0EtiPcJbD6GCeXE2hb_1.mNHhYwIs%2BvLKcJcXc1igMH4O%2FIkuwQdygd1XjN7ediM - test.amelisa.ru 200 0 0 367 530 514
404错误示例(无vpn,来自中国的请求):
2013-04-29 02:32:47 W3SVC1 LOFT4002 188.138.16.31 GET /zazaza - 80 - 112.90.90.18 HTTP/1.1 Mozilla/5.0+(Windows+NT+6.2;+WOW64)+AppleWebKit/537.31+(KHTML,+like+Gecko)+Chrome/26.0.1410.64+Safari/537.31 connect.sid=s%3AdL_RALh0qLd0eLoCxZUk6Po-.N9h97BMFy9%2Fm9tl8lrQd%2FIHQjwpwzEXfWC7f4%2FrHxpY - test.amelisa.ru 404 0 0 1390 532 436
iisnode 没有日志,也没有跟踪 404 请求,所以我认为它甚至没有为它们启动。
此服务器上的所有 iisnode/node.js 站点都存在同样的问题。
但是这台服务器上的Asp Net Mvc网站无论如何都会返回200,所以可能不是中文金盾问题。
我可以提供任何信息。
任何帮助将不胜感激。
【问题讨论】:
-
您找到解决方案了吗?它发生在我身上,我试图重新启动 de IIS 什么都没有。我也没有尝试创建其他网站
-
嘿!我在您的代码中发现了问题。当没有为请求类型配置路由时会发生此错误。要进行测试,请创建一个类似“/test”的路由,并使用此 URL test.amelisa.ru/test 调用相同的 URL。创建路由只是: app.post('/test', function(req, res){ res.json(true); });