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

举报
yd_244540595 发表于 2024/12/30 18:10:18 2024/12/30
【摘要】  转自作者:古时的风筝,原文:juejin.cn/post/7436414760712929289本文目的为个人学习记录及知识分享。如果有什么不正确、不严谨的地方请及时指正,不胜感激。曾经,用JavaScript,你可以让按钮动起来,现在用 JavaScript,你可以让整个互联网运转起来。这句话虽然是调侃,但多少也反应了一些事实,最开始JavaScript 就是纯纯的脚本语言,只为工作在浏...
 转自作者:古时的风筝,原文:juejin.cn/post/7436414760712929289
本文目的为个人学习记录及知识分享。如果有什么不正确、不严谨的地方请及时指正,不胜感激。

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

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


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


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


当然,JavaScript 不光涉及浏览器和服务器,还涉及PC客户端和移动客户端,我之前写的独立开发者都用什么框架开发客户端产品(PC客户端篇)独立开发者都用什么框架开发移动端产品这两篇文章里,介绍了几种跨平台的开发框架,其中PC端 Electron 、Tauri 以及移动端React Native、UniApp都使用 JavaScript 实现的。你就说它强不强吧。


设想一下,假设哪天世界上的 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) 和更新的扩展。

官网地址: github.com/nginx/njs


按照 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!\n");
}

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了。

#畅聊专区#更多的使用示例可以参考 github.com/nginx/njs-e… ,包括权限处理、日志处理、代理转发、重定向等都在里面。


说实话,以前自己配置 Nginx 的话,能简单就简单着来,还真没想过在 Nginx 中搞什么,宁愿在应用服务中做,现在用 NJS 的话,感觉也不是不可以了,毕竟在 Nginx 端处理一些东西效果和性能上要更好一些。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。