Nginx 这个赛道还是被 JavaScript 闯进来了

前端后端

🍄 大家好,我是风筝

🌍 转自作者:古时的风筝,原文:juejin.cn/post/7436414760712929289

本文目的为个人学习记录及知识分享。如果有什么不正确、不严谨的地方请及时指正,不胜感激。

每一个赞都是我前进的动力。

曾经,用JavaScript,你可以让按钮动起来,现在用 JavaScript,你可以让整个互联网运转起来。

这句话虽然是调侃,但多少也反应了一些事实,最开始JavaScript 就是纯纯的脚本语言,只为工作在浏览器上,配合 HTML和 CSS 的,后来地位越来越重要,网站的动效和交互都要依靠它来完成。

picture.image

再之后,NodeJS 横空出世,使JavaScript变成了全栈语言。从此,JavaScript 成了唯一一种能同时让前端浏览器和后端服务器崩溃的语言。

JavaScript 从纯前端语言向后端跨了一小步,这是 JavaScript 的一小步,却是前端开发者的一大步,从此前端开发者全都轻轻松松变成了全栈开发,从此前后端一把梭,独立开发信手拈来,作为后端开发,只能咬牙切齿拍大腿:“早知道当初学前端了,失业了还能搞独立开发”。

当然,JavaScript 不光涉及浏览器和服务器,还涉及PC客户端和移动客户端

设想一下,假设哪天世界上的 JavaScript 突然神奇的都不工作了,那会有多少网站、应用崩溃。

如果到这儿就结束了,那就太单纯了。

相信各位大多数都知道 Nginx 是支持动态模块的,比如 HTTPS 模块、SSL 模块等,就像插件一样,添加某个插件就能支持一些功能,大部分模块都是用 C 语言实现的。除了 C 语言外,Nginx 支持的最好的应该就是 Lua 模块了。

这不,JavaScript 也挤进来了,最近 Nginx 正式推出了 JavaScript 动态模块 NJS。

picture.image

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 端处理一些东西效果和性能上要更好一些。

0
0
0
0
关于作者
相关资源
抖音连麦音画质体验提升与进阶实践
随着互娱场景实时互动创新玩法层出不穷,业务伙伴对 RTC「体验」和「稳定」的要求越来越高。火山引擎 RTC 经历了抖音 6 亿 DAU 的严苛验证和打磨,在架构设计、音画质提升、高可靠服务等方面沉淀了丰富的经验,本次演讲将和大家分享火山引擎 RTC 在直播连麦等场景中的技术优化及其带来的新玩法。
相关产品
评论
未登录
看完啦,登录分享一下感受吧~
暂无评论