底層: 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 主配置文件
nano /etc/nginx/conf.d/default.conf
# {
# 修改 第 8 行,將 root 后的路徑更改為新的 默認網站數據目錄
root /data/www;
# }
# 重新啟動 Nginx 服務
systemctl restart nginx.service
默認主頁文件
修改 默認網站 路徑
# 修改 Nginx 主配置文件
nano /etc/nginx/conf.d/default.conf
# {
# 修改 第 8 行,將 listen 后的端口更改為新的 默認網站 端口
listen 8081;
# }
# 防火墻放行 Nginx 8081 端口
sudo firewall-cmd --permanent --zone=public --add-port=8081/tcp
# 生效 防火墻策略
firewall-cmd --reload
# 重新啟動 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的相關配置,后文中再做提及,作為單獨一篇仔細講解。
*請認真填寫需求信息,我們會在24小時內與您取得聯系。