主頁(yè) > 知識(shí)庫(kù) > 利用docker-compsoe部署前后端分離的項(xiàng)目方法

利用docker-compsoe部署前后端分離的項(xiàng)目方法

熱門(mén)標(biāo)簽:400電話號(hào)碼辦理多少錢(qián) 山東企業(yè)外呼系統(tǒng)公司 濮陽(yáng)好的聯(lián)通400電話申請(qǐng) 虛假地圖標(biāo)注 承德地圖標(biāo)注公司 地圖標(biāo)注如何改成微信號(hào) 地圖標(biāo)注黃河的位置 百度地圖標(biāo)注公司位置要多少錢(qián) 靈圖uu電子寵物店地圖標(biāo)注

說(shuō)在前面

我們都知道,docker可以實(shí)現(xiàn)很簡(jiǎn)便的部署環(huán)境?,F(xiàn)在我們有一個(gè)前后端分離的項(xiàng)目,前端基于Vue開(kāi)發(fā)、利用Webpakc打包為dist文件夾。后端則是一個(gè)Node.js服務(wù),提供API接口,前端和后端是分離的。所以我們肯定是前端項(xiàng)目一個(gè)container,后臺(tái)項(xiàng)目也是一個(gè)container。那么如果是在生產(chǎn)環(huán)境,就會(huì)產(chǎn)生跨域問(wèn)題。前端的請(qǐng)求要反向代理到后臺(tái)。大家肯定首先想到的就是使用 Nginx 設(shè)置 proxy_pass 。是的沒(méi)有錯(cuò)。那么我們有了這些想法。我們?nèi)绾瓮ㄟ^(guò) docker-compose 來(lái)實(shí)現(xiàn)呢?

開(kāi)始動(dòng)手

其實(shí)我也是才開(kāi)始了解docker的。所以有很多不明白的地方,例如在docker里面,是通過(guò)image生成一個(gè)container,那么這個(gè)container,就可以當(dāng)作是一個(gè)獨(dú)立的系統(tǒng),這個(gè)系統(tǒng)也就有自己獨(dú)立的端口。那么就像我們剛剛那樣的需求,假設(shè)我們的前端在 container1 里面暴露80端口,同時(shí)映射到宿主機(jī)的80端口,后端在 container2 里面暴露3000端口,同時(shí)映射到宿主機(jī)的3000端口。那我們反向代理請(qǐng)求的時(shí)候,是通過(guò)宿主機(jī)來(lái)反向代理呢,還是通過(guò)container來(lái)實(shí)現(xiàn)呢?我在網(wǎng)上查閱并學(xué)習(xí)了很多其他大佬的文章,還有官網(wǎng)的文檔。發(fā)現(xiàn)直接通過(guò)container就可以實(shí)現(xiàn)這種需求。為什么呢?因?yàn)閐ocker-compose,會(huì)將所有的container構(gòu)建在同一網(wǎng)絡(luò)下,我們要找其他container,我們只需通過(guò)docker-compose里面的 service name 即可找到。 下面先來(lái)看看我們的目錄:

vueMusic
 ├─ .git
 ├─ .gitignore
 ├─ LICENSE
 ├─ README.md
 ├─ babel.config.js
 ├─ dist
 ├─ docker-compose.yml
 ├─ docs
 ├─ nginx.conf
 ├─ package-lock.json
 ├─ package.json
 ├─ public
 ├─ server
 ├─ src
 └─ vue.config.js

dist是我們的前端項(xiàng)目,server是我們的后端項(xiàng)目。 下面再來(lái)看看我們的 docker-compose.yml :

version: '3'
 services:
 music-web: #前端項(xiàng)目的service name
   container_name: 'music-web-container' #容器名稱(chēng)
   image: nginx #指定鏡像
   restart: always
   ports:
   - 80:80
   volumes: 
   - ./nginx.conf:/etc/nginx/nginx.conf #掛載nginx配置
   - ./dist:/usr/share/nginx/html/  #掛載項(xiàng)目
   depends_on:
   - music-server
 music-server:  #后端項(xiàng)目的service name
   container_name: 'music-server-container'
   build: ./server #根據(jù)server目錄下面的Dockerfile構(gòu)建鏡像
   restart: always
   expose:
   - 3000

可以看見(jiàn),我們通過(guò) volumes 屬性將宿主機(jī)的 nginx.conf 掛載到容器內(nèi)的nginx配置文件,用來(lái)覆蓋原有的配置文件,同時(shí)也將 dist 掛載到容器內(nèi)。我們將前端項(xiàng)目的容器暴露并映射給宿主機(jī)的80端口,我們將后端項(xiàng)目的容器暴露3000端口。那么我們?cè)谀睦飳?shí)現(xiàn)反向代理請(qǐng)求呢?請(qǐng)看 nginx.conf :

#user nobody;
 worker_processes 1;
 events {
   worker_connections 1024;
 }
 http {
   include    mime.types;
   default_type application/octet-stream;
   sendfile    on;
   #tcp_nopush   on;
   #keepalive_timeout 0;
   keepalive_timeout 65;
   #gzip on;
   gzip on;
   gzip_min_length 5k;
   gzip_buffers   4 16k;
   #gzip_http_version 1.0;
   gzip_comp_level 3;
   gzip_types text/plain application/javascript application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png;
   gzip_vary on;
   server {
     listen 80;
     server_name www.xieyezi.com;
     #音樂(lè)app項(xiàng)目
     location / {
     index index.html index.htm;  #添加屬性。 
     root /usr/share/nginx/html;  #站點(diǎn)目錄
     }
     #音樂(lè)app項(xiàng)目設(shè)置代理轉(zhuǎn)發(fā)
     location /api/ {
     proxy_pass http://music-server:3000/;
     }
     error_page  500 502 503 504 /50x.html;
     location = /50x.html {
       root  /usr/share/nginx/html;
     }
   }
 }

可以看上面的 proxy_pass http://music-server:3000/; 。其中 music-server 是我們后端項(xiàng)目的服務(wù)名,我們通過(guò)服務(wù)名來(lái)找到這個(gè)容器,這樣就實(shí)現(xiàn)了反向代理。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:安康 福州 淮安 德宏 樂(lè)山 泰安 上海 鷹潭

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《利用docker-compsoe部署前后端分離的項(xiàng)目方法》,本文關(guān)鍵詞  利用,docker-compsoe,部署,前,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《利用docker-compsoe部署前后端分離的項(xiàng)目方法》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于利用docker-compsoe部署前后端分離的項(xiàng)目方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章