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

Docker+Nginx打包部署前后端分離步驟實現(xiàn)

 更新時間:2023年01月08日 15:47:08   作者:別團等shy哥發(fā)育  
這篇文章主要介紹了Docker+Nginx打包部署前后端分離步驟實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

問題描述

最近做了一個前后端分離的通用權(quán)限管理系統(tǒng),今天想用自己的服務(wù)器部署下,本地部署測試是沒問題的,但是部署在服務(wù)器上還是出現(xiàn)了許多小插曲,這里大概記錄一下吧。

項目打包

前端項目打包

由于我需要在同一個端口號下使用nginx部署多個前端項目,所以需要額外設(shè)置一些東西。

修改vue.config.js文件

添加如下配置:

image-20221230164452873

router配置中添加base屬性

const createRouter = () => new Router({
  // mode: 'history', // require service support
  scrollBehavior: () => ({ y: 0 }),
  routes: constantRoutes,
  base:'/guigu'
})

image-20221230164614590

打包前端項目

執(zhí)行命令:

npm run build:prod

image-20221230164743322

image-20221230164732551

出現(xiàn)dist文件夾說明打包成功

image-20221230164808807

后端項目打包

這里我跳過了test步驟

image-20221230164838903

打包之后target文件夾下面會有jar包

image-20221230164906192

將前端和后端的打包文件上傳到服務(wù)器

這里上傳的方法較多,不過多贅述了。

image-20221230165043432

將dist.tgz文件解壓即可

tar -zxvf dist.tgz -C 

寫你的解壓路徑即可

nginx反向代理配置

部分配置如下:

image-20221230165222245

  server {
        listen       80;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
           proxy_pass http://blog;
		   proxy_set_header HOST $host;
		   proxy_set_header X-Forwarded-Proto $scheme;
		   proxy_set_header X-Real-IP $remote_addr;
		   proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }
		
		location ^~/prod-api/ {
			proxy_set_header X-Real-IP $remote_addr;
			proxy_set_header REMOTE-HOST $remote_addr;
			proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
			proxy_set_header X-NginX-Proxy true;
			proxy_pass http://127.0.0.1:8800/;
		}
		# guigu-auth配置
		location /guigu {
			alias /opt/guigu-auth/guigu-front/;
			index index.html index.htm;
		}

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }

上面nginx.conf的配置分為兩個部分,第一個部分實現(xiàn)前端vue的映射,

即將

/opt/guigu-auth/guigu-front/index.html

映射成

127.0.0.1:8080/guigu
location /guigu {
			alias /opt/guigu-auth/guigu-front/;
			index index.html index.htm;
}

第二部分是將后端請求指向后端項目。這里直接替換了uri的前綴

prod-api

也就是說假設(shè)前端向后端發(fā)送的請求為

http://localhost:8800/prod-api/admin/system/index

經(jīng)過nginx反向代理后,實際上到達后端的uri為

http://localhost:8800/admin/system/index

至此,前端項目部署完畢

訪問

codeleader.top/guigu

會出現(xiàn)如下頁面說明前端部署成功

image-20221230170335533

后端通過Dockerfile打包成docker鏡像

這里為什么使用docker?

我開始不想用這個,是直接將jar包在服務(wù)器上部署的,覺得小項目沒必要用docker。

但是由于我以前搭建個人博客的時候裝的jdk11,這個項目使用jdk8開發(fā)的,環(huán)境不一致,docker的環(huán)境隔離機制非常適合現(xiàn)在這種情況,關(guān)于docker使用場景請看我docker專欄,這里不再贅述。

編寫Dockerfile

# 基礎(chǔ)鏡像使用java
FROM java:8
# 作者
MAINTAINER xtt
# VOLUME 指定臨時文件目錄為/tmp,在主機/var/lib/docker目錄下創(chuàng)建了一個臨時文件并鏈接到容器的/tmp
VOLUME /tmp
# 將jar包添加到容器中并更名為guigu_docker.jar
ADD service-system.jar guigu_docker.jar
# 運行jar包
RUN bash -c 'touch /guigu_docker.jar'
ENTRYPOINT ["java","-jar","/guigu_docker.jar"]
#暴露8800端口作為微服務(wù)
EXPOSE 8800

構(gòu)建Docker鏡像

將打包的后端項目jar包和Dockerfile放在同一個目錄下面

image-20221230170847494

執(zhí)行命令如下命令構(gòu)建鏡像:

docker build -t guigu_docker:1.0 .

image-20221230170948838

查看構(gòu)建的鏡像

docker images

image-20221230171022201

運行容器

docker run -d -p 8800:8800 --name guigu-auth guigu_docker:1.0

image-20221230171057150

image-20221230171116141

運行測試

點擊登錄按鈕,成功進入系統(tǒng),說明前后端部署成功。

image-20221230171226854

image-20221230171736165

image-20221230171711121

現(xiàn)在這種部署方式跟部署單個微服務(wù)的方法一樣,但是生產(chǎn)中不可能只有一個微服務(wù),所以需要借助容器編排來實現(xiàn)一次打包一堆微服務(wù),包括docker-compose、docker swam、k8s、DevOps等這還需要大量的開發(fā)實踐才行,這些技術(shù)光學(xué)沒用,要在自己的項目中實踐才行。其實這里nginx和前端也可以用容器部署的,但這里暫時感覺沒必要。

開發(fā)+部署多有意思啊,現(xiàn)在整天搞自己不感興趣的方向已經(jīng)和當初自己想象的研究生科研生涯完全不同了,這種感覺或許只有自己讀研之后才能感同身受了,雖有諸多無奈,但我絕不會放棄我所熱愛的技術(shù),架構(gòu)師之路任重而道遠。

以上就是Docker+Nginx打包部署前后端分離步驟實現(xiàn)的詳細內(nèi)容,更多關(guān)于Docker+Nginx部署前后端分離的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • docker操作Permission denied無權(quán)限的問題解決

    docker操作Permission denied無權(quán)限的問題解決

    我們?nèi)粘P枰猟ocker環(huán)境進入容器配置或查看一些文件,本文主要介紹了docker操作Permission denied無權(quán)限的問題解決,具有一定的參考價值,感興趣的可以了解一下
    2024-06-06
  • Docker部署前后端分離項目的實現(xiàn)示例

    Docker部署前后端分離項目的實現(xiàn)示例

    本文主要介紹了Docker部署前后端分離項目的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • docker服務(wù)關(guān)停的實現(xiàn)步驟

    docker服務(wù)關(guān)停的實現(xiàn)步驟

    在我看來所謂的優(yōu)雅關(guān)閉,就是在系統(tǒng)關(guān)閉時,預(yù)留一些時間,讓你有機會來善后一些事情,本文就來介紹一下docker服務(wù)如何正確關(guān)停,感興趣的可以了解一下
    2023-10-10
  • Docker打包鏡像及修改配置的實現(xiàn)

    Docker打包鏡像及修改配置的實現(xiàn)

    這篇文章主要介紹了Docker打包鏡像及修改配置的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧
    2021-01-01
  • Docker Namespace容器隔離的實現(xiàn)

    Docker Namespace容器隔離的實現(xiàn)

    Namespace是Docker容器中的一種隔離機制,通過劃分資源獨立空間,確保容器之間互不干擾,本文主要介紹一下Docker Namespace容器隔離的實現(xiàn),感興趣的可以了解一下
    2024-11-11
  • 綁定Dokcer容器到主機指定網(wǎng)卡的方法

    綁定Dokcer容器到主機指定網(wǎng)卡的方法

    這篇文章主要介紹了綁定 Dokcer 容器到主機指定網(wǎng)卡的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • docker的鏡像存放地址在哪里

    docker的鏡像存放地址在哪里

    Docker鏡像(Image)是用于創(chuàng)建?Docker?容器的模板,下面這篇文章主要給大家介紹了關(guān)于docker的鏡像存放地址在哪里的相關(guān)資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2023-01-01
  • 使用Docker+jenkins+python3環(huán)境搭建超詳細教程

    使用Docker+jenkins+python3環(huán)境搭建超詳細教程

    這篇文章主要介紹了使用Docker+jenkins+python3環(huán)境搭建超詳細教程,本文通過多種方法結(jié)合示例代碼給大家詳細介紹,需要的朋友可以參考下
    2021-07-07
  • docker鏡像無法刪除 Error:No such image:xxxxxx解決

    docker鏡像無法刪除 Error:No such image:xxxxxx解決

    這篇文章主要介紹了docker鏡像無法刪除 Error:No such image:xxxxxx解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧
    2020-09-09
  • docker 部署prometheus+grafana的過程詳解

    docker 部署prometheus+grafana的過程詳解

    這篇文章主要介紹了docker 部署prometheus+grafana的過程,本文通過示例圖文相結(jié)合給大家介紹的非常詳細,需要的朋友可以參考下
    2024-03-03

最新評論