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 相关文章推荐
读jQuery之六 缓存数据功能介绍
Jun 21 Javascript
document节点对象的获取方式示例介绍
Dec 24 Javascript
jQuery中:hidden选择器用法实例
Dec 30 Javascript
jQuery获取checkboxlist的value值的方法
Sep 27 Javascript
JavaScript File分段上传
Mar 10 Javascript
Node.js的环境安装配置(使用nvm方式)
Oct 11 Javascript
微信小程序 参数传递实例代码
Mar 20 Javascript
bootstrap是什么_动力节点Java学院整理
Jul 14 Javascript
详解element-ui表格中勾选checkbox,高亮当前行
Sep 02 Javascript
JS面向对象编程——ES6 中class的继承用法详解
Mar 03 Javascript
基于javascript实现碰撞检测
Mar 12 Javascript
typescript配置alias的详细步骤
Aug 12 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/08/21 PHP
解析PHP中常见的mongodb查询操作
2013/06/20 PHP
PHP 读取大文件的X行到Y行内容的实现代码
2013/06/24 PHP
php使用PDO从数据库表中读取数据的实现方法(必看)
2017/06/02 PHP
php实现小程序支付完整版
2018/10/09 PHP
PHP类的自动加载与命名空间用法实例分析
2020/06/05 PHP
在Javascript中为String对象添加trim,ltrim,rtrim方法
2006/09/22 Javascript
javascript深入理解js闭包
2010/07/03 Javascript
jquery中的过滤操作详细解析
2013/12/02 Javascript
js的for in循环和java里foreach循环的区别分析
2015/01/28 Javascript
JSON格式的键盘编码对照表
2015/01/29 Javascript
jQuery插件scroll实现无缝滚动效果
2015/04/27 Javascript
深入分析jQuery的ready函数是如何工作的(工作原理)
2015/12/17 Javascript
jQuery简单设置文本框回车事件的方法
2016/08/01 Javascript
全面了解函数声明与函数表达式、变量提升
2016/08/09 Javascript
详解jquery validate实现表单验证 (正则表达式)
2017/01/18 Javascript
vue-cli结合Element-ui基于cropper.js封装vue实现图片裁剪组件功能
2018/03/01 Javascript
JavaScript常用工具函数库汇总
2020/09/17 Javascript
python关闭windows进程的方法
2015/04/18 Python
Python中threading模块join函数用法实例分析
2015/06/04 Python
python通过pip更新所有已安装的包实现方法
2017/05/19 Python
Python语言描述随机梯度下降法
2018/01/04 Python
python模拟点击网页按钮实现方法
2020/02/25 Python
浅谈python的elementtree模块处理中文注意事项
2020/03/06 Python
css3的图形3d翻转效果应用示例
2014/04/08 HTML / CSS
现代绅士日常奢侈品:Todd Snyder
2019/12/13 全球购物
关于VPN
2012/06/10 面试题
如何判断计算机可能已经中马
2013/03/22 面试题
RIP版本1跟版本2的区别
2013/12/30 面试题
高中体育教学反思
2014/01/24 职场文书
大学生先进事迹材料
2014/02/16 职场文书
优质服务活动实施方案
2014/05/02 职场文书
不服从公司安排检讨书
2014/09/24 职场文书
Anaconda安装pytorch及配置PyCharm 2021环境
2021/06/04 Python
node快速搭建后台的实现步骤
2022/02/18 NodeJs
如何设置多台电脑共享打印机?多台电脑共享打印机的方法
2022/04/08 数码科技