背景:
最近搞了個專案,需要做檔案上傳,沒用fastdfs,沒用阿里oss,也沒有在專案開靜態資源訪問目錄,直接在系統上創建目錄,檔案上傳到該目錄,通過nginx代理,資料庫保存檔案存盤路徑,前端訪問檔案/圖片資源時,后端拼接nginx地址+檔案路徑回傳,
windows本地環境配置:
下載nginx軟體包并解壓,如:D:\dev\nginx-1.19.5

進入conf目錄修改nginx.conf檔案:
#user nobody;
worker_processes 1;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
server {
listen 8000;
server_name localhost;
location ~* \.(gif|jpg|jpeg|png|css|js|ico|cur|eot|ttf|woff2|svg|woff|pdf|doc|docx|xls|xlsx|txt|json|otf|csv)$ {
expires 24h;
root /home/tool_market/;#指定圖片存放路徑
access_log /home/tool_market/log;#圖片路徑
proxy_store on;
proxy_store_access user:rw group:rw all:rw;
proxy_temp_path /home/tool_market/;#圖片路徑
proxy_redirect off;
proxy_set_header Host 127.0.0.1;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
client_max_body_size 10m;
client_body_buffer_size 1280k;
proxy_connect_timeout 900;
proxy_send_timeout 900;
proxy_read_timeout 900;
proxy_buffer_size 40k;
proxy_buffers 40 320k;
proxy_busy_buffers_size 640k;
proxy_temp_file_write_size 640k;
#if ( !-e $request_filename)
#{
# proxy_pass http://127.0.0.1:8000; #代理訪問地址
#}
}
location ~* \.(htm|html)$ {
add_header Cache-Control no-store;
add_header Pragma no-cache;
root /home/tool_market/html/;
}
location / {
root html;
index index.html index.htm;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
}
配置了兩個訪問指定,一個處理圖片和office檔案等,訪問圖片時直接打開,訪問檔案則下載,
另一個處理html檔案,
啟動:
進入命令列,進入D:\dev\nginx-1.19.5目錄,直接輸入nginx.exe 回車即可
停止命令:
nginx.exe -s stop
瀏覽器訪問測驗:

訪問圖片檔案和html檔案測驗成功,
Linux使用docker配置:
先獲取鏡像:docker pull nginx
創建存盤目錄:
mkdir -p /home/tool_market/html
普通檔案存到/home/tool_market,html檔案存到/home/tool_market/html
docker中安裝的nginx,使用的是嵌套式的nginx配置,即主配置在/etc/nginx/nginx.conf中,server配置在/etc/nginx/conf.d中,
創建nginx目錄:
mkdir /home/docker_nginx
上傳nginx.conf檔案和server內容的nginx-file-server.conf檔案(名字自定義,docker run時指定即可)
nginx.conf檔案內容如下:
user root;
worker_processes 1;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
events {
worker_connections 1024;
}
http {
include /etc/nginx/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 /var/log/nginx/access.log main;
sendfile on;
keepalive_timeout 65;
include /etc/nginx/conf.d/*.conf;
}
nginx-file-server.conf檔案內容如下:
server {
listen 80;
server_name localhost;
charset utf-8; # 避免中文亂碼
location ~* \.(gif|jpg|jpeg|png|css|js|ico|cur|eot|ttf|woff2|svg|woff|pdf|doc|docx|xls|xlsx|txt|json|otf|csv)$ {
expires 24h;
root /data/;#指定圖片存放路徑
proxy_store on;
proxy_store_access user:rw group:rw all:rw;
proxy_temp_path /datat/;#圖片路徑
proxy_redirect off;
proxy_set_header Host 127.0.0.1;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
client_max_body_size 10m;
client_body_buffer_size 1280k;
proxy_connect_timeout 900;
proxy_send_timeout 900;
proxy_read_timeout 900;
proxy_buffer_size 40k;
proxy_buffers 40 320k;
proxy_busy_buffers_size 640k;
proxy_temp_file_write_size 640k;
#if ( !-e $request_filename)
#{
# proxy_pass http://127.0.0.1:8000; #代理訪問地址
#}
}
location ~* \.(htm|html)$ {
add_header Cache-Control no-store;
add_header Pragma no-cache;
root /data/html/;
}
location / {
root html;
index index.html index.htm;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
這里的存盤路徑配置的是docker容器里的,使用/data和/data/html(可自定義,docker run陳述句指定即可)
運行容器,陳述句如下:
docker run -d -p 8000:80 --name nginx \
-v /home/tool_market:/data \
-v /home/tool_market/html:/data/html \
-v /home/docker_nginx/nginx.conf:/etc/nginx/nginx.conf \
-v /home/docker_nginx/nginx-file-server.conf:/etc/nginx/conf.d/default.conf \
docker.io/nginx:latest
使用了8000埠映射容器內80埠
宿主機檔案目錄為/home/tool_market,映射容器內/data(和nginx-file-server.conf檔案內容對應)
并指定剛才上傳的兩個組態檔映射
docker ps 查看容器是否拉起成功:

上傳測驗圖片和html到宿主機存盤目錄進行測驗,并訪問瀏覽器:


訪問測驗成功,
轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/299958.html
標籤:其他
上一篇:青龍面板重啟后打不開的解決方案
下一篇:SLAM各種并行加速方法
