真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

nginx的JavaScript能力nginScript實例分析

這篇文章主要介紹“nginx的JavaScript能力nginScript實例分析”,在日常操作中,相信很多人在nginx的JavaScript能力nginScript實例分析問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”nginx的JavaScript能力nginScript實例分析”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比睢陽網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式睢陽網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋睢陽地區(qū)。費用合理售后完善,十年實體公司更值得信賴。

 nginx主要可以做以下幾點:

1、工作在tcp第七層,可以對http協(xié)議的所有內(nèi)容進行分析和處理。
2、支持lua,perl,javascript動態(tài)語言
3、支持第三方插件

再說說nginscript

1、 nginscript是javascript/ecmascript的子集 。它實現(xiàn)了大部分的javascript語言的能力,沒有完全遵從ecmascript標準,同時拋棄了javascript比較難懂的部分。

2、 nginscript不是通過v8引擎實現(xiàn)的 。而是通過一個更小、能耗更低、更符合nginx應(yīng)用場景的小虛擬機(vm)來實現(xiàn)??梢岳斫鉃閚ginx為其實現(xiàn)了一套自己的詞法解析。

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

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

5、 nginscript目前是早期研發(fā)狀態(tài) 。大家可以通過郵件  等方式和nginx團隊進行溝通和提出你的訴求。

如何安裝nginscript

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

// 1、下載最新nginx包,地址可見:  wget  //2、 解壓 tar -xzvf nginx-1.9.4.tar.gz //3、通過mercurial獲取nginscript模塊,這里如果沒有安裝mercurial,需要先運行 yum install mercurial hg clone

//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 ,設(shè)置配置里的變量值

js_run ,直接執(zhí)行配置規(guī)則

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

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

結(jié)果:

nginx的JavaScript能力nginScript實例分析 

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

2、 js_run 的運行規(guī)則和場景

js_run 是運行在location指令里,匹配指定location的路徑就會執(zhí)行對應(yīng)的javascript
js_run 是直接通過javascript來產(chǎn)生http返回的內(nèi)容
下面舉個具體的例子:

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

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

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

通過 js_set 和 js_run 可以對http request請求有完整的控制權(quán),控制的方式就是變量 $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;
 }
}

結(jié)果如圖:

nginx的JavaScript能力nginScript實例分析 

nginscript目前還存在的問題

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

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

對于我們的實踐場景

這個之前和黎小騰君,donald討論過的2個主要場景,reallog系統(tǒng)和nohost2.0系統(tǒng)。 nginscript對這里兩個場景來講都無疑是很大的好消息,這里在規(guī)則響應(yīng)上,在現(xiàn)有的體系下就可以有很靈活的處理方法。 但在用戶配置動態(tài)加載方面,我們?nèi)孕枰ㄟ^其他方式來實現(xiàn),這個部分我們先提issue給到nginx開發(fā)團隊,看下具體情況再和大家進一步討論和同步。

到此,關(guān)于“nginx的JavaScript能力nginScript實例分析”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
分享標題:nginx的JavaScript能力nginScript實例分析
網(wǎng)頁鏈接:http://weahome.cn/article/goejog.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部