node解析修改nginx配置文件操作实例分析


Posted in Javascript onNovember 06, 2019

本文实例讲述了node解析修改nginx配置文件操作。分享给大家供大家参考,具体如下:

主要是通过nginx-conf这个工具。

git地址:https://github.com/tmont/nginx-conf

具体用法:

npm install -S nginx-conf 安装工具

var NginxConfFile = require('nginx-conf').NginxConfFile;
// 这个api提供了node读写conf文件的功能
NginxConfFile.create('/etc/nginx.conf', function(err, conf) {
 if (err) {
  console.log(err);
  return;
 }
// 通过_value的方式读取每一个配置的值
 console.log(conf.nginx.user._value); //www www
 console.log(conf.nginx.http.server.listen._value); //one.example.com
 //模块中有多个子模块,比如server中配置了多个location,通过数组下标的方式访问
 console.log(conf.nginx.http.server.location[3].root._value); // /spool/www
 //修改配置
 //create api是同步修改文件的,对于配置的修改和删除会同步反映到磁盘中
 conf.on('flushed', function() {
  console.log('finished writing to disk');
 });
 //listen to the flushed event to determine when the new file has been flushed to disk
 conf.nginx.events.connections._value = 1000;
 // 这个api的用途是当配置改变时不写到磁盘中
 conf.die('/etc/nginx.conf');
 conf.nginx.events.connections._value = 2000; //change remains local, not in /etc/nginx.conf
 // 将内存中的配置写到另一个文件中
 conf.live('/etc/nginx.conf.bak');
 // 强行将内存中的配置刷到磁盘中
 conf.flush();
 // 增加和移除指令 通过 _add 和 _remove
 conf.nginx.http._add('add_header', 'Cache-Control max-age=315360000, public');
 console.log(conf.nginx.http.add_header._value); //Cache-Control max-age=315360000, public
 conf.nginx.http._add('add_header', 'X-Load-Balancer lb-01');
 conf.nginx.http._add('add_header', 'X-Secure true');
 console.log(conf.nginx.http.add_header[0]._value); //Cache-Control max-age=315360000, public
 console.log(conf.nginx.http.add_header[1]._value); //X-Load-Balancer lb-01
 console.log(conf.nginx.http.add_header[2]._value); //X-Secure true
 conf.nginx.http._remove('add_header'); //removes add_header[0]
 conf.nginx.http._remove('add_header', 1); //removes add_header[1]
 //如果只有一个带有名称的指令,会被被展开成一个属性,通过数组下表访问的将是undefined
 console.log(conf.nginx.http.add_header._value); //X-Load-Balancer lb-01
 console.log(conf.nginx.http.add_header[0]); //undefined
 // 增加一个新的模块
 conf.nginx.http._add('server');
 conf.nginx.http.server._add('listen', '80');
 //that'll create something like this:
 /*
  server {
   listen 80;
  }
 */
 // 存在多个模块是通过数组方式访问
 conf.nginx.http._add('server');
 conf.nginx.http.server[1]._add('listen', '443');
 /*
  server {
   listen 80;
  }
  server {
   listen 443;
  }
 */
 // blocks with values:
 conf.nginx.http.server[1]._add('location', '/');
 conf.nginx.http.server[1].location._add('root', '/var/www/example.com');
 /*
  server {
   location / {
    root /var/www/example.com;
   }
  }
 */
 // lua blocks also work, but you can't put a mismatched "{" or "}" in a comment!
 conf.nginx.http.location._addVerbatimBlock('rewrite_by_lua_block', '{\n\
 ngx.say("this is a lua block!")\n\
 res = ngx.location.capture("/memc",\n\
  { args = { cmd = "incr", key = ngx.var.uri } }\n\
 )\n\
}');
});

此工具同样支持对注释的修改

// 读取use配置上的注释,以数组的方式返回
console.log(conf.nginx.events.use._comments.length); // 1
console.log(conf.nginx.events.use._comments[0]); // use [ kqueue | rtsig | epoll | /dev/poll | select | poll ];
// 删除注释
conf.nginx.events.use._comments.splice(0, 1);
// 添加注释
conf.nginx.event.use._comments.push('my new comment');
console.log(conf.nginx.events.use._comments.length); // 1
console.log(conf.nginx.events.use._comments[0]); //my new comment
// 修改注释
conf.nginx.event.use._comments[0] = 'updated';
console.log(conf.nginx.events.use._comments[0]); //updated

注意特殊情况

foo #comment
bar;
console.log(conf.nginx.foo._value); //bar
console.log(conf.nginx.foo._comments[0]); //comment
But if the comment comes after:
foo bar;
#comment
console.log(conf.nginx.foo._value); //bar
console.log(conf.nginx.foo._comments.length); //0

希望本文所述对大家node.js程序设计有所帮助。

Javascript 相关文章推荐
如何取得中文输入的真实长度?
Jun 24 Javascript
Prototype 学习 工具函数学习($A方法)
Jul 12 Javascript
jquery 新浪网易的评论块制作
Jul 01 Javascript
实用的Jquery选项卡TAB示例代码
Aug 28 Javascript
Javascript 基础---Ajax入门必看
Jul 06 Javascript
js鼠标按键事件和键盘按键事件用法实例汇总
Oct 03 Javascript
JavaScript简单生成 N~M 之间随机数的方法
Jan 13 Javascript
Vue中使用方法、计算属性或观察者的方法实例详解
Oct 31 Javascript
微信小程序实现顶部导航特效
Jan 28 Javascript
vue实现PC端录音功能的实例代码
Jun 05 Javascript
Vue scoped及deep使用方法解析
Aug 01 Javascript
JavaScript快速调试的两个技巧
Nov 04 Javascript
vuex实现像调用模板方法一样调用Mutations方法
Nov 06 #Javascript
vuex actions异步修改状态的实例详解
Nov 06 #Javascript
Windows上node.js的多版本管理工具用法实例分析
Nov 06 #Javascript
vue限制输入框只能输入8位整数和2位小数的代码
Nov 06 #Javascript
vuex存值与取值的实例
Nov 06 #Javascript
node省市区三级数据性能测评实例分析
Nov 06 #Javascript
vue计算属性无法监听到数组内部变化的解决方案
Nov 06 #Javascript
You might like
PHP 文件类型判断代码
2009/03/13 PHP
Yii中srbac权限扩展模块工作原理与用法分析
2016/07/14 PHP
[原创]php token使用与验证示例【测试可用】
2017/08/30 PHP
Javascript常用运算符(Operators)-javascript基础教程
2007/12/14 Javascript
基于jquery的可多选的下拉列表框
2012/07/20 Javascript
原生js写的放大镜效果
2012/08/22 Javascript
在JS方法中返回多个值的方法汇总
2015/05/20 Javascript
JavaScript的代码编写格式规范指南
2015/12/07 Javascript
JS组件Bootstrap ContextMenu右键菜单使用方法
2016/04/17 Javascript
浅谈如何实现easyui的datebox格式化
2016/06/12 Javascript
JavaScript实现邮箱地址自动匹配功能代码
2016/11/28 Javascript
JS实现旋转木马式图片轮播效果
2017/01/18 Javascript
JS中cookie的使用及缺点讲解
2017/05/13 Javascript
canvas绘制爱心的几种方法总结(推荐)
2017/10/31 Javascript
详解webpack与SPA实践之开发环境搭建
2017/12/18 Javascript
angularJS开发注意事项
2018/05/26 Javascript
浅析vue-router jquery和params传参(接收参数)$router $route的区别
2018/08/03 jQuery
详解ES6 Fetch API HTTP请求实用指南
2018/11/14 Javascript
微信小程序textarea层级过高(盖住其他元素)问题的解决办法
2019/03/04 Javascript
Layui数据表格判断编辑输入的值,是否为我需要的类型详解
2019/10/26 Javascript
vue渲染方式render和template的区别
2020/06/05 Javascript
JS实现鼠标按下拖拽效果
2020/07/23 Javascript
用Python的Tornado框架结合memcached页面改善博客性能
2015/04/24 Python
Python实现Sqlite将字段当做索引进行查询的方法
2016/07/21 Python
python 队列详解及实例代码
2016/10/18 Python
Python字符串格式化%s%d%f详解
2018/02/02 Python
基于Pandas读取csv文件Error的总结
2018/06/15 Python
Django 开发环境配置过程详解
2019/07/18 Python
flask 使用 flask_apscheduler 做定时循环任务的实现
2019/12/10 Python
查看已安装tensorflow版本的方法示例
2020/04/19 Python
美国定制钻石订婚戒指:Ritani
2017/12/08 全球购物
Linux面试经常问的文件系统操作命令
2015/11/05 面试题
教师自我评价范例
2013/09/24 职场文书
证婚人经典证婚词
2014/01/09 职场文书
小学生暑假家长评语
2014/04/17 职场文书
学校查摆问题整改措施
2014/09/28 职场文书