nginx發布的nginScript


nginx發布的nginScript

背景

2015年9月,nginx宣布支持類JavaScript語言。這意味着開發者可以更輕松、自由的控制全球最優秀的HTTP及反向代理服務器,並在此之上可以衍生出更多有用、好玩的創意。

 Nginx介紹:

1、工作在TCP第七層,可以對HTTP協議的所有內容進行分析和處理。
2、支持lua,perl,JavaScript動態語言
3、支持第三方插件

nginScript介紹:

1、 nginScript是JavaScript/ECMAscript的子集 。它實現了大部分的JavaScript語言的能力,沒有完全遵從ECMAScript標准,同時拋棄了JavaScript比較難懂的部分。

2、 nginScript不是通過V8引擎實現的 。而是通過一個更小、能耗更低、更符合nginx應用場景的小虛擬機(VM)來實現。可以理解為nginx為其實現了一套自己的詞法解析。

3、 nginScript是跑在nginx的配置文件里 。 比如:nginx.conf文件里。所以nginScript可以完成傳統配置文件所能處理的所有事情,同時可以讓配置管理動態化。這也是nginScript出現的最重要的原因。

4、 nginScript 是以nginx插件的方式存在。 插件名叫: njs 。和其他nginx插件一樣,我們需要重新編譯nginx來完成安裝。

5、 nginScript目前是早期研發狀態 。大家可以通過郵件 nginx-devel@nginx.org 等方式和nginx團隊進行溝通和提出你的訴求。

如何安裝nginScript

這里直接按照官方給出的步驟來就好:

1、下載最新nginx包,地址可見: http://nginx.org/en/download.html wget http://nginx.org/download/nginx-1.9.4.tar.gz

2、 解壓 tar -xzvf nginx-1.9.4.tar.gz

3、通過mercurial獲取nginScript模塊,這里如果沒有安裝mercurial,需要先運行 yum install mercurial hg clone http://hg.nginx.org/njs

4、編譯nginx,這里只具體了njs模塊,其他需要的模塊自己要記得一起裝哦。如果你沒編譯過nginx,有些依賴模塊需要yum安裝,請自行搜索。

cd nginx-1.9.4

./configure --add-module=../njs/nginx --prefix=/usr/local

make

make install

ok,這就安裝完了,我們可以開始玩啦。

具體如何使用nginScript

nginScript的使用主要是在nginx的配置體系里增加了2個指令。具體指令分別為:

js_set ,設置配置里的變量值

js_run ,直接執行配置規則

1、先看看 js_set 在nginx.conf里怎么運行的。

http {
 js_set $msg"
   var str = 'hello,imweb';
   // JavaScript str;
 ";
 server {
  ...
  location /{
   return 200 $msg;
  }
 }
}

 

結果:

 

上面例子里可以看出,我們可以通過JS隨意地給nginx設置變量值。而這些變量是可以用在nginx配置的各個地方。比如:proxy_pass,limit_req_zone, and sub_filter。這里相對之前配置已經大大的提高了靈活性。

2、 js_run 的運行規則和場景

js_run 是運行在location指令里,匹配指定location的路徑就會執行對應的JavaScript
js_run 是直接通過JavaScript來產生HTTP返回的內容
下面舉個具體的例子:

location /imwebteam {
 js_run "
  var res;
  res = $r.response;
  res.status = 200;
  res.send('hello,imweb!');
  res.finish();
 ";
}

 

這個結果和第一個結果是一樣的。這里就不贅述。

3、處理兩個指令以外,還有個重要的變量 $r

通過 js_set 和 js_run 可以對HTTP request請求有完整的控制權,控制的方式就是變量 $r 的使用。 $r 里有什么可以通過以下簡單例子看到。

http {
 js_set $summary "
 var a, s, h;
 s = 'JS summary\n\n';
 s += 'Method: ' + $r.method + '\n';
 s += 'HTTP version: ' + $r.httpVersion + '\n';
 s += 'Host: ' + $r.headers.host + '\n';
 s += 'Remote Address: ' + $r.remoteAddress + '\n';
 s += 'URI: ' + $r.uri + '\n';
 s += 'Headers:\n';
 for (h in $r.headers) {
  s += ' header \"' + h + '\" is \"' + $r.headers[h] + '\"\n';
 }
 s += 'Args:\n';
 for (a in $r.args) {
  s += ' arg \"' + a + '\" is \"' + $r.args[a] + '\"\n';
 }
 s;
 ";
 server {
 listen 8000;
 location /imwebteam{
  return 200 $summary;
 }
}
 

結果如圖:

 

nginScript目前還存在的問題

經過上面的介紹,相信大家對nginScript已經有了基本的認識。那么我們在看看這個新生兒有哪些問題吧。

首先,調試方法弱。目前還是比較原始,通過log的方式來展示,且錯誤日志的詳細程度很不如人意。
其次,控制力度弱。目前nginScript的處理力度還僅限於http request的處理和返回response的層面,還無法做到動態處理nginx請求之外的一些內容,比如動態用戶數據或轉發配置表動態更新等。
最后,整體實現弱。整體結構還是比較簡單,js_run和js_set的運行環境是不太一致的,js_set執行ok的代碼段在js_run上會出現一些異常。
綜合來說,nginScript還是一個願望和前景很美好的新生兒。需要一定時間打磨和優化。也希望大家多多的提供意見和反饋,甚至是提交自己的插件。從而使得它有更好的成長。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM