Nodejs 将命令行参数设置为常量

Nodejs set command line argument as constant

本文关键字:常量 设置 参数 命令行 Nodejs      更新时间:2023-09-26
我想在

启动服务器时从命令行获取 argv,然后我想将其设置为模块的常量。

例如,我想从命令行定义我的日志文件路径:

我的启动器.js看起来像:

var optimist = require("optimist");
var server = require("./start_server");
var argv = optimist.describe('logpath', 'logptah for info').argv;
server.init({logpath:argv.logpath});

我的start_server.js如下所示:

    var restify = require('restify');
    var server = restify.createServer({
        name: 'dummy-project'
    });
    module.exports.logpath = null;
    function init(args){
        server.listen(1234, function() {
            console.log("inside logs");
            console.log(args.logpath);
            module.exports.logpath = args.logpath;
            console.log('%s listening at %s', server.name, server.url);
        });
    };
    module.exports.init = init;
    var fun = require('./common/loghandler');

我的日志处理程序.js看起来像:

var server = require('./../start_server');
console.log("inside log handler");
var LOGPATH = server.logpath;
console.log(LOGPATH);

当我运行node starter.js --logpath='../../custom/info.txt'我没有在我的日志处理程序中获取日志路径。

似乎在server.listen之前调用了日志路径处理程序。

控制台输出如下所示:

node starter.js --logpath='../../custom/info.txt'
inside log handler
null
inside log handler 
../../custom/info.txt
dummy-project listening at http://0.0.0.0:1234

如何克服它并将我的日志路径作为命令行参数传递?

提前谢谢。

您的init()函数在starter.js使用require('./start_server')后执行。使用 require() 时,将加载文件及其所有依赖项。这意味着在此过程中,您还执行了 require('./common/loghandler') ,该 server.init()starter.js 中运行之前完成。由于此时尚未设置server.logpath,因此您将获得一个 null 值。

除此之外,module.exports是在需要的时间设置的,以后更改值不起作用。若要解决遇到的问题,应避免在应用程序完全加载之前使用函数,并将返回值放入模块中。