欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

寫給前端的nginx配置指南基于docker所有配置秒級(jí)運(yùn)行(最新講解)

 更新時(shí)間:2022年06月07日 10:35:24   作者:程序員山月  
這篇文章主要介紹了寫給前端的nginx配置指南基于docker所有配置秒級(jí)運(yùn)行,通過(guò)?docker?高效學(xué)習(xí)?nginx?配置,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下

三年經(jīng)驗(yàn)的前端或多或少與 nginx 配置打過(guò)交道。

nginx 的重要性不言而喻。

本篇文章以前端的視角,介紹下 nginx 的常見(jiàn)配置。

通過(guò) docker 高效學(xué)習(xí) nginx 配置

推薦一種高效學(xué)習(xí) nginx 的方法: 在本地使用 nginx 鏡像并掛載 nginx 配置啟動(dòng)容器。

通過(guò)以下 docker-compose 可秒級(jí)驗(yàn)證 nginx 配置,無(wú)疑是學(xué)習(xí) nginx 的絕佳利器。

我將所有關(guān)于 nginx 的配置放置在 simple-deploy,并且每一份配置對(duì)應(yīng) docker compose 中的一個(gè) service,如以下 nginx、location、order1 就是 service。

version: "3"
services:
  # 關(guān)于 nginx 最常見(jiàn)配置的學(xué)習(xí)
  nginx:
    image: nginx:alpine
    ports:
      - 8080:80
    volumes:
      - ./nginx.conf:/etc/nginx/conf.d/default.conf
      - .:/usr/share/nginx/html
  # 關(guān)于 location 的學(xué)習(xí)
  location: ...
  # 關(guān)于 location 匹配順序的學(xué)習(xí)
  order1: ...

每次修改配置時(shí),需要重啟容器,可根據(jù)服務(wù)名學(xué)習(xí)指定內(nèi)容。

$ docker-compose up <service>
# 學(xué)習(xí) nginx 最基礎(chǔ)的配置
$ docker-compose up nginx
# 學(xué)習(xí)關(guān)于 location 的配置
$ docker-compose up location

本篇文章所有的 nginx 配置均可以通過(guò) docker 來(lái)進(jìn)行學(xué)習(xí),并附全部代碼及配置。

root 與 index

  • root: 靜態(tài)資源的根路徑。見(jiàn)文檔 nginx.org/en/docs/htt…
  • index: 當(dāng)請(qǐng)求路徑以 / 結(jié)尾時(shí),則自動(dòng)尋找該路徑下的 index 文件。見(jiàn)文檔 nginx.org/en/docs/htt…

rootindex 為前端部署的基礎(chǔ),在默認(rèn)情況下 root 為 /usr/share/nginx/html,因此我們部署前端時(shí),往往將構(gòu)建后的靜態(tài)資源目錄掛載到該地址。

server {
    listen       80;
    server_name  localhost;
    root   /usr/share/nginx/html;
    index  index.html index.htm;
}

location

location 用以匹配路由,配置語(yǔ)法如下。

location [ = | ~ | ~* | ^~ ] uri { ... }

其中 uri 前可提供以下修飾符

  • = 精確匹配。優(yōu)先級(jí)最高
  • ^~ 前綴匹配,優(yōu)先級(jí)其次
  • ~ 正則匹配,優(yōu)先級(jí)再次 (~* 只是不區(qū)分大小寫,不單列)
  • / 通用匹配,優(yōu)先級(jí)再次

為了驗(yàn)證所匹配的 location,我會(huì)在以下示例中添加一個(gè)自定義響應(yīng)頭 X-Config,可通過(guò)瀏覽器控制臺(tái)網(wǎng)絡(luò)面板驗(yàn)證其響應(yīng)頭。

add_header X-Config B;

注意,我所有配置文件中的鏈接可直接點(diǎn)擊,避免了在 compose 配置文件中尋找映射端口號(hào)的不方便。

location 修飾符驗(yàn)證

對(duì)于此四種修飾符可以在我的 nginx 下進(jìn)行驗(yàn)證。

由于此處使用了 proxy_pass,因此需要 location2,api 兩個(gè)服務(wù)一起啟動(dòng),在 location2 服務(wù)中,可直接通過(guò) service 名稱作為 hostname 即 http://api:3000 訪問(wèn) api 服務(wù)。

而 api 服務(wù),為我自己寫的一個(gè) whoami 服務(wù),用以打印出請(qǐng)求路徑等信息,詳見(jiàn) shfshanyue/whoami。

$ docker-compose up location2 api

以下是關(guān)于驗(yàn)證 location 的配置文件,詳見(jiàn) shfshanyue/simple-daploy:learn-nginxs

server {
    listen       80;
    server_name  localhost;
    root   /usr/share/nginx/html;
    index  index.html index.htm;
    # 通用匹配,所有 /xxx 任意路徑都會(huì)匹配其中的規(guī)則
    location / {
        add_header X-Config A;
        try_files  $uri $uri.html $uri/index.html /index.html;
    }
    # http://localhost:8120/test1           ok
    # http://localhost:8120/test1/          ok
    # http://localhost:8120/test18          ok
    # http://localhost:8120/test28          not ok
    location /test1 {
        # 可通過(guò)查看響應(yīng)頭來(lái)判斷是否成功返回
        add_header X-Config B;
        proxy_pass http://api:3000;
    }
    # http://localhost:8120/test2           ok
    # http://localhost:8120/test2/          not ok
    # http://localhost:8120/test28          not ok
    location = /test2 {
        add_header X-Config C;
        proxy_pass http://api:3000;
    }
    # http://localhost:8120/test3           ok
    # http://localhost:8120/test3/          ok
    # http://localhost:8120/test38          ok
    # http://localhost:8120/hellotest3      ok
    location ~ .*test3.* {
        add_header X-Config D;
        proxy_pass http://api:3000;
    }
    # http://localhost:8120/test4           ok
    # http://localhost:8120/test4/          ok
    # http://localhost:8120/test48          ok
    # http://localhost:8120/test28          not ok
    location ^~ /test4 {
        # 可通過(guò)查看響應(yīng)頭來(lái)判斷是否成功返回
        add_header X-Config E;
        proxy_pass http://api:3000;
    }
}

location 優(yōu)先級(jí)驗(yàn)證

在我配置文件中,以 order 打頭來(lái)命名所有優(yōu)先級(jí)驗(yàn)證的 nginx 配置,此處僅僅以 order1 為例進(jìn)行驗(yàn)證。

配置如下:

# 以下配置,訪問(wèn)以下鏈接,其 X-Config 為多少
#
# http://localhost:8210/shanyue,為 B,若都是前綴匹配,則找到最長(zhǎng)匹配的 location
server {
    root   /usr/share/nginx/html;
    # 主要是為了 shanyue 該路徑,因?yàn)闆](méi)有后綴名,無(wú)法確認(rèn)其 content-type,會(huì)自動(dòng)下載
    # 因此這里采用 text/plain,則不會(huì)自動(dòng)下載
    default_type text/plain;
    location ^~ /shan {
        add_header X-Config A;
    }
    location ^~ /shanyue {
        add_header X-Config B;
    }
}

啟動(dòng)服務(wù):

$ docker-compose up order1

curl 驗(yàn)證:

當(dāng)然也可以通過(guò)瀏覽器控制臺(tái)網(wǎng)絡(luò)面板驗(yàn)證,由于此處只需要驗(yàn)證響應(yīng)頭,則我們通過(guò) curl --head 只發(fā)送 head 請(qǐng)求即可。

# 查看其 X-Config 為 B
$ curl --head http://localhost:8210/shanyue
HTTP/1.1 200 OK
Server: nginx/1.21.4
Date: Fri, 03 Jun 2022 10:15:11 GMT
Content-Type: text/plain
Content-Length: 15
Last-Modified: Thu, 02 Jun 2022 12:44:23 GMT
Connection: keep-alive
ETag: "6298b0a7-f"
X-Config: B
Accept-Ranges: bytes

proxy_pass

proxy_pass 反向代理,也是 nginx 最重要的內(nèi)容,這也是常用的解決跨域的問(wèn)題。

當(dāng)使用 proxy_pass 代理路徑時(shí),有兩種情況

  • 代理服務(wù)器地址不含 URI,則此時(shí)客戶端請(qǐng)求路徑與代理服務(wù)器路徑相同。強(qiáng)烈建議這種方式
  • 代理服務(wù)器地址含 URI,則此時(shí)客戶端請(qǐng)求路徑匹配 location,并將其 location 后的路徑附在代理服務(wù)器地址后。
# 不含 URI
proxy_pass http://api:3000;
# 含 URI
proxy_pass http://api:3000/;
proxy_pass http://api:3000/api;
proxy_pass http://api:3000/api/;

再舉一個(gè)例子:

location /api3 {
    add_header X-Config C;
    # http://localhost:8300/api3/hello -> proxy:3000/hello/hello
    proxy_pass http://api:3000/hello;
}

有點(diǎn)拗口,在我們?cè)囼?yàn)環(huán)境有多個(gè)示例,使用以下代碼啟動(dòng)可反復(fù)測(cè)試:

$ docker-compose up proxy api

由于 proxy_pass 所代理的服務(wù)為 whoami,可打印出真實(shí)請(qǐng)求路徑,可根據(jù)此進(jìn)行測(cè)試

server {
    listen       80;
    server_name  localhost;
    root   /usr/share/nginx/html;
    index  index.html index.htm;
    # 建議使用此種 proxy_pass 不加 URI 的寫法,原樣路徑即可
    # http://localhost:8300/api1/hello -> proxy:3000/api1/hello
    location /api1 {
        # 可通過(guò)查看響應(yīng)頭來(lái)判斷是否成功返回
        add_header X-Config A;
        proxy_pass http://api:3000;
    }
    # http://localhost:8300/api2/hello -> proxy:3000/hello
    location /api2/ {
        add_header X-Config B;
        proxy_pass http://api:3000/;
    }
    # http://localhost:8300/api3/hello -> proxy:3000/hello/hello
    location /api3 {
        add_header X-Config C;
        proxy_pass http://api:3000/hello;
    }
    # http://localhost:8300/api4/hello -> proxy:3000//hello
    location /api4 {
        add_header X-Config D;
        proxy_pass http://api:3000/;
    }
}

add_header

控制響應(yīng)頭。

由于很多特性都是通過(guò)響應(yīng)頭控制,因此基于此指令可做很多事情,比如:

  • Cache
  • CORS
  • HSTS
  • CSP
  • ...

Cache

location /static {
    add_header Cache-Control max-age=31536000;
}

CORS

location /api {
    add_header Access-Control-Allow-Origin *;
}
復(fù)制代碼

HSTS

location / {
    listen 443 ssl;
    add_header Strict-Transport-Security max-age=7200;
}

CSP

location / {
    add_header Content-Security-Policy "default-src 'self';";
}

作業(yè)

  • 初階: 基于 docker 學(xué)習(xí) nginx 配置,并可配置 index.html 強(qiáng)緩存 60s 時(shí)間
  • 高階: 基于 docker 學(xué)習(xí) nginx 配置,并可配置 gzip/brotli
  • 面試: brotli/gzip 有何區(qū)別

到此這篇關(guān)于寫給前端的nginx配置指南基于docker所有配置秒級(jí)運(yùn)行的文章就介紹到這了,更多相關(guān)docker  nginx 配置內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Docker學(xué)習(xí)筆記之容器查看啟動(dòng)終止刪除的方法

    Docker學(xué)習(xí)筆記之容器查看啟動(dòng)終止刪除的方法

    本篇文章主要Docker學(xué)習(xí)筆記之容器查看啟動(dòng)終止刪除的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-12-12
  • Docker私有倉(cāng)庫(kù)管理和刪除本地倉(cāng)庫(kù)中的鏡像

    Docker私有倉(cāng)庫(kù)管理和刪除本地倉(cāng)庫(kù)中的鏡像

    這篇文章主要介紹了Docker私有倉(cāng)庫(kù)管理和刪除本地倉(cāng)庫(kù)中的鏡像,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-01-01
  • Docker安裝Oracle_11g的方法

    Docker安裝Oracle_11g的方法

    這篇文章主要介紹了Docker安裝Oracle_11g的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-04-04
  • Docker 安裝 MySQL 并實(shí)現(xiàn)遠(yuǎn)程連接教程

    Docker 安裝 MySQL 并實(shí)現(xiàn)遠(yuǎn)程連接教程

    這篇文章主要介紹了Docker 安裝 MySQL 并實(shí)現(xiàn)遠(yuǎn)程連接的教程,幫助大家更好的理解和使用docker容器,感興趣的朋友可以了解下
    2020-09-09
  • Docker?容器連接的具體實(shí)現(xiàn)

    Docker?容器連接的具體實(shí)現(xiàn)

    本文主要介紹了Docker?容器連接的具體實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • 詳解Dockerfile 中的 COPY 與 ADD 命令

    詳解Dockerfile 中的 COPY 與 ADD 命令

    Dockerfile 中提供了兩個(gè)非常相似的命令 COPY 和 ADD,本文嘗試解釋這兩個(gè)命令的基本功能,以及其異同點(diǎn),然后總結(jié)其各自適合的應(yīng)用場(chǎng)景。感興趣的朋友跟隨小編一起看看吧
    2018-09-09
  • 關(guān)于Docker 刪除dead狀態(tài)的容器問(wèn)題及解決方案

    關(guān)于Docker 刪除dead狀態(tài)的容器問(wèn)題及解決方案

    這篇文章主要介紹了Docker 刪除dead狀態(tài)的容器,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-05-05
  • docker push遇到unknown blob問(wèn)題解決

    docker push遇到unknown blob問(wèn)題解決

    這篇文章主要為大家介紹了docker push遇到unknown blob問(wèn)題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-11-11
  • 淺談Docker數(shù)據(jù)持久化

    淺談Docker數(shù)據(jù)持久化

    這篇文章主要介紹了淺談Docker數(shù)據(jù)持久化,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-03-03
  • Ubuntu 16.04安裝使用Docker教程

    Ubuntu 16.04安裝使用Docker教程

    本篇文章主要介紹了Ubuntu 16.04安裝使用Docker教程,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-03-03

最新評(píng)論