整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          Java教程:Nginx靜態資源配置命令介紹

          Java教程:Nginx靜態資源配置命令介紹

          ginx靜態資源的配置指令

          listen指令

          listen:用來配置監聽端口。

          語法

          listen address[:port] [default_server]...; listen port [default_server]...;

          默認值

          listen *:80 | *:8000

          位置

          server

          listen的設置比較靈活,我們通過幾個例子來把常用的設置方式熟悉下:

          listen 127.0.0.1:8000; // listen localhost:8000 監聽指定的IP和端口

          listen 127.0.0.1; 監聽指定IP的所有端口

          listen 8000; 監聽指定端口上的連接

          listen *:8000; 監聽指定端口上的連接

          default_server屬性是標識符,用來將此虛擬主機設置成默認主機。所謂的默認主機指的是如果沒有匹配到對應的address:port,則會默認執行的。如果不指定默認使用的是第一個server。

          server{
          	listen 8080;
          	server_name 127.0.0.1;
          	location /{
          		root html;
          		index index.html;
          	}
          }
          server{
          	listen 8080 default_server;
          	server_name localhost;
          	default_type text/plain;
          	return 444 'This is a error request';
          }
          
          

          server_name指令

          server_name:用來設置虛擬主機服務名稱。

          127.0.0.1 、 localhost 、域名[www.baidu.com | www.jd.com]

          語法

          server_name name ...; name可以提供多個中間用空格分隔

          默認值

          server_name "";

          位置

          server

          關于server_name的配置方式有三種,分別是:

          ·精確匹配

          ·通配符匹配

          ·正則表達式匹配

          配置方式一:精確匹配

          server {
          	listen 80;
          	server_name www.itcast.cn www.itheima.cn;
          	...
          }
          
          

          補充小知識點:

          hosts是一個沒有擴展名的系統文件,可以用記事本等工具打開,其作用就是將一些常用的網址域名與其對應的IP地址建立一個關聯“數據庫”,當用戶在瀏覽器中輸入一個需要登錄的網址時,系統會首先自動從hosts文件中尋找對應的IP地址,一旦找到,系統會立即打開對應網頁,如果沒有找到,則系統會再將網址提交DNS域名解析服務器進行IP地址的解析。

          windows:C:\Windows\System32\drivers\etc

          centos:/etc/hosts

          因為域名是要收取一定的費用,所以我們可以使用修改hosts文件來制作一些虛擬域名來使用。需要修改 /etc/hosts文件來添加

          vim /etc/hosts
          127.0.0.1 www.itcast.cn
          127.0.0.1 www.itheima.cn
          
          

          配置方式二:使用通配符配置

          server_name中支持通配符"*",但需要注意的是通配符不能出現在域名的中間,只能出現在首段或尾段,如:

          server {
          	listen 80;
          	server_name  *.itcast.cn	www.itheima.*;
          	# www.itcast.cn abc.itcast.cn www.itheima.cn www.itheima.com
          	...
          }

          下面的配置就會報錯

          server {
          	listen 80;
          	server_name  www.*.cn www.itheima.c*
          	...
          }
          
          

          配置三:使用正則表達式配置

          server_name中可以使用正則表達式,并且使用~作為正則表達式字符串的開始標記。

          常見的正則表達式

          代碼

          說明

          ^

          匹配搜索字符串開始位置

          $

          匹配搜索字符串結束位置

          .

          匹配除換行符\n之外的任何單個字符

          \

          轉義字符,將下一個字符標記為特殊字符

          [xyz]

          字符集,與任意一個指定字符匹配

          [a-z]

          字符范圍,匹配指定范圍內的任何字符

          \w

          與以下任意字符匹配 A-Z a-z 0-9 和下劃線,等效于[A-Za-z0-9_]

          \d

          數字字符匹配,等效于[0-9]

          {n}

          正好匹配n次

          {n,}

          至少匹配n次

          {n,m}

          匹配至少n次至多m次

          *

          零次或多次,等效于{0,}

          +

          一次或多次,等效于{1,}

          ?

          零次或一次,等效于{0,1}

          配置如下:

          server{
                  listen 80;
                  server_name ~^www\.(\w+)\.com$;
                  default_type text/plain;
                  return 200 $1  $2 ..;
          }
          
          

          注意 ~后面不能加空格,括號可以取值

          匹配執行順序

          由于server_name指令支持通配符和正則表達式,因此在包含多個虛擬主機的配置文件中,可能會出現一個名稱被多個虛擬主機的server_name匹配成功,當遇到這種情況,當前的請求交給誰來處理呢?

          server{
          	listen 80;
          	server_name ~^www\.\w+\.com$;
          	default_type text/plain;
          	return 200 'regex_success';
          }
          
          server{
          	listen 80;
          	server_name www.itheima.*;
          	default_type text/plain;
          	return 200 'wildcard_after_success';
          }
          
          server{
          	listen 80;
          	server_name *.itheima.com;
          	default_type text/plain;
          	return 200 'wildcard_before_success';
          }
          
          server{
          	listen 80;
          	server_name www.itheima.com;
          	default_type text/plain;
          	return 200 'exact_success';
          }
          
          server{
          	listen 80 default_server;
          	server_name _;
          	default_type text/plain;
          	return 444 'default_server not found server';
          }
          
          

          結論:

          exact_success
          wildcard_before_success
          wildcard_after_success
          regex_success
          default_server not found server!!
          
          

          No1:準確匹配server_name

          No2:通配符在開始時匹配server_name成功

          No3:通配符在結束時匹配server_name成功

          No4:正則表達式匹配server_name成功

          No5:被默認的default_server處理,如果沒有指定默認找第一個server

          location指令

          server{
          	listen 80;
          	server_name localhost;
          	location / {
          	
          	}
          	location /abc{
          	
          	}
          	...
          }
          
          

          location:用來設置請求的URI

          默認值

          語法

          location [=| ~ | ~* | ^~ |@ ] uri{...}

          位置

          server,location

          uri變量是待匹配的請求字符串,可以不包含正則表達式,也可以包含正則表達式,那么nginx服務器在搜索匹配location的時候,是先使用不包含正則表達式進行匹配,找到一個匹配度最高的一個,然后在通過包含正則表達式的進行匹配,如果能匹配到直接訪問,匹配不到,就使用剛才匹配度最高的那個location來處理請求。

          屬性介紹:

          不帶符號,要求必須以指定模式開始

          server {
          	listen 80;
          	server_name 127.0.0.1;
          	location /abc{
          		default_type text/plain;
          		return 200 "access success";
          	}
          }
          以下訪問都是正確的
          http://192.168.200.133/abc
          http://192.168.200.133/abc?p1=TOM
          http://192.168.200.133/abc/
          http://192.168.200.133/abcdef
          
          

          =: 用于不包含正則表達式的uri前,必須與指定的模式精確匹配

          server {
          	listen 80;
          	server_name 127.0.0.1;
          	location=/abc{
          		default_type text/plain;
          		return 200 "access success";
          	}
          }
          可以匹配到
          http://192.168.200.133/abc
          http://192.168.200.133/abc?p1=TOM
          匹配不到
          http://192.168.200.133/abc/
          http://192.168.200.133/abcdef
          
          

          ~ : 用于表示當前uri中包含了正則表達式,并且區分大小寫

          ~*: 用于表示當前uri中包含了正則表達式,并且不區分大小寫

          換句話說,如果uri包含了正則表達式,需要用上述兩個符合來標識

          server {
          	listen 80;
          	server_name 127.0.0.1;
          	location ~^/abc\w${
          		default_type text/plain;
          		return 200 "access success";
          	}
          }
          server {
          	listen 80;
          	server_name 127.0.0.1;
          	location ~*^/abc\w${
          		default_type text/plain;
          		return 200 "access success";
          	}
          }
          
          

          ^~: 用于不包含正則表達式的uri前,功能和不加符號的一致,唯一不同的是,如果模式匹配,那么就停止搜索其他模式了。

          server {
          	listen 80;
          	server_name 127.0.0.1;
          	location ^~/abc{
          		default_type text/plain;
          		return 200 "access success";
          	}
          }
          
          

          設置請求資源的目錄root / alias

          root:設置請求的根目錄

          語法

          root path;

          默認值

          root html;

          位置

          http、server、location

          path為Nginx服務器接收到請求以后查找資源的根目錄路徑。

          alias:用來更改location的URI

          語法

          alias path;

          默認值

          位置

          location

          path為修改后的根路徑。

          以上兩個指令都可以來指定訪問資源的路徑,那么這兩者之間的區別是什么?

          舉例說明:

          (1)在/usr/local/nginx/html目錄下創建一個 images目錄,并在目錄下放入一張圖片mv.png圖片

          location /images {
          	root /usr/local/nginx/html;
          }
          
          

          訪問圖片的路徑為:

          http://192.168.200.133/images/mv.png

          (2)如果把root改為alias

          location /images {
          	alias /usr/local/nginx/html;
          }

          再次訪問上述地址,頁面會出現404的錯誤,查看錯誤日志會發現是因為地址不對,所以驗證了:

          root的處理結果是: root路徑+location路徑
          /usr/local/nginx/html/images/mv.png
          alias的處理結果是:使用alias路徑替換location路徑
          /usr/local/nginx/html/images

          需要在alias后面路徑改為

          location /images {
          	alias /usr/local/nginx/html/images;
          }

          (3)如果location路徑是以/結尾,則alias也必須是以/結尾,root沒有要求

          將上述配置修改為

          location /images/ {
          	alias /usr/local/nginx/html/images;
          }

          訪問就會出問題,查看錯誤日志還是路徑不對,所以需要把alias后面加上 /

          小結:

          root的處理結果是: root路徑+location路徑

          alias的處理結果是:使用alias路徑替換location路徑

          alias是一個目錄別名的定義,root則是最上層目錄的含義。

          如果location路徑是以/結尾,則alias也必須是以/結尾,root沒有要求

          index指令

          index:設置網站的默認首頁

          語法

          index file ...;

          默認值

          index index.html;

          位置

          http、server、location

          index后面可以跟多個設置,如果訪問的時候沒有指定具體訪問的資源,則會依次進行查找,找到第一個為止。

          舉例說明:

          location / {
          	root /usr/local/nginx/html;
          	index index.html index.htm;
          }
          訪問該location的時候,可以通過 http://ip:port/,地址后面如果不添加任何內容,則默認依次訪問index.html和index.htm,找到第一個來進行返回
          
          

          error_page指令

          error_page:設置網站的錯誤頁面

          語法

          error_page code ... [=[response]] uri;

          默認值

          位置

          http、server、location......

          當出現對應的響應code后,如何來處理。

          舉例說明:

          (1)可以指定具體跳轉的地址

          server {
          	error_page 404 http://www.itcast.cn;
          }
          
          

          (2)可以指定重定向地址

          server{
          	error_page 404 /50x.html;
          	error_page 500 502 503 504 /50x.html;
          	location=/50x.html{
          		root html;
          	}
          }

          (3)使用location的@符合完成錯誤信息展示

          server{
          	error_page 404 @jump_to_error;
          	location @jump_to_error {
          		default_type text/plain;
          		return 404 'Not Found Page...';
          	}
          }

          可選項=[response]的作用是用來將相應代碼更改為另外一個

          server{
          	error_page 404=200 /50x.html;
          	location=/50x.html{
          		root html;
          	}
          }

          這樣的話,當返回404找不到對應的資源的時候,在瀏覽器上可以看到,最終返回的狀態碼是200,這塊需要注意下,編寫error_page后面的內容,404后面需要加空格,200前面不能加空格。

          一種:Nginx自己的錯誤頁面

          Nginx訪問一個靜態的html 頁面,當這個頁面沒有的時候,Nginx拋出404,那么如何返回給客戶端404呢?

          看下面的配置,這種情況下不需要修改任何參數,就能實現這個功能。

          server {

          listen 80;

          server_name www.test.com;

          root /var/www/test;

          index index.html index.htm;

          location / {

          }

          # 定義錯誤頁面碼,如果出現相應的錯誤頁面碼,轉發到那里。

          error_page 404 403 500 502 503 504 /404.html;

          # 承接上面的location。

          location=/404.html {

          # 放錯誤頁面的目錄路徑。

          root /usr/share/nginx/html;

          }

          }

          第二種:反向代理的錯誤頁面

          如果后臺Tomcat處理報錯拋出404,想把這個狀態叫Nginx反饋給客戶端或者重定向到某個連接,配置如下:

          upstream www {

          server 192.168.1.201:7777 weight=20 max_fails=2 fail_timeout=30s;

          ip_hash;

          }

          server {

          listen 80;

          server_name www.test.com;

          root /var/www/test;

          index index.html index.htm;

          location / {

          if ($request_uri ~* ‘^/$’) {

          rewrite .* http://www.test.com/index.html redirect;

          }

          # 關鍵參數:這個變量開啟后,我們才能自定義錯誤頁面,當后端返回404,nginx攔截錯誤定義錯誤頁面

          proxy_intercept_errors on;

          proxy_pass http://www;

          proxy_set_header HOST $host;

          proxy_set_header X-Real-IP $remote_addr;

          proxy_set_header X-Forwarded-FOR $proxy_add_x_forwarded_for;

          }

          error_page 404 /404.html;

          location=/404.html {

          root /usr/share/nginx/html;

          }

          }

          第三種:Nginx解析php代碼的錯誤頁面

          如果后端是php解析的,需要加一個變量

          在http段中加一個變量 fastcgi_intercept_errors on 就可以了。

          指定一個錯誤頁面:

          error_page 404 /404.html;

          location=/404.html {

          root /usr/share/nginx/html;

          }

          指定一個url地址:

          error_page 404 /404.html;

          error_page 404=http://www.test.com/error.html;

          、nginx在安裝好之后,默認訪問端口是80,訪問路徑是/usr/share/nginx/html中的html頁面,訪問方式是ip地址直接訪問。關于安裝,小編的《云服務器環境搭建中的nginx部分》一文中有說到過。

          2、域名需要解析成功后才可以操作,域名解析只可以定向到ip地址,端口則無法同時關聯到。關于解析,在《對于云服務器環境搭建中的問題小結》一文中也做了說明。配置ip+端口=域名,則只需在location中添加proxy_pass即可,具體值則為域名/ip地址+端口號即可。然后直接域名訪問即可。

          3、域名解析后,訪問域名下載服務器上指定的文件,在location中作如下配置即可。其中,root為文件所在絕對路徑,index則是默認訪問的文件。域名訪問會下載該文件。

          4、關于php+nginx的相關配置,后文中再做提及,作為單獨一篇仔細講解。


          主站蜘蛛池模板: 久久久久人妻一区精品性色av| 国产av成人一区二区三区| 国产乱码精品一区二区三区四川 | 精品人妻一区二区三区浪潮在线| 亚洲av无码片区一区二区三区| 国产拳头交一区二区| 97久久精品一区二区三区| 丝袜无码一区二区三区| 男人的天堂亚洲一区二区三区 | 日本不卡一区二区三区| 国产乱码伦精品一区二区三区麻豆| 无码少妇丰满熟妇一区二区| 日韩精品一区二区三区老鸭窝| 色噜噜狠狠一区二区| 亚洲日韩AV无码一区二区三区人| 日韩亚洲一区二区三区| 亚洲国产视频一区| AV天堂午夜精品一区二区三区| 国精产品一区一区三区有限公司| 亚洲国产美女福利直播秀一区二区| 亚洲一区免费视频| 日本在线观看一区二区三区| 国产一区二区视频在线播放| 久久亚洲一区二区| 日本一区二区三区不卡视频| 香蕉久久ac一区二区三区| 国产成人高清视频一区二区 | 亚洲日本精品一区二区| 69久久精品无码一区二区| 国产在线一区二区三区在线| 国产福利91精品一区二区| 武侠古典一区二区三区中文| 久久久久人妻精品一区蜜桃| 成人在线观看一区| 国产精品高清一区二区三区| 国产AV一区二区精品凹凸 | 国产成人精品无码一区二区| 国产精品亚洲综合一区在线观看 | 国模少妇一区二区三区| 日韩精品一区二区三区中文版| 中文字幕一区二区人妻|