🍄 大家好,我是风筝
🌍 转自作者:古时的风筝,原文:juejin.cn/post/7436414760712929289
本文目的为个人学习记录及知识分享。如果有什么不正确、不严谨的地方请及时指正,不胜感激。
每一个赞都是我前进的动力。
曾经,用JavaScript,你可以让按钮动起来,现在用 JavaScript,你可以让整个互联网运转起来。
这句话虽然是调侃,但多少也反应了一些事实,最开始JavaScript 就是纯纯的脚本语言,只为工作在浏览器上,配合 HTML和 CSS 的,后来地位越来越重要,网站的动效和交互都要依靠它来完成。
再之后,NodeJS 横空出世,使JavaScript变成了全栈语言。从此,JavaScript 成了唯一一种能同时让前端浏览器和后端服务器崩溃的语言。
JavaScript 从纯前端语言向后端跨了一小步,这是 JavaScript 的一小步,却是前端开发者的一大步,从此前端开发者全都轻轻松松变成了全栈开发,从此前后端一把梭,独立开发信手拈来,作为后端开发,只能咬牙切齿拍大腿:“早知道当初学前端了,失业了还能搞独立开发”。
当然,JavaScript 不光涉及浏览器和服务器,还涉及PC客户端和移动客户端
设想一下,假设哪天世界上的 JavaScript 突然神奇的都不工作了,那会有多少网站、应用崩溃。
如果到这儿就结束了,那就太单纯了。
相信各位大多数都知道 Nginx 是支持动态模块的,比如 HTTPS 模块、SSL 模块等,就像插件一样,添加某个插件就能支持一些功能,大部分模块都是用 C 语言实现的。除了 C 语言外,Nginx 支持的最好的应该就是 Lua 模块了。
这不,JavaScript 也挤进来了,最近 Nginx 正式推出了 JavaScript 动态模块 NJS。
NJS 全称NGINX JavaScript,是 NGINX 的一个动态模块,支持使用熟悉的 JavaScript 语法扩展内置功能。NJS 语言是 JavaScript 的子集,与 ES5 (ECMAScript 5.1 Strict Variant) 兼容,并带有一些 ES6 (ECMAScript 6) 和更新的扩展。
按照 NJS 模块后,Nginx 就支持用JavaScript语法来实现一些规则了,比如鉴权、日志、动态代理等,也就是以前用 Lua 实现的功能,可以用大多数人更熟悉的 JavaScript 语法来实现了。
<顺便吆喝一句,技术大厂年前捞人,前后端测试方向,给的待遇还行,看机会的可以试试>
安装和使用
假设你使用的是 Ubuntu 服务器,使用下面的命令安装 NJS 模块。
sudo apt install nginx-module-njs
然后打开 Nginx 配置文件
sudo vim /etc/nginx/nginx.conf
在其中启用 NJS 模块
load_module modules/ngx_http_js_module.so;
之后,就可以动手写 JavaScript 文件了,假设在 /etc/nginx/njs
目录下,创建一个 hello.js
function hello(r) {
r.return(200, "Hello world!
");
}
export default {hello}
是不是一下就到了熟悉的领域了,从此 Nginx 都变得眉清目秀了。
再来 nginx.conf
改一下配置
# 加载 NJS 模块
load_module modules/ngx_http_js_module.so;
events {}
http {
# 设置 js 文件目录
js_path "/etc/nginx/njs/";
# 导入js文件到 main 变量中
js_import main from http/hello.js;
server {
listen 80;
location / {
# 当接到请求后,返回mian.hello 函数,也就是 hello.js 中的hello方法
js_content main.hello;
}
}
}
之后 reload 一下nginx,再次请求 http://127.0.0.1
的时候,就会返回Hello World
说实话,以前自己配置 Nginx 的话,能简单就简单着来,还真没想过在 Nginx 中搞什么,宁愿在应用服务中做,现在用 NJS 的话,感觉也不是不可以了,毕竟在 Nginx 端处理一些东西效果和性能上要更好一些。