node.js - 无法启用 Azure Node.js 日志记录

标签 node.js azure iisnode

我无法让日志记录适用于我部署到 Windows Azure 的 Node 应用程序。我使用 iisnode.yml 文件选项覆盖 web.config。

这是 yml 文件内容:

node_env: development
nodeProcessCountPerApplication: 1
maxConcurrentRequestsPerProcess: 1024
maxNamedPipeConnectionRetry: 24
namedPipeConnectionRetryDelay: 250
maxNamedPipeConnectionPoolSize: 512
maxNamedPipePooledConnectionAge: 30000
asyncCompletionThreadCount: 0
initialRequestBufferSize: 4096
maxRequestBufferSize: 65536
watchedFiles: *.js;iisnode.yml
uncFileChangesPollingInterval: 5000
gracefulShutdownTimeout: 60000
loggingEnabled: true
logDirectory: iisnode
debuggingEnabled: true
debuggerPortRange: 5058-6058
debuggerPathSegment: debug
maxLogFileSizeInKB: 128
maxTotalLogFileSizeInKB: 1024
maxLogFiles: 20
devErrorsEnabled: true
flushResponse: false
enableXFF: false

以下是被覆盖的 web.config 文件的内容:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
    <system.webServer>
        <modules runAllManagedModulesForAllRequests="false" />
        <iisnode configOverrides="iisnode.yml" debuggingEnabled="true" loggingEnabled="true" logDirectory="iisnode" devErrorsEnabled="true" nodeProcessCommandLine="&quot;%programfiles(x86)%\nodejs\node.exe&quot;"  />
        <handlers>
            <add name="iisnode" path="server.js" verb="*" modules="iisnode" />
        </handlers>
        <rewrite>
            <rules>
                <clear />
                <rule name="app" enabled="true" patternSyntax="ECMAScript" stopProcessing="true">
                    <match url="server\.js.+" negate="true" />
                    <conditions logicalGrouping="MatchAll" trackAllCaptures="false" />
                    <action type="Rewrite" url="server.js" />
                </rule>
                <rule name="LogFile" patternSyntax="ECMAScript" stopProcessing="true">
                    <match url="iisnode"/>
                </rule>
                <rule name="NodeInspector" patternSyntax="ECMAScript" stopProcessing="true">
                    <match url="^server.js\/debug[\/]?" />
                </rule>
                <rule name="StaticContent">
                    <action type="Rewrite" url="public{{REQUEST_URI}}"/>
                </rule>
                <rule name="DynamicContent">
                    <conditions>
                        <add input="{{REQUEST_FILENAME}}" matchType="IsFile" negate="True"/>
                    </conditions>
                    <action type="Rewrite" url="server.js"/>
                </rule>
            </rules>
        </rewrite>
    </system.webServer>
</configuration>

我很确定我已经启用了两个日志记录选项,但在部署期间以及当我访问典型日志记录位置 http://mysite.com/iisnode/index.html 时,Azure 似乎都没有选择这些选项。或http://mysite.com/iisnode/我收到 404 错误。

任何帮助或想法将不胜感激。

最佳答案

如果您使用的是 Express,请将其添加到静态文件夹位置

app.use(express.static(__dirname + '/../iisnode'));

或者定义您自己的日志路由,如下所示。在这里您可以得到奇特的结果,并且只显示错误等。

//logging routes
var fs = require('fs');
app.get('/iisnode', function(req, res){
  var _index = fs.readFileSync('./iisnode/index.html', 'utf8');
  var index = _index.replace("logCell.innerHTML = '<a href=\"' + logFile.file + '\">log</a>';", "logCell.innerHTML = '<a href=\"/iisnode/' + logFile.file + '\">log</a>';");
  res.send(index);
});

app.get('/iisnode/:log', function(req, res){
  var _log = fs.readFileSync('./iisnode/' + req.route.params['log'], 'utf8');
  res.contentType('text/plain');
  res.send(_log);
});

您可以将 app.get 替换为您正在使用的任何路由解决方案。

请记住在生产环境中启动应用程序之前将其删除。

关于node.js - 无法启用 Azure Node.js 日志记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12483782/

相关文章:

javascript - Node JS 安全摄像头运动检测

node.js - npm 'json-update' 未按预期工作

azure - 在 ubuntu 16.04 中安装 Varnish

deployment - 由于启动脚本,Azure 部署失败

node.js - 访问 Node.js 中的 Azure ServiceConfiguration 设置

node.js - 错误 : EPERM, Node.js 和 Etherpad Lite 不允许进行操作

javascript - Nodeunit 测试因异步数据库调用 ORMnomnom 而挂起

mysql - 如何避免在nodejs中重复的sql连接代码并使用.env文件代替

Azure Frontdoor Classic 规则引擎配置为 Premium

javascript - 如何在azure网站子目录中运行node.js应用程序