整合營銷服務商

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

          免費咨詢熱線:

          網頁服務-Nginx - 修改默認網站存儲路徑

          本環境

          底層: Windows 11 x64
          虛擬化層:VMWare Workstation 17.0.2
          虛擬化兼容性:ESXi 6.7
          虛擬硬件:
              CPU: 4 Core
              RAM: 16 GB
              HDD: 128 GB SCSI
              NetWork: NAT
          操作系統版本: CentOS 7.9.2207 Mininal 無更新、無升級內核
                          無系統更新
                          無內核升級
                          關閉 SELinux
                          配置 NTP 時間同步
                          安裝 Open VM Tools
                          美化 CLI

          修改 默認網站 數據目錄

          創建 網站數據 目錄

          #    創建 新網站數據 目錄
          mkdir -p /data/www
          #    創建 新網站首頁
          echo "Welcom To FourLeaf Studio by SRover Lee <br> Web Data /data/www/" > /data/www/index.html

          修改 Nginx 配置文件

          #    修改 Nginx 主配置文件
          nano /etc/nginx/conf.d/default.conf
          #    {
          #    修改 第 8 行,將 root 后的路徑更改為新的 默認網站數據目錄
                  root   /data/www;
          #    }

          重新啟動 Nginx 服務

          #    重新啟動 Nginx 服務
          systemctl restart nginx.service

          默認主頁文件

          修改 默認網站 路徑

          修改 默認網站 端口

          修改 Nginx 配置文件

          #    修改 Nginx 主配置文件
          nano /etc/nginx/conf.d/default.conf
          #    {
          #    修改 第 8 行,將 listen 后的端口更改為新的 默認網站 端口
                  listen       8081;
          #    }

          Nginx 防火墻管理

          #    防火墻放行 Nginx 8081 端口
          sudo firewall-cmd --permanent --zone=public --add-port=8081/tcp
          #    生效 防火墻策略
          firewall-cmd --reload

          重新啟動 Nginx 服務

          #    重新啟動 Nginx 服務
          systemctl restart nginx.service

          修改端口后,不輸入端口

          修改端口后,輸入端口

          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在安裝好之后,默認訪問端口是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一区二区三区 | 国产一区二区三区夜色| 精品无码综合一区| av无码免费一区二区三区| 日韩一区二区在线视频| 一区二区高清视频在线观看| 欧洲精品无码一区二区三区在线播放 | 精品欧洲av无码一区二区| 99久久无码一区人妻a黑| 亚洲AV成人精品一区二区三区 | 亚洲另类无码一区二区三区| 亚洲区精品久久一区二区三区| 国产一区视频在线| 国产精品高清一区二区三区不卡| 亚洲国产情侣一区二区三区| 国产一区二区三区免费看| 精品成人av一区二区三区| 亚洲av午夜福利精品一区| 中文字幕无线码一区二区| 国产一国产一区秋霞在线观看| 久久国产精品一区免费下载| 亚洲AV无码第一区二区三区| 日美欧韩一区二去三区| 亚洲一区二区三区在线观看蜜桃| 麻豆国产在线不卡一区二区| 亚洲天堂一区二区| 国产在线步兵一区二区三区| 人妖在线精品一区二区三区| 好吊视频一区二区三区| 久久一区二区三区精华液使用方法 | 亚洲一区二区三区深夜天堂| 国产伦理一区二区三区| 国产伦精品一区二区三区视频猫咪 | 亚洲综合一区国产精品| 国产成人片视频一区二区| 精品无码一区二区三区水蜜桃| 人妻久久久一区二区三区|