日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長提供免費(fèi)收錄網(wǎng)站服務(wù),提交前請做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點(diǎn)擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

目錄
  • 前言
  • Docker安裝nginx服務(wù)
  • 動態(tài)配置nginx.conf
  • 總結(jié)

前言

前后端聯(lián)調(diào)接口時,經(jīng)常會用到nginx反向代理來解決跨域問題。部署時,同一份前端代碼有時候會根據(jù)開發(fā)環(huán)境不同,需要切換不同的后端接口地址進(jìn)行代理。 傳統(tǒng)方式是為每個環(huán)境都獨(dú)立部署一份nginx配置,但是多數(shù)情況下,這些配置里的內(nèi)容大體上相同,只有少數(shù)部分內(nèi)容需要修改,這時候我們就希望nginx配置能夠從docker中獲取環(huán)境變量,動態(tài)設(shè)置有差異的那部分配置。本文將以代理接口地址為例,介紹下解決方案

Docker安裝nginx服務(wù)

我們先從配置一份靜態(tài)的nginx環(huán)境開始。

  • 首先,找一個空文件夾,把前端項目打包后的dist文件夾拷貝到根目錄
  • 在根目錄下配置nginx.conf如下,代理接口的關(guān)鍵點(diǎn)在于proxy_pass:
server {
  listen 80;
  location / {
    root   /usr/share/nginx/html;
    index  index.html index.htm;
    try_files $uri $uri/ /index.html;
  }
  location /api/ {
    #這里假設(shè)接口地址為http://127.0.0.1:8081
    #前端以/api/開頭的接口將被代理到http://127.0.0.1:8081
    proxy_pass http://127.0.0.1:8081;
  }
}
  • 同時在根目錄下面創(chuàng)建一份Dockerfile文件,寫入以下內(nèi)容
# 拉取nginx鏡像
FROM nginx:stable-alpine
# 把本地的dist文件夾下所有內(nèi)容復(fù)制到/usr/share/nginx/html下
COPY dist/ /usr/share/nginx/html
COPY nginx.conf /etc/nginx/conf.d
# 暴露80端口
EXPOSE 80
# 將docker環(huán)境下的命令行路徑切換到/etc/nginx/conf.d下執(zhí)行
WORKDIR /etc/nginx/conf.d
# 此時相當(dāng)于在docker容器里的/etc/nginx/conf.d路徑下,運(yùn)行nginx命令
ENTRYPOINT nginx -g 'daemon off;'
  • 執(zhí)行docker build . -t my-nginx命令將本地資源打包成鏡像,鏡像名為my-nginx

  • 執(zhí)行docker run --name nginx-server -d -p 8080:8080 my-nginx運(yùn)行鏡像,--name nginx-server設(shè)置docker容器的名稱,-p 8080:8080指將容器內(nèi)8080端口映射到宿主機(jī)的8080端口,my-nginx就是之前打包好的鏡像

  • 這時瀏覽器打開http://localhost:8080進(jìn)行訪問,接口就被代理到了http://127.0.0.1:8081

動態(tài)配置nginx.conf

上一步我們使用靜態(tài)配置運(yùn)行了nginx服務(wù),現(xiàn)在我們來試試通過環(huán)境變量,動態(tài)注入nginx配置。

  • nginx.conf重命名為nginx.template(名字可以隨便起,不重命名也行,這里為了表示這是一個模板),修改內(nèi)容如下
server {
  listen 80;
  location / {
    root   /usr/share/nginx/html;
    index  index.html index.htm;
    try_files $uri $uri/ /index.html;
  }
  location /api/ {
    #使用變量替換具體的地址,或者用${URL_1}也行
    proxy_pass $URL_1;
  }
  location /login/ {
    #新增一個代理接口,方便演示注入多個變量,或者用${URL_2}也行
    proxy_pass $URL_2;
  }
}

2.同時Dockerfile也有修改一下

FROM nginx:stable-alpine
COPY dist/ /usr/share/nginx/html
#這里改成將nginx配置模板復(fù)制過去
COPY nginx.template /etc/nginx/conf.d
EXPOSE 80
WORKDIR /etc/nginx/conf.d
#添加環(huán)境變量的寫入
ENTRYPOINT envsubst '$URL_1 $URL_2'  < nginx.template > default.conf && cat default.conf && nginx -g 'daemon off;'

這里實現(xiàn)環(huán)境變量注入的核心原理是利用linux自帶的envsubst指令。envsubst '$URL_1 $URL_2' < nginx.template作用是取環(huán)境的$URL_1$URL_2(此處變量名也可以寫成${URL_2},與模板保持一致即可)的值注入到nginx.template模板里對應(yīng)的位置,然后后半句> default.conf是將替換好變量后的模板內(nèi)容寫入到docker容器下default.conf文件里。cat default.conf這句話方便我們查看nginx的配置內(nèi)容,下文會提到。

  • 重新執(zhí)行docker build . -t new-nginx重新打包鏡像

  • 執(zhí)行docker run --name new-nginx-server -d -p 8080:8080 -e URL_1=http://127.0.0.1:8081 -e URL_2=http://127.0.0.1:8082 new-nginx運(yùn)行鏡像,這里我們新增了-e URL_1=http://127.0.0.1:8081 -e URL_2=http://127.0.0.1:8082,往容器里注入了環(huán)境變量,URL_1的值為http://127.0.0.1:8081URL_2的值為http://127.0.0.1:8082

  • 然后我們使用docker logs -f new-nginx-server查看容器里打印的內(nèi)容,因為之前已經(jīng)提前寫好cat default.conf,所以執(zhí)行完命令后,可以直接在 控制臺看到打印出的nginx配置,之前的變量部分,已經(jīng)成功的被替換掉:

server {
  listen 80;
  location / {
    root   /usr/share/nginx/html;
    index  index.html index.htm;
    try_files $uri $uri/ /index.html;
  }
  location /api/ {
    proxy_pass http://127.0.0.1:8081;
  }
  location /login/ {
    proxy_pass http://127.0.0.1:8082;
  }
}

總結(jié)

整個方案,采用的是通過docker run -e xxxx=xxx先往容器注入環(huán)境變量,然后進(jìn)一步通過envsubst指令將環(huán)境變量寫入到具體的文件當(dāng)中,實現(xiàn)動態(tài)配置文件內(nèi)容。 當(dāng)然這個方案依然有一些缺陷,例如當(dāng)需要替換的變量有成百上千時,命令會很長,那時可能需要找一些其他方案進(jìn)行優(yōu)化。此外這里envsubst只是實現(xiàn)變量替換的其中一種方式, 其實實現(xiàn)類似的功能的方式有很多,例如利用nodejs配合ejs動態(tài)寫入也是可以的,本文僅是提供一下大體的思路,具體實現(xiàn)可以結(jié)合自身項目靈活變通。

分享到:
標(biāo)簽:動態(tài) 小結(jié) 服務(wù)器 環(huán)境變量 配置
用戶無頭像

網(wǎng)友整理

注冊時間:

網(wǎng)站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨(dú)大挑戰(zhàn)2018-06-03

數(shù)獨(dú)一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學(xué)四六

運(yùn)動步數(shù)有氧達(dá)人2018-06-03

記錄運(yùn)動步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績評定2018-06-03

通用課目體育訓(xùn)練成績評定