我现在会收到此错误,然后当我点击此地址时:
http://apps.facebook.com/pazooza
iisnode encountered an error when processing the request.
HRESULT: 0x2
HTTP status: 500
HTTP reason: Internal Server Error
You are receiving this HTTP 200 response because system.webServer/iisnode/@devErrorsEnabled configuration setting is 'true'.
In addition to the log of stdout and stderr of the node.exe process, consider using debugging and ETW traces to further diagnose the problem.
You may get additional information about this error condition by logging stdout and stderr of the node.exe process.To enable logging, set the system.webServer/iisnode/@loggingEnabled configuration setting to 'true' (current value is 'false').
但是当我点击刷新时,网站正确加载,一切正常。只有当我离开网站几个小时后才会回来,或许我会再次看到这个错误,或者也许不会。这很烦人,因为导航到我网站的用户认为它已经坏了而且不想点击刷新!
所以我的问题是,之前是否有其他人遇到过这种类型的问题,你已经检查了你的代码,并且网站加载的一切似乎都正确,但是不时的Node或IIS-Node都会发现这个错误。
我的设置如下:
服务器:Windows Azure /网站(共享,2个实例) 语言:Node.js 工具:Webmatrix(我使用模板项目Starter Site)
最烦人的事情是我打开了错误消息的记录等,并且日志记录系统没有收到此错误,当我去检查我的日志时,如果发生此错误则没有创建错误日志,所以我还没有找到一种捕捉它的方法。有人有任何建议吗?
这是我的server.js文件的样子:
var express = require('express')
, connect = require('connect')
, config = require('./utils/config')
, observer = require('./utils/observer')
, cronJob = require('cron').CronJob
, azure = require('azure')
, uuid = require('node-uuid')
, db = require("./utils/database")
, async = require('async')
, serialNumbers = require("./utils/serialNumbers");
var app = module.exports = express.createServer();
// Create a cron job to listen for servicebus queue messages
var jobProcessServices = new cronJob({
cronTime: '*/1 * * * * *',
onTick: function () {
observer.processQueue(function () { });
},
start: false
});
app.configure(function() {
app.set('views', __dirname + '/views');
app.set('view engine', 'ejs');
app.set('view options', {
layout: false
});
app.use(express.favicon());
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(connect.static(__dirname + '/public'));
app.use(require('./middleware/siteTotals'));
app.use(require('./middleware/authenticate'));
app.use(express.cookieParser());
app.use(express.session({ secret: 'ljklkdsflkfdj4848384' }));
app.use(app.router);
// start listening for queue messages
jobProcessServices.start();
console.log('starting job service\n\n');
// create table stores
var ts1 = azure.createTableService(config.storageAccount, config.storageAccessKey, config.tableHost);
ts1.createTableIfNotExists('channels', function(error) {
ts1.createTableIfNotExists('users', function(error) {
ts1.createTableIfNotExists('snusers', function(error) {
ts1.createTableIfNotExists('snchannels', function(error) {
var query = azure.TableQuery
.select()
.from('snchannels');
ts1.queryEntities(query, function(error, result) {
if(error === null && result.length == 0) {
// must be site initialization, generate serial numbers for channels and users
serialNumbers.generateNewNumbers('snchannels', config.maxNumber, config.usageRates[2], function() {
serialNumbers.generateNewNumbers('snusers', config.maxNumber, config.usageRates[2], function() {
initializeDefaultQueues(function() {
// Create default storage container
var bc1 = azure.createBlobService(config.storageAccount, config.storageAccessKey, config.blobHost);
bc1.createContainerIfNotExists(config.container, function () { });
});
});
});
}
else initializeDefaultQueues(function() { });
});
});
});
});
});
ts1.createTableIfNotExists('sitetotals', function(error) {
if(error === null) {
var query = azure.TableQuery
.select()
.from('sitetotals');
ts1.queryEntities(query, function(error, siteTotals) {
if(error === null && siteTotals.length == 0) {
// must be site initialization create defaults
ts1.insertEntity('sitetotals', { PartitionKey: 'users', RowKey: uuid(), Total: '0', Deleted: '0' }, function(error) {
ts1.insertEntity('sitetotals', { PartitionKey: 'channels', RowKey: uuid(), Total: '0', Deleted: '0' }, function(error){ });
});
}
});
}
});
});
/**
* ERROR MANAGEMENT
* -------------------------------------------------------------------------------------------------
* error management - instead of using standard express / connect error management, we are going
* to show a custom 404 / 500 error using jade and the middleware errorHandler (see ./middleware/errorHandler.js)
**/
var errorOptions = { dumpExceptions: true, showStack: true }
app.configure('development', function() { });
app.configure('production', function() {
errorOptions = {};
});
app.use(require('./middleware/errorHandler')(errorOptions));
// static vars
app.helpers({ config: {
fbAppNamespace: config.fbAppNamespace,
siteUrl: config.siteUrl,
canvasUrl: config.canvasUrl,
appID: config.appID,
commentPageSize: config.commentPageSize,
videoPageSize: config.videoPageSize,
channelPageSize: config.channelPageSize,
userFollowPageSize: config.userFollowPageSize,
followPageSize: config.followPageSize,
friendPageSize: config.friendPageSize,
pazoozaFbUrl: config.pazoozaFbUrl,
pazoozaTwitterUrl: config.pazoozaTwitterUrl,
anonymousUser: config.anonymousUser,
usageRates: config.usageRates,
categorys: config.categorys,
channelTypes: config.channelTypes,
ratings: config.ratings
},
serverYear: new Date().getFullYear()
});
// all views have access to these variables
// note: can't do http calls with these functions
app.dynamicHelpers({
session: function (req, res) {
return req.session;
},
signed_request: function (req, res) {
return req.param('signed_request');
}
});
/**
* ROUTING
* -------------------------------------------------------------------------------------------------
* include a route file for each major area of functionality in the site
**/
require('./routes/home')(app);
require('./routes/channel')(app);
require('./routes/user')(app);
require('./routes/search')(app);
require('./routes/utils')(app);
require('./routes/facebook')(app);
require('./routes/testing')(app);
// Global Routes - this should be last!
require('./routes/global')(app);
app.listen(process.env.PORT || 3000);
console.log("Express server in %s mode", app.settings.env);
// helper functions
function initializeDefaultQueues(callback){
// create default service bus message queues
var qs1 = azure.createQueueService(config.storageAccount, config.storageAccessKey, config.queueHost);
qs1.createQueueIfNotExists('serialnumbers', function(error){
callback();
});
}
有一些中间件模块,例如siteTotals和authenticate,用于管理安装应用程序的Facebook用户,并确保他们的FB信息始终可供应用程序使用。
我不知道是否需要安装最新版本的IISNode?如何确定IISNode的版本以及是否需要更新?
此外,我应该指出,无论您使用哪种Windows Azure网站模式,都会发生此错误:免费,分享或保留。
这是我的web.config文件:
<iisnode
node_env="%node_env%"
nodeProcessCommandLine=""%programfiles%\nodejs\node.exe""
nodeProcessCountPerApplication="1"
maxConcurrentRequestsPerProcess="1024"
maxNamedPipeConnectionRetry="3"
namedPipeConnectionRetryDelay="2000"
maxNamedPipeConnectionPoolSize="512"
maxNamedPipePooledConnectionAge="30000"
asyncCompletionThreadCount="0"
initialRequestBufferSize="4096"
maxRequestBufferSize="65536"
watchedFiles="*.js;node_modules\*;routes\*.js;views\*.jade;middleware\*.js;iisnode.yml"
uncFileChangesPollingInterval="5000"
gracefulShutdownTimeout="60000"
loggingEnabled="true"
debuggingEnabled="false"
debuggerPortRange="5058-6058"
debuggerPathSegment="debug"
maxLogFileSizeInKB="128"
devErrorsEnabled="true"
flushResponse="false"
enableXFF="false"
promoteServerVars=""
/>
这是使用我用来启动整个项目的Webmatrix模板时创建的标准文件。
答案 0 :(得分:0)
我们的Node站点有一个类似的问题,它使用了mongolab后端作为它的数据库。我们最终在连接字符串中添加了一个keep alive标志(并将其设置为on)以解决问题。我认为这个问题是由于azure的负载平衡问题,但我从来没有花时间弄清楚我们搬到亚马逊的时候。希望能帮到你。
答案 1 :(得分:0)
您能否提供有关申请的更多详情?如果没有更多信息,很难确定确切的问题,尤其是关于应用程序连接的资源。
问题可能是由于一段时间不活动后应用程序刷新引起的。由于网站是共享的,因此如果不用于提高应用程序密度,则会定期刷新每个站点。在应用程序重新启动后,您可能需要重新建立连接的某些资源。
您可以通过编辑iisnode.yml文件并设置loggingEnabled = true来获取有关错误的更多详细信息(基本上是记录到stdout或stderr流的任何数据),然后下载日志(使用跨平台下载天蓝色站点日志)工具)。
-Mark
答案 2 :(得分:0)
如果您有iisnode.yml,请使用它打开日志记录和调试。 iisnode.yml会覆盖web.config中的任何设置,我们删除的默认设置会将deverrors和logging都禁用,因为这些是生产应用程序的正常设置。编辑iisnode.yml以更改这些值应该为您启用日志。