基于javascript处理nginx请求过程详解


Posted in Javascript onJuly 07, 2020

nginx是一个HTTP和反向代理服务器,目前很多网站都在使用nginx作为反向代理服务器。
njs是JavaScript语言的一个子集,它允许扩展nginx的功能,这点跟lua有点类似,不过采用的语言是javascript。

1. 安装nginx

要使用njs,需要安装一个nginx,这里的我使用的环境是Ubuntu18.04.4。

首先从http://nginx.org/en/download.html下载最新的stable version的nginx源码。

a. 解压源码

sudo tar zxvf nginx-1.18.0.tar.gz

b. 安装必要依赖库

sudo apt-get install libpcre3 libpcre3-dev
sudo apt-get install zlib1g-dev
sudo apt-get install openssl libssl-dev
# 如果是Centos系统,则使用下面的命令
# yum install pcre pcre-devel
# yum install zlib zlib-devel
# yum install openssl-devel

c. 拉取njs源码

# 安装mercurial
sudo apt-get install mercurial
# 拉取源码
cd /usr/local/src
hg clone http://hg.nginx.org/njs

d. 配置nginx

cd nginx-1.18.0
sudo ./configure \
--sbin-path=/usr/local/nginx/nginx \
--conf-path=/usr/local/nginx/nginx.conf \
--pid-path=/usr/local/nginx/nginx.pid \
--add-module=/usr/local/src/njs/nginx

如果配置成功,可以看到如下信息:

Configuration summary
+ using system PCRE library
+ OpenSSL library is not used
+ using system zlib library

nginx path prefix: "/usr/local/nginx"
nginx binary file: "/usr/local/nginx/nginx"
nginx modules path: "/usr/local/nginx/modules"
nginx configuration prefix: "/usr/local/nginx"
nginx configuration file: "/usr/local/nginx/nginx.conf"
nginx pid file: "/usr/local/nginx/nginx.pid"
nginx error log file: "/usr/local/nginx/logs/error.log"
nginx http access log file: "/usr/local/nginx/logs/access.log"
nginx http client request body temporary files: "client_body_temp"
nginx http proxy temporary files: "proxy_temp"
nginx http fastcgi temporary files: "fastcgi_temp"
nginx http uwsgi temporary files: "uwsgi_temp"
nginx http scgi temporary files: "scgi_temp"

e. 编译源码

sudo make
# 如果没有安装make指令,可以通过下面的命令安装
# sudo apt-get install make
f. 安装

sudo make install
# 安装目录为/usr/local/nginx

g. 启动nginx

cd /usr/local/nginx
sudo ./nginx

启动后可以通过访问http://localhost查看nginx是否启动成功,也可以通过logs目录下的日志查看启动日志。
到这里集成njs的nginx就安装完成了,下面可以开始写javascript代码了。

2. 编写js代码

在nginx根目录中创建一下js目录用存放所有的js程序,并编写http.js测试njs模块是否集成完成。

sudo mkdir js
cd js
sudo touch http.js

http.js的源码

function hello(r) {
  r.return(200, "Hello world!");
}
export default {hello};

3. 引入js程序

http.js编写完成后,需要引入到nginx中,修复nginx.conf配置,下面省略了其他相关配置

http {
 # 引入http程序
 js_import js/http.js;

 server {
  location /js {
   default_type 'text/html';
   js_content http.hello;
  }
 }
}

上面指定了/js路径的处理由http.hello程序处理,这样可以通过浏览器访问http://localhost/js来查看http.hello返回的结果。

4. 更多njs指令

关于更多的njs指令及案例,可以在官网中查阅 http://nginx.org/en/docs/njs/index.html。

案例地址:http://nginx.org/en/docs/njs/examples.html。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js 关于=+与+=日期函数使用说明(赋值运算符)
Nov 15 Javascript
JavaScript转换与解析JSON方法实例详解
Nov 24 Javascript
Vuejs第十篇之vuejs父子组件通信
Sep 06 Javascript
ES6字符串模板,剩余参数,默认参数功能与用法示例
Apr 06 Javascript
详解Node.js 命令行程序开发教程
Jun 07 Javascript
JavaScript实现动态添加Form表单元素的方法示例
Aug 14 Javascript
详解React Native开源时间日期选择器组件(react-native-datetime)
Sep 13 Javascript
JS实现自定义状态栏动画文字效果示例
Oct 12 Javascript
Vue.js 中取得后台原生HTML字符串 原样显示问题的解决方法
Jun 10 Javascript
Vue Element 分组+多选+可搜索Select选择器实现示例
Jul 23 Javascript
使用JS判断移动端手机横竖屏状态
Jul 30 Javascript
JavaScript适配器模式原理与用法实例详解
Mar 09 Javascript
vue-i18n实现中英文切换的方法
Jul 06 #Javascript
vue 实现动态路由的方法
Jul 06 #Javascript
Nuxt配置Element-UI按需引入的操作方法
Jul 06 #Javascript
解决Nuxt使用axios跨域问题
Jul 06 #Javascript
js实现星星打分效果
Jul 05 #Javascript
jQuery实现简单飞机大战
Jul 05 #jQuery
javascript实现贪吃蛇小练习
Jul 05 #Javascript
You might like
PHP函数utf8转gb2312编码
2006/12/21 PHP
php set_time_limit(0) 设置程序执行时间的函数
2010/05/26 PHP
探讨多键值cookie(php中cookie存取数组)的详解
2013/06/06 PHP
php获取远程文件内容的函数
2015/11/02 PHP
PHP的Yii框架中移除组件所绑定的行为的方法
2016/03/18 PHP
Yii框架视图、视图布局、视图数据块操作示例
2019/10/14 PHP
ThinkPHP5&5.1实现验证码的生成、使用及点击刷新功能示例
2020/02/07 PHP
JS input文本框禁用右键和复制粘贴功能的代码
2010/04/15 Javascript
javascript中的prototype属性使用说明(函数功能扩展)
2010/08/16 Javascript
红米手机抢购的js代码
2014/03/10 Javascript
浅谈jQuery 选择器和dom操作
2016/06/07 Javascript
jQuery多个版本和其他js库冲突的解决方法
2016/08/11 Javascript
BOM系列第一篇之定时器setTimeout和setInterval
2016/08/17 Javascript
node网页分段渲染详解
2016/09/05 Javascript
JS实现拖动滚动条评分的效果代码分享
2016/09/29 Javascript
Vue自定义指令拖拽功能示例
2017/02/17 Javascript
详解Vue 事件驱动和依赖追踪
2017/04/22 Javascript
Vue 使用 Mint UI 实现左滑删除效果CellSwipe
2018/04/27 Javascript
node.js部署之启动后台运行forever的方法
2018/05/23 Javascript
react在安卓中输入框被手机键盘遮挡问题的解决方法
2018/09/03 Javascript
vue form 表单提交后刷新页面的方法
2018/09/04 Javascript
Vue实现菜单切换功能
2020/11/08 Javascript
python中使用PIL制作并验证图片验证码
2018/03/15 Python
Python进程间通信Queue消息队列用法分析
2019/05/22 Python
python函数参数(必须参数、可变参数、关键字参数)
2019/08/16 Python
python实现文字版扫雷
2020/04/24 Python
Python持续监听文件变化代码实例
2020/07/22 Python
世界上最大的字体市场:MyFonts
2020/01/10 全球购物
某公司部分笔试题
2013/11/05 面试题
关键字throw与throws的用法差异
2016/11/22 面试题
经贸日语专业个人求职信
2013/12/13 职场文书
2014年社区个人工作总结
2014/12/02 职场文书
食堂采购员岗位职责
2015/04/03 职场文书
单位收入证明范本
2015/06/18 职场文书
CSS3实现的侧滑菜单
2021/04/27 HTML / CSS
详解CSS不受控制的position fixed
2021/05/25 HTML / CSS