Windows下使用?Nginx?搭建?HTTP文件服務(wù)器?實(shí)現(xiàn)文件下載功能
WHAT IS THE NGINX ?
“Nginx 是一款輕量級(jí)的 HTTP 服務(wù)器,采用事件驅(qū)動(dòng)的異步非阻塞處理方式框架,這讓其具有極好的 IO 性能,時(shí)常用于服務(wù)端的反向代理和負(fù)載均衡。
它是由俄羅斯人 伊戈?duì)?middot;賽索耶夫?yàn)槎砹_斯訪問(wèn)量第二的 Rambler.ru 站點(diǎn)開發(fā)的,并于2004年首次公開發(fā)布的。
web服務(wù)器:負(fù)責(zé)處理和響應(yīng)用戶請(qǐng)求,一般也稱為http服務(wù)器,如 Apache、IIS、Nginx ? 應(yīng)用服務(wù)器:存放和運(yùn)行系統(tǒng)程序的服務(wù)器,負(fù)責(zé)處理程序中的業(yè)務(wù)邏輯,如 Tomcat、Weblogic、Jboss(現(xiàn)在大多數(shù)應(yīng)用服務(wù)器也包含了web服務(wù)器的功能)
Nginx 是什么,總結(jié)一下就是這些:
一種輕量級(jí)的web服務(wù)器
設(shè)計(jì)思想是事件驅(qū)動(dòng)的異步非阻塞處理(類node.js)
占用內(nèi)存少、啟動(dòng)速度快、并發(fā)能力強(qiáng)
使用C語(yǔ)言開發(fā)
擴(kuò)展性好,第三方插件非常多
在互聯(lián)網(wǎng)項(xiàng)目中廣泛應(yīng)用
WHY WE USE NGINX?
Nginx 是全球排名前三的服務(wù)WHY器,并且近年來(lái)用戶增長(zhǎng)非常快。
有人統(tǒng)計(jì),世界上約有三分之一的網(wǎng)址采用了Nginx。在大型網(wǎng)站的架構(gòu)中,Nginx被普遍使用,如 百度、阿里、騰訊、京東、網(wǎng)易、新浪、大疆等。
Nginx 安裝簡(jiǎn)單,配置簡(jiǎn)潔,作用卻無(wú)可替代。
HOW TO USE NGINX ?
下載 (通過(guò)連接或官網(wǎng)):
啟動(dòng)
windows 下 Nginx 基礎(chǔ)命令:
首先要使用 CMD 跳轉(zhuǎn)到 NGINX 安裝目錄下
啟動(dòng) Nginx:
start nginx
停止 Nginx:
nginx -s stop / nginx -s quit
熱重啟 Nginx:
nginx -s reload
強(qiáng)制停止 Nginx:
pkill -9 nginx
修改配置
打開 nginx.conf
找到第一個(gè) server { }
添加:
server {
? ? ? listen ? ? ? 8099; # 訪問(wèn)端口號(hào)
? ? ? server_name (你的主機(jī)IP) localhost;# 你的服務(wù)器名稱(訪問(wèn)名稱)
? ? ? root ? ? ? ? F:\Nginx_text; # 你需要在 NGINX 服務(wù)器上放置的文件目錄
? ? ? #autoindex for nginx
location ~ ^(.*)/$ {
? ? ? ? ? ? ? allow all;
? ? ? ? ? ? ? autoindex ? ? ? on; #開啟目錄瀏覽
? ? ? ? ? ? ? autoindex_localtime on; #以服務(wù)器的文件時(shí)間作為顯示的時(shí)間
? ? ? ? ? ? ? autoindex_exact_size off; #切換為 off 后,以可讀的方式顯示文件大小,單位為 KB、MB 或者 GB
? ? ? ? ? ? ? charset utf-8,gbk; #展示中文文件名
? ? ? #這一段是為了美化界面,需要先下載插件然后添加以下這行配置,不嫌丑的話直接注釋即可
? ? ? #add_after_body /.autoindex/footer.html;
? ? ? ? ? }
#location ~ ^/.(mp4|doc|pdf)$ { #默認(rèn)遇到.mp4以及.pdf格式會(huì)在瀏覽器中打開,可設(shè)置為點(diǎn)擊直接下載。
#添加這一段,點(diǎn)擊任何文件都是下載。
? ? ? ? ? location ~ ^/(.*)$ {
? ? ? ? ? ? ? add_header Content-Disposition "attachment; filename=$1"; ?
? ? ? ? ? }server{ } 其實(shí)是包含在 http{ } 內(nèi)部的。每一個(gè) server{ } 是一個(gè)虛擬主機(jī)(站點(diǎn))。
上面代碼塊的意思是:當(dāng)一個(gè)請(qǐng)求叫做 localhost:8099 請(qǐng)求nginx服務(wù)器時(shí),該請(qǐng)求就會(huì)被匹配進(jìn)該代碼塊的 server{ } 中執(zhí)行。
當(dāng)然 nginx 的配置非常多,用的時(shí)候可以根據(jù)文檔進(jìn)行配置。
英文文檔:nginx.org/en/docs/
中文文檔:www.nginx.cn/doc/
配置完成之后熱重啟一下就可以使用 你的主機(jī)IP + : + 端口號(hào)訪問(wèn) NGINX 服務(wù)器了

一些經(jīng)典的操作
快速部署靜態(tài)應(yīng)用
參考代碼:
server { ?
? ? ? listen ? ? ? 8080; ? ? ? ?
? ? ? server_name localhost;
?
? ? ? location / {
? ? ? ? ? # root ? html; # Nginx默認(rèn)路徑
? ? ? ? ? root /usr/local/var/www/my-project; # 設(shè)置為個(gè)人項(xiàng)目的根目錄路徑
? ? ? ? ? index index.html index.htm;
? ? ? }
}請(qǐng)求過(guò)濾
設(shè)置訪問(wèn)白名單
當(dāng)你的項(xiàng)目沒(méi)有灰度環(huán)境,又想在功能上線后先讓測(cè)試同事試用一下的時(shí)候,就需要設(shè)置訪問(wèn)的白名單了。
如果你的項(xiàng)目用上了 nginx 做代理,你就會(huì)發(fā)現(xiàn)這就是小菜一碟。
參考代碼:
server {
? ? ? listen ? ? ? 8080; ? ? ? ?
? ? ? server_name localhost;
?
? ? ? location / {
? ? ? ? ? # IP訪問(wèn)限制(只允許IP是 10.81.1.11 的機(jī)器才能訪問(wèn))
? ? ? ? ? allow 10.81.1.11;
? ? ? ? ? deny all;
? ? ? ? ? ?
? ? ? ? ? root ? html;
? ? ? ? ? index index.html index.htm;
? ? ? }
}配置圖片防盜鏈
參考代碼:
server {
listen 8080;
server_name localhost;
location / {
root /usr/local/var/www/my-project; # 設(shè)置為個(gè)人項(xiàng)目的根目錄路徑
index index.html index.htm;
}
# 圖片防盜鏈
location ~* \.(gif|jpg|jpeg|png|bmp|swf)$ {
valid_referers none blocked 192.168.0.103; # 只允許本機(jī)IP外鏈引用
if ($invalid_referer){
return 403;
}
}
}上面代碼塊設(shè)置了只允許本機(jī)IP外鏈引用圖片資源,其他域名下的請(qǐng)求都會(huì)被403禁止訪問(wèn)。
解決跨域
參考代碼:
server {
listen 8080;
server_name localhost;
location / {
# 跨域代理設(shè)置
proxy_pass http://www.proxy.com; # 要實(shí)現(xiàn)跨域的域名
add_header Access-Control-Allow-Origin *;
add_header Access-Control-Allow-Methods 'GET, POST, OPTIONS';
add_header Access-Control-Allow-Headers 'DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Authorization';
}
}思路就是在反向代理請(qǐng)求過(guò)程中,增加可以跨域訪問(wèn)的請(qǐng)求頭。
Nginx有哪些應(yīng)用?
動(dòng)靜分離

如上圖所示,動(dòng)靜分離其實(shí)就是 Nginx 服務(wù)器將接收到的請(qǐng)求分為動(dòng)態(tài)請(qǐng)求和靜態(tài)請(qǐng)求。
靜態(tài)請(qǐng)求直接從 nginx 服務(wù)器所設(shè)定的根目錄路徑去取對(duì)應(yīng)的資源,動(dòng)態(tài)請(qǐng)求轉(zhuǎn)發(fā)給真實(shí)的后臺(tái)(前面所說(shuō)的應(yīng)用服務(wù)器,如圖中的Tomcat)去處理。
這樣做不僅能給應(yīng)用服務(wù)器減輕壓力,將后臺(tái) api 接口服務(wù)化,還能將前后端代碼分開并行開發(fā)和部署。
server {
listen 8080;
server_name localhost;
location / {
root html; # Nginx默認(rèn)值
index index.html index.htm;
}
# 靜態(tài)化配置,所有靜態(tài)請(qǐng)求都轉(zhuǎn)發(fā)給 nginx 處理,存放目錄為 my-project
location ~ .*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|js|css)$ {
root /usr/local/var/www/my-project; # 靜態(tài)請(qǐng)求所代理到的根目錄
}
# 動(dòng)態(tài)請(qǐng)求匹配到path為'node'的就轉(zhuǎn)發(fā)到8002端口處理
location /node/ {
proxy_pass http://localhost:8002; # 充當(dāng)服務(wù)代理
}訪問(wèn)靜態(tài)資源 nginx 服務(wù)器會(huì)返回 my-project 里面的文件,如獲取 index.html:
訪問(wèn)動(dòng)態(tài)請(qǐng)求 nginx 服務(wù)器會(huì)將它從8002端口請(qǐng)求到的內(nèi)容,原封不動(dòng)的返回回去:
反向代理
反向代理是什么?
反向代理其實(shí)就類似你去找代購(gòu)幫你買東西(瀏覽器或其他終端向nginx請(qǐng)求),你不用管他去哪里買,只要他幫你買到你想要的東西就行(瀏覽器或其他終端最終拿到了他想要的內(nèi)容,但是具體從哪兒拿到的這個(gè)過(guò)程它并不知道)。
反向代理的作用
保障應(yīng)用服務(wù)器的安全(增加一層代理,可以屏蔽危險(xiǎn)攻擊,更方便的控制權(quán)限)
實(shí)現(xiàn)負(fù)載均衡(稍等~下面會(huì)講)
實(shí)現(xiàn)跨域(號(hào)稱是最簡(jiǎn)單的跨域方式)
配置反向代理
配置一個(gè)簡(jiǎn)單的反向代理是很容易的,代碼如下
server {
listen 8080;
server_name localhost;
location / {
root html; # Nginx默認(rèn)值
index index.html index.htm;
}
proxy_pass http://localhost:8000; # 反向代理配置,請(qǐng)求會(huì)被轉(zhuǎn)發(fā)到8000端口
}反向代理的表現(xiàn)很簡(jiǎn)單。那上面的代碼塊來(lái)說(shuō),其實(shí)就是向nginx請(qǐng)求localhost:8080跟請(qǐng)求http://localhost:8000是一樣的效果。(跟代購(gòu)的原理一樣)
這是一個(gè)反向代理最簡(jiǎn)單的模型,只是為了說(shuō)明反向代理的配置。但是現(xiàn)實(shí)中反向代理多數(shù)是用在負(fù)載均衡中。

nginx 就是充當(dāng)圖中的 proxy。左邊的3個(gè) client 在請(qǐng)求時(shí)向 nginx 獲取內(nèi)容,是感受不到3臺(tái) server 存在的。
此時(shí),proxy就充當(dāng)了3個(gè) server 的反向代理。
反向代理應(yīng)用十分廣泛,CDN 服務(wù)就是反向代理經(jīng)典的應(yīng)用場(chǎng)景之一。除此之外,反向代理也是實(shí)現(xiàn)負(fù)載均衡的基礎(chǔ),很多大公司的架構(gòu)都應(yīng)用到了反向代理。
負(fù)載均衡
負(fù)載均衡是什么?
隨著業(yè)務(wù)的不斷增長(zhǎng)和用戶的不斷增多,一臺(tái)服務(wù)已經(jīng)滿足不了系統(tǒng)要求了。這個(gè)時(shí)候就出現(xiàn)了服務(wù)器集群。
在服務(wù)器集群中,Nginx 可以將接收到的客戶端請(qǐng)求“均勻地”(嚴(yán)格講并不一定均勻,可以通過(guò)設(shè)置權(quán)重)分配到這個(gè)集群中所有的服務(wù)器上。這個(gè)就叫做負(fù)載均衡。
負(fù)載均衡的示意圖如下:

負(fù)載均衡的作用
分?jǐn)偡?wù)器集群壓力
保證客戶端訪問(wèn)的穩(wěn)定性
前面也提到了,負(fù)載均衡可以解決分?jǐn)偡?wù)器集群壓力的問(wèn)題。除此之外,Nginx還帶有健康檢查(服務(wù)器心跳檢查)功能,會(huì)定期輪詢向集群里的所有服務(wù)器發(fā)送健康檢查請(qǐng)求,來(lái)檢查集群中是否有服務(wù)器處于異常狀態(tài)。
一旦發(fā)現(xiàn)某臺(tái)服務(wù)器異常,那么在這以后代理進(jìn)來(lái)的客戶端請(qǐng)求都不會(huì)被發(fā)送到該服務(wù)器上(直健康檢查發(fā)現(xiàn)該服務(wù)器已恢復(fù)正常),從而保證客戶端訪問(wèn)的穩(wěn)定性。
配置負(fù)載均衡
配置一個(gè)簡(jiǎn)單的負(fù)載均衡并不復(fù)雜,代碼如下:
# 負(fù)載均衡:設(shè)置domain
upstream domain {
server localhost:8000;
server localhost:8001;
}
server {
listen 8080;
server_name localhost;
location / {
# root html; # Nginx默認(rèn)值
# index index.html index.htm;
proxy_pass http://domain; # 負(fù)載均衡配置,請(qǐng)求會(huì)被平均分配到8000和8001端口
proxy_set_header Host $host:$server_port;
}
}8000和8001是我本地用 Node.js 起的兩個(gè)服務(wù),負(fù)載均衡成功后可以看到訪問(wèn)localhost:8080有時(shí)會(huì)訪問(wèn)到8000端口的頁(yè)面,有時(shí)會(huì)訪問(wèn)到8001端口的頁(yè)面。
能看到這個(gè)效果,就說(shuō)明你配置的負(fù)載均衡策略生效了。
實(shí)際項(xiàng)目中的負(fù)載均衡遠(yuǎn)比這個(gè)案例要更加復(fù)雜,但是萬(wàn)變不離其宗,都是根據(jù)這個(gè)理想模型衍生出來(lái)的。
受集群?jiǎn)闻_(tái)服務(wù)器內(nèi)存等資源的限制,負(fù)載均衡集群的服務(wù)器也不能無(wú)限增多。但因其良好的容錯(cuò)機(jī)制,負(fù)載均衡成為了實(shí)現(xiàn)高可用架構(gòu)中必不可少的一環(huán)。
正向代理
正向代理跟反向道理正好相反。拿上文中的那個(gè)代購(gòu)例子來(lái)講,多個(gè)人找代購(gòu)購(gòu)買同一個(gè)商品,代購(gòu)找到買這個(gè)的店后一次性給買了。這個(gè)過(guò)程中,該店主是不知道代購(gòu)是幫別代買買東西的。那么代購(gòu)對(duì)于多個(gè)想買商品的顧客來(lái)講,他就充當(dāng)了正向代理。
正向代理的示意圖如下:

nginx 就是充當(dāng)圖中的 proxy。左邊的3個(gè) client 在請(qǐng)求時(shí)向 nginx 獲取內(nèi)容,server 是感受不到3臺(tái) client 存在的。
此時(shí),proxy 就充當(dāng)了3個(gè) client 的正向代理。
正向代理,意思是一個(gè)位于客戶端和原始服務(wù)器(origin server)之間的服務(wù)器,為了從原始服務(wù)器取得內(nèi)容,客戶端向代理發(fā)送一個(gè)請(qǐng)求并指定目標(biāo)(原始服務(wù)器),然后代理向原始服務(wù)器轉(zhuǎn)交請(qǐng)求并將獲得的內(nèi)容返回給客戶端??蛻舳瞬拍苁褂谜虼怼.?dāng)你需要把你的服務(wù)器作為代理服務(wù)器的時(shí)候,可以用Nginx來(lái)實(shí)現(xiàn)正向代理。
KX上網(wǎng)vpn(俗稱F墻)其實(shí)就是一個(gè)正向代理工具。
該 vpn 會(huì)將想訪問(wèn)墻外服務(wù)器 server 的網(wǎng)頁(yè)請(qǐng)求,代理到一個(gè)可以訪問(wèn)該網(wǎng)站的代理服務(wù)器 proxy 上。這個(gè) proxy 把墻外服務(wù)器 server 上獲取的網(wǎng)頁(yè)內(nèi)容,再轉(zhuǎn)發(fā)給客戶。
代理服務(wù)器 proxy 就是 Nginx 搭建的。
到此這篇關(guān)于Windows下使用 Nginx 搭建 HTTP文件服務(wù)器 實(shí)現(xiàn)文件下載功能的文章就介紹到這了,更多相關(guān)Windows使用 Nginx 搭建 HTTP文件服務(wù)器內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Nginx中配置開啟Nginx Status來(lái)查看服務(wù)器運(yùn)行狀態(tài)
這篇文章主要介紹了Nginx中配置開啟Nginx Status來(lái)查看服務(wù)器運(yùn)行狀態(tài)的方法,Nginx Status為Nginx服務(wù)器內(nèi)置的狀態(tài)頁(yè),需要的朋友可以參考下2016-01-01
配置解決Nginx服務(wù)器中WordPress路徑不自動(dòng)加斜杠問(wèn)題
這篇文章主要介紹了配置解決Nginx服務(wù)器中WordPress路徑不自動(dòng)加斜杠問(wèn)題,nginx不會(huì)自動(dòng)在請(qǐng)求的最后加上一個(gè)斜線的問(wèn)題文中也有提到通用的規(guī)則改寫方法,需要的朋友可以參考下2016-01-01
詳細(xì)聊聊K8s容器內(nèi)nginx帶變量的域名解析
這篇文章主要給大家介紹了關(guān)于K8s容器內(nèi)nginx帶變量域名的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-01-01
Nginx中禁止使用IP訪問(wèn)網(wǎng)站的配置實(shí)例
這篇文章主要介紹了Nginx中禁止使用IP訪問(wèn)網(wǎng)站的配置實(shí)例,一般在備案時(shí)可能需要這種設(shè)置,需要的朋友可以參考下2014-07-07
Mac上搭建nginx+rtmp直播服務(wù)器的步驟詳解
最近的直播很火,所以這篇文章跟大家分享了在Mac上搭建nginx+rtmp直播服務(wù)器的步驟,文章通過(guò)一步步圖文介紹的很詳細(xì),有需要的朋友們可以參考借鑒。2016-09-09
Nginx HTTP Status 400 – 錯(cuò)誤的請(qǐng)求問(wèn)題解決
本文主要介紹了在配置Nginx反向代理兩個(gè)Tomcat站點(diǎn)時(shí)遇到HTTPStatus400錯(cuò)誤,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2025-01-01
NGINX?權(quán)限控制文件預(yù)覽和下載的實(shí)現(xiàn)原理
我們知道,使用nginx作為文件下載服務(wù)器,可以極大地降低對(duì)后端Java服務(wù)器的負(fù)載沖擊,但是nginx本身并不提供授權(quán)控制,這下該如何操作呢,下面小編給大家?guī)?lái)了NGINX?權(quán)限控制文件預(yù)覽和下載的實(shí)現(xiàn)原理,感興趣的朋友跟隨小編一起看看吧2022-01-01

