配置模板
```
#user nobody;
worker_processes 1;
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid logs/nginx.pid;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
#access_log logs/access.log main;
sendfile on;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
#gzip on;
server {
listen 80;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
root html;
index index.html index.htm;
}
#error_page 404 /404.html;
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
# proxy the PHP scripts to Apache listening on 127.0.0.1:80
#
#location ~ \.php$ {
# proxy_pass http://127.0.0.1;
#}
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
#location ~ \.php$ {
# root html;
# fastcgi_pass 127.0.0.1:9000;
# fastcgi_index index.php;
# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
# include fastcgi_params;
#}
# deny access to .htaccess files, if Apache's document root
# concurs with nginx's one
#
#location ~ /\.ht {
# deny all;
#}
}
# another virtual host using mix of IP-, name-, and port-based configuration
#
#server {
# listen 8000;
# listen somename:8080;
# server_name somename alias another.alias;
# location / {
# root html;
# index index.html index.htm;
# }
#}
# HTTPS server
#
#server {
# listen 443 ssl;
# server_name localhost;
# ssl_certificate cert.pem;
# ssl_certificate_key cert.key;
# ssl_session_cache shared:SSL:1m;
# ssl_session_timeout 5m;
# ssl_ciphers HIGH:!aNULL:!MD5;
# ssl_prefer_server_ciphers on;
# location / {
# root html;
# index index.html index.htm;
# }
#}
}
```
# 概述 參考來源:[https://baijiahao.baidu.com/s?id=1604485941272024493&wfr=spider&for=pc](https://baijiahao.baidu.com/s?id=1604485941272024493&wfr=spider&for=pc)
在前面《Nginx服務器開箱體驗》 一文中我們從開箱到體驗,感受了一下Nginx服務器的魅力。Nginx是輕量級的高性能Web服務器,提供了諸如HTTP代理和反向代理、負載均衡、緩存等一系列重要特性,因而在實踐之中使用廣泛,筆者也在學習和實踐之中。
在本文中,我們繼續延續前文,從前文給出的一份示例配置清單開始,詳解一下Nginx服務器的各種配置指令的作用和用法。
看到了下文中的包含了“小豬佩琪色” 的配圖了嗎,嘿嘿,我們開始吧!
Nginx配置文件的整體結構
圖片來自學習筆記Blog【imydl.tech】
從圖中可以看出主要包含以下幾大部分內容:
1\. 全局塊
該部分配置主要影響Nginx全局,通常包括下面幾個部分:
配置運行Nginx服務器用戶(組)worker process數Nginx進程PID存放路徑錯誤日志的存放路徑配置文件的引入
2\. events塊
該部分配置主要影響Nginx服務器與用戶的網絡連接,主要包括:
設置網絡連接的序列化是否允許同時接收多個網絡連接事件驅動模型的選擇最大連接數的配置
3\. http塊
定義MIMI-Type自定義服務日志允許sendfile方式傳輸文件連接超時時間單連接請求數上限
4\. server塊
配置網絡監聽基于名稱的虛擬主機配置基于IP的虛擬主機配置
5\. location塊
location配置請求根目錄配置更改location的URI網站默認首頁配置
配置清單例析
筆者按照文章:《Nginx服務器開箱體驗》 中的實驗,給出了一份簡要的清單配置舉例:
圖片來自學習筆記Blog【imydl.tech】
配置代碼如下:
user nobody nobody;worker\_processes3;error\_log logs/error.log;pid logs/nginx.pid;events { useepoll; worker\_connections1024;}http { include mime.types; default\_type application/octet-stream; log\_format main '$remote\_addr - $remote\_user \[$time\_local\] "$request" ''$status$body\_bytes\_sent "$http\_referer" ''"$http\_user\_agent" "$http\_x\_forwarded\_for"'; access\_log logs/access.log main; sendfileon; keepalive\_timeout65; server { listen8088; server\_name codesheep; access\_log /codesheep/webserver/server1/log/access.log; error\_page404 /404.html; location /server1/location1 { root /codesheep/webserver; index index.server2-location1.htm; } location /server1/location2 { root /codesheep/webserver; index index.server2-location2.htm; } } server { listen8089; server\_name192.168.31.177; access\_log /codesheep/webserver/server2/log/access.log; error\_page404 /404.html; location /server2/location1 { root /codesheep/webserver; index index.server2-location1.htm; } location /srv2/loc2 { alias /codesheep/webserver/server2/location2/; index index.server2-location2.htm; } location = /404.html { root /codesheep/webserver/; index404.html; } }}
接下來就來詳細剖析以下配置文件中各個指令的含義
配置運行Nginx服務器用戶(組)
指令格式:
user user \[group\];
user:指定可以運行Nginx服務器的用戶group:可選項,可以運行Nginx服務器的用戶組
如果user指令不配置或者配置為
user nobody nobody
,則默認所有用戶都可以啟動Nginx進程
worker process數配置
Nginx服務器實現并發處理服務的關鍵,指令格式:
worker\_processes number | auto;
number:Nginx進程最多可以產生的worker process數auto:Nginx進程將自動檢測
按照上文中的配置清單的實驗,我們給worker\_processes配置的數目是:3,啟動Nginx服務器后,我們可以后臺看一下主機上的Nginx進程情況:
ps -aux | grep nginx
很明顯,理解 worker\_processes 這個指令的含義就很容易了
圖片來自學習筆記Blog【imydl.tech】
Nginx進程PID存放路徑
Nginx進程是作為系統守護進程在運行,需要在某文件中保存當前運行程序的主進程號,Nginx支持該保存文件路徑的自定義
指令格式:
pid file;
file:指定存放路徑和文件名稱如果不指定默認置于路徑 logs/nginx.pid
錯誤日志的存放路徑
指定格式:
error\_log file | stderr;
file:日志輸出到某個文件filestderr:日志輸出到標準錯誤輸出
配置文件的引入
指令格式:
include file;
該指令主要用于將其他的Nginx配置或者第三方模塊的配置引用到當前的主配置文件中
設置網絡連接的序列化
指令格式:
accept\_mutex on | off;
該指令默認為on狀態,表示會對多個Nginx進程接收連接進行序列化,防止多個進程對連接的爭搶。
說到該指令,首先得闡述一下什么是所謂的 “驚群問題”,可以參考 WIKI百科的解釋。就Nginx的場景來解釋的話大致的意思就是:當一個新網絡連接來到時,多個worker進程會被同時喚醒,但僅僅只有一個進程可以真正獲得連接并處理之。如果每次喚醒的進程數目過多的話,其實是會影響一部分性能的。
所以在這里,如果accept\_mutex on,那么多個worker將是以串行方式來處理,其中有一個worker會被喚醒;反之若accept\_mutex off,那么所有的worker都會被喚醒,不過只有一個worker能獲取新連接,其它的worker會重新進入休眠狀態
這個值的開關與否其實是要和具體場景掛鉤的。
是否允許同時接收多個網絡連接
指令格式:
multi\_accept on | off;
該指令默認為off狀態,意指每個worker process 一次只能接收一個新到達的網絡連接。若想讓每個Nginx的workerprocess都有能力同時接收多個網絡連接,則需要開啟此配置
事件驅動模型的選擇
指令格式:
use model;
model模型可選擇項包括:select、poll、kqueue、epoll、rtsig等......
最大連接數的配置
指令格式:
worker\_connections number;
number默認值為512,表示允許每一個worker process可以同時開啟的最大連接數
定義MIME-Type
\*\*指令格式:
include mime.types;
default\_type mime-type;
\*\*
MIME-Type指的是網絡資源的媒體類型,也即前端請求的資源類型include指令將mime.types文件包含進來
cat mime.types
來查看mime.types文件內容,我們發現其就是一個types結構,里面包含了各種瀏覽器能夠識別的MIME類型以及對應類型的文件后綴名字,如下所示:
圖片來自學習筆記Blog【imydl.tech】
自定義服務日志
指令格式:
access\_log path \[format\];
path:自定義服務日志的路徑 + 名稱format:可選項,自定義服務日志的字符串格式。其也可以使用 log\_format 定義的格式
允許sendfile方式傳輸文件
\*\*指令格式:
sendfile on | off;
sendfile\_max\_chunk size;
\*\*
前者用于開啟或關閉使用sendfile()傳輸文件,默認off后者指令若size>0,則Nginx進程的每個workerprocess每次調用sendfile()傳輸的數據了最大不能超出此值;若size=0則表示不限制。默認值為0
連接超時時間配置
指令格式:
keepalive\_timeout timeout \[header\_timeout\];
timeout 表示server端對連接的保持時間,默認75秒header\_timeout 為可選項,表示在應答報文頭部的 Keep-Alive 域設置超時時間:“Keep-Alive :timeout = header\_timeout”
單連接請求數上限
指令格式:
keepalive\_requests number;
該指令用于限制用戶通過某一個連接向Nginx服務器發起請求的次數
配置網絡監聽
\*\*指令格式:第一種:配置監聽的IP地址:
listen IP\[:PORT\];
第二種:配置監聽的端口:
listen PORT;
\*\*
實際舉例:
listen192.168.31.177:8080; # 監聽具體IP和具體端口上的連接listen192.168.31.177; # 監聽IP上所有端口上的連接listen8080; # 監聽具體端口上的所有IP的連接
基于名稱和IP的虛擬主機配置
指令格式:
server\_name name1 name2 ...
name可以有多個并列名稱,而且此處的name支持正則表達式書寫
實際舉例:
server\_name ~^www\\d+\\.myserver\\.com$
此時表示該虛擬主機可以接收類似域名
www1.myserver.com
等的請求而拒絕
www.myserver.com
的域名請求,所以說用正則表達式可以實現更精準的控制
至于基于IP的虛擬主機配置比較簡單,不再太贅述:
指令格式:
server\_name IP地址
location配置
指令格式為:
location \[ = | ~ | ~\* | ^~ \] uri {...}
這里的uri分為標準uri和正則uri,兩者的唯一區別是uri中是否包含正則表達式
uri前面的方括號中的內容是可選項,解釋如下:
“=”:用于標準uri前,要求請求字符串與uri嚴格匹配,一旦匹配成功則停止“~”:用于正則uri前,并且區分大小寫“~\*”:用于正則uri前,但不區分大小寫“^~”:用于標準uri前,要求Nginx找到標識uri和請求字符串匹配度最高的location后,立即使用此location處理請求,而不再使用location塊中的正則uri和請求字符串做匹配
請求根目錄配置
指令格式:
root path;
path:Nginx接收到請求以后查找資源的根目錄路徑
當然,還可以通過alias指令來更改location接收到的URI請求路徑,指令為:
alias path;
\# path為修改后的根路徑
設置網站的默認首頁
指令格式:
index file ......
file可以包含多個用空格隔開的文件名,首先找到哪個頁面,就使用哪個頁面響應請求
- 常見功能
- 第三方授權登錄
- 郵件發送
- 簡易聊天室
- 獲取各國匯率
- PHP獲取服務器硬件指標
- 數據上報之
- web開發
- 開發規范
- 前端
- 踩坑
- 將footer固定在底部
- bootstrap
- Metronic
- 用到的jquery插件
- bootstrap-hover-dropdown
- jquery.slimscroll
- jquery.blockui
- bootstrap-switch
- js.cookie
- moment
- bootstrap-daterangepicker
- morris
- raphael
- jquery.waypoints
- jquery.counterup
- select2
- 取值和設置默認值
- vue
- axios
- 瀏覽器
- 谷歌瀏覽器
- 谷歌插件
- layui
- layui-表格
- layui-表單
- layui-彈窗
- layui-分頁
- 后端
- 操作系統
- linux
- 用戶管理
- 文件管理
- 目錄管理
- 壓縮和解壓縮
- 進程查看
- 端口查看
- 開機自啟動服務
- 定時任務
- shell腳本
- 殺掉運行超過指定時長指定服務的進程
- 獲取服務器使用狀態
- bash-shell連接socket
- 自定義快捷命令
- centos-踩坑
- 防火墻
- 軟件
- yum
- vim
- screen
- window
- 語言
- PHP
- 配置優化
- 框架
- thinkphp5.1+
- think命令行
- laravel6.+
- 維護模式
- 根據環境讀取不同配置
- laravel6.+采坑
- laravel坑位
- 數據庫事務
- 任務調度
- 文件權限問題
- 增強框架
- larvel:elastic-search
- 圖形驗證碼
- laravel獲取ip
- 函數
- strtotime
- 正則匹配
- 類
- 接口類與抽象類
- 類相關的關鍵字 - abstract
- 類相關的關鍵字 - interface
- PHP有關類的調用方式"->"與"::"的區別
- 擴展
- 問題歸納
- json_encode和json_decode
- 字符串的運算
- curl
- 優化php效率
- 數組相加合并與array_merge
- 時區轉換
- 不常用特性
- php反射
- 包管理器-composer
- GuzzleHttp
- Python
- Go
- 數據庫
- Redis
- 安裝
- 本地化-數據備份
- php-redis操作
- Mysql
- mysql-命令集合
- 設置終端可訪問
- 數據庫設計
- 用戶基礎信息表
- 踩坑集合
- mysql-2002
- mysql-2054
- 優化策略
- mysql-密碼驗證插件
- 一些牛逼的sql查詢
- topN
- 無限級分類
- Memcache
- MongoDb
- 安裝mongo-server
- 安裝php-mongodb擴展
- 在laravel中使用mongoDB
- 客戶端軟件
- Hbase
- Elasticsearch
- elastic-search
- restfulApi操作es
- web服務器
- 1.nginx
- 配置語法規則
- 配置詳解
- rewrite規則
- request_filename
- 2.apache
- 功能設計
- 加密解密
- Base64
- 對亞馬遜SKU加密
- 兼職項目中的加解密
- 騰訊外包時的加密
- 接口設計
- 接口限流設計
- 分庫分表
- 遍歷展示文件目錄結構
- 時區換算
- 文件切割
- 解析xml字符串
- 項目
- 博客后臺管理
- 亞馬遜廣告API
- 官方指引文檔
- 開發人員中心
- 應用商店
- 第三方庫
- 申請API郵件記錄
- 亞馬遜MWS
- 付款報告
- 亂碼
- 亞馬遜管理庫存報告
- 報告
- 商品
- 入庫
- 履行
- 出庫
- 財務
- 訂單
- 異步任務處理
- 集群如何同步代碼
- 基本開發流程
- 文檔管理
- showdoc
- 運行環境
- 開發環境
- vagrant
- windows上配置安裝
- vagrant安裝插件緩慢
- 更換ssh默認端口映射
- 設置x-shell密碼登錄
- 使用市場的box-homestead
- homestead-7: Box 'lc/homestead'
- 常見問題
- 虛擬環境reboot
- 突然無法使用
- phpStudy
- wamp
- 壓測性能
- VPN
- vultr
- 凌空圖床
- 寶塔
- 自動化部署
- 版本管理軟件鉤子
- 線上環境-LNMP
- centos7
- nginx
- mysql
- mysql開機自啟
- mysql-更換默認端口
- datetime字段類型默認值
- php
- php擴展安裝
- redis
- swoole
- gd
- BCMath
- igbinary
- zstd
- 包管理器:composer
- 優化性能
- nodejs
- 更新gcc版本
- 版本控制
- git
- 常用命令
- gitlab
- 版本管理規范
- 使用阿里云創建遠程倉庫
- git自動化部署
- svn
- 忽略指定文件
- 拉取代碼
- 自動化運維
- jekins
- 容器
- 集群
- 架構設計
- 設計原則
- 閱讀參考
- 代碼規劃
- 架構實戰
- 服務治理
- 權限控制設計
- 具體設計
- 計劃
- 疑問知識點
- 讀書筆記
- 高性能Mysql
- TCP-IP詳解-卷一:協議
- 思考
- php如何實現并發執行
- 對接調用設計
- 如何在瀏覽器上實現插件
- 如何設計一個app結合業務告警
- mysql的where查詢沒有用到索引
- 為啥in查詢比循環嵌套sql的查詢還要慢
- 使用git來創建屬于自己的composer包
- 翻頁獲取數據的時候又新增了數據
- 安全思路
- 月報
- PHP ?? 和 ?: 的區別
- PHP異步執行
- redis集群的目標是什么
- 大文件數據處理
- 性能瓶頸分析
- 命令行里輸出帶顏色的字體
- 面試問題合集
- 基礎
- 安全
- 算法
- 冒泡排序
- 快速排序
- 二分法查詢數組指定成員
- 字符查找匹配
- 令牌桶
- 漏桶
- 計數器
- 代理
- 協議
- http
- 狀態碼
- tcp
- udp
- Oauth2.0
- 設計模式
- 單例模式
- 適配器模式
- 工廠模式
- 觀察者模式
- 流程化
- 地址欄輸入網址到返回網頁的流程
- 題目收集
- 工具
- rabbitMq
- rabbitMQ用戶管理
- 生產者
- 消費者
- 支持TP5.*的think-queue
- 消息丟失
- 消費者報錯
- rabbitMQ配置優化
- 磁盤滿載導致服務掛掉
- PHP類庫
- rabbitMQ踩坑
- navicat
- vscode
- phpstorm
- 激活碼
- markdown
- PHP自定義類庫
- 工具類
- 領導力
- 任務分配
- 代碼組織
- 不要重復
- 避免污染
- 接口定義規范
- 小業務需求
- 獲取充值面額組成
- 監控服務器CPU和內存
- shell腳本版本