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

vue前端項(xiàng)目打包成Docker鏡像并運(yùn)行的實(shí)現(xiàn)

 更新時(shí)間:2022年08月09日 14:13:52   作者:Song_Estelle  
這篇文章主要介紹了vue前端項(xiàng)目打包成Docker鏡像并運(yùn)行的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

vue前端項(xiàng)目打包成Docker鏡像并運(yùn)行

首先說明咱們的前端項(xiàng)目是基于Vue的,反向代理使用的是nginx

1.打包vue前端項(xiàng)目生成dist文件夾上傳至服務(wù)器

新建一個(gè)文件夾,叫vueDockerTest,下面的文件都需要。

cert是你存放ssl證書的文件夾,nginx.conf 是nginx的配置文件,dist是你打包的前端靜態(tài)文件

2.修改Dockerfile文件

# 基于nginx:1.20鏡像
FROM nginx:1.20
# 將dist文件中的內(nèi)容復(fù)制到 /usr/share/nginx/html/ 這個(gè)目錄下面
COPY dist/ /usr/share/nginx/html/dist/
# 用本地的 nginx.conf 配置來替換nginx鏡像里的默認(rèn)配置
COPY nginx.conf /etc/nginx/nginx.conf
# 將證書文件內(nèi)容復(fù)制到/usr/local/nginx/文件夾下
COPY cert/ /usr/local/nginx/cert/

3.修改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;
    # HTTPS server
    server {
        listen 443 ssl;
        server_name  localhost;
        ssl_certificate      /usr/local/nginx/cert/server.crt;
        ssl_certificate_key  /usr/local/nginx/cert/server.key;
        ssl_session_cache    shared:SSL:1m;
        ssl_session_timeout  5m;
        ssl_ciphers  HIGH:!aNULL:!MD5;
        ssl_prefer_server_ciphers  on;
                location / {
            root   /usr/share/nginx/html/dist;
                        try_files $uri $uri/ /index.html;
            index  index.html index.htm;
        }
                location /backend/{
                       proxy_set_header Host $http_host;
                       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;
                       client_max_body_size 20M;
                       proxy_send_timeout 500;
                       proxy_read_timeout 480;
                       proxy_pass http://localhost:8992;
               }
                error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }
}

4.打包成docker鏡像

docker build -t nss-web:1.0 .

執(zhí)行docker images可以查看到已經(jīng)生成的docker鏡像

5.運(yùn)行前端鏡像容器

容器內(nèi)部的端口號(hào)是443 我使用--net=host,就不需要映射端口號(hào)了

如果防火墻開著的話,需要放行443和80端口哦

docker run -d --privileged=true --name nss-web1.0 --restart always --net=host nss-web:1.0
--privileged=true        #容器內(nèi)部擁有root權(quán)限
--restart always         #自啟動(dòng)
--net=host               #網(wǎng)絡(luò)與宿主機(jī)保持一致

6.使用https://你的IP地址即可訪問運(yùn)行

前端將vue打包成鏡像發(fā)布

提示:以下是本篇文章正文內(nèi)容,下面案例可供參考

一、總體預(yù)覽

二、打包配置

2.1 default.conf

server {
    listen       80;
    server_name  localhost;
    location / {
        root   /usr/share/nginx/html/;
        index  index.html index.htm;
        # try_files $uri $uri/ /index.html;
    }
    location /finalLearn {
        alias  /usr/share/nginx/html/;
        # index index.html index.htm;
        try_files $uri /finalLearn/index.html;
    }
    error_page   500 502 503 504  /50x.html;
}

2.2 Dockerfile

# 基礎(chǔ)鏡像
FROM nginx
MAINTAINER cw
# 刪除原有的default.conf文件
RUN rm /etc/nginx/conf.d/default.conf
# 增加自定義default.conf文件到對(duì)應(yīng)目錄
ADD default.conf /etc/nginx/conf.d/
# 將dist目錄下的文件復(fù)制到nginx內(nèi)的目錄下,與上文對(duì)應(yīng)
COPY dist/ /usr/share/nginx/html/

2.3 打包

docker build -t <自定義tag>

三、問題思考

打包發(fā)布后,有時(shí)候出現(xiàn)錯(cuò)誤 Uncaught SyntaxError: Unexpected token <

大多情況下靜態(tài)文件js、css等訪問不到的問題。具體配置需和前端打包方式對(duì)應(yīng)上。

但是如果條件允許可以把js等靜態(tài)文件放在OSS上,這種問題也不會(huì)發(fā)生,同時(shí)也可cdn加速。具體結(jié)當(dāng)下場(chǎng)景。 

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue Element前端應(yīng)用開發(fā)之樹列表組件

    Vue Element前端應(yīng)用開發(fā)之樹列表組件

    本篇隨筆主要介紹樹列表組件和下拉列表樹組件在項(xiàng)目中的使用,以及一個(gè)SplitPanel的組件。
    2021-05-05
  • Vite開發(fā)環(huán)境搭建詳解

    Vite開發(fā)環(huán)境搭建詳解

    Vite是一款非常輕量級(jí)的Web開發(fā)框架,它可以幫助開發(fā)者快速搭建一個(gè)開發(fā)環(huán)境。Vite搭建的開發(fā)環(huán)境可以提供更快的編譯速度,更少的配置,更好的性能和更多的開發(fā)者友好性,使開發(fā)者可以更快地構(gòu)建出功能強(qiáng)大的Web應(yīng)用程序。
    2023-02-02
  • 淺析Vue中Virtual?DOM和Diff原理及實(shí)現(xiàn)

    淺析Vue中Virtual?DOM和Diff原理及實(shí)現(xiàn)

    這篇文章主要為大家詳細(xì)介紹了Vue中Virtual?DOM和Diff原理及實(shí)現(xiàn)的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下
    2023-03-03
  • Vue實(shí)現(xiàn)一個(gè)帶有緩存功能的Tab頁簽功能

    Vue實(shí)現(xiàn)一個(gè)帶有緩存功能的Tab頁簽功能

    在現(xiàn)代?Web?應(yīng)用中,Tab?頁簽功能是非常常見的一種交互模式,它可以幫助用戶在不同的視圖間快速切換,而不會(huì)丟失當(dāng)前視圖的狀態(tài),本文將介紹如何在?Vue?項(xiàng)目中實(shí)現(xiàn)一個(gè)帶有緩存功能的?Tab?頁簽功能,需要的朋友可以參考下
    2024-08-08
  • vue項(xiàng)目如何全局修改el-button樣式

    vue項(xiàng)目如何全局修改el-button樣式

    這篇文章主要介紹了vue項(xiàng)目如何全局修改el-button樣式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • 詳細(xì)分析vue表單數(shù)據(jù)的綁定

    詳細(xì)分析vue表單數(shù)據(jù)的綁定

    這篇文章主要介紹了vue表單數(shù)據(jù)的綁定的相關(guān)資料,文中講解非常細(xì)致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-07-07
  • vue2.0中set添加屬性后視圖不能更新的解決辦法

    vue2.0中set添加屬性后視圖不能更新的解決辦法

    在本文里我們給大家整理了關(guān)于vue2.0中set添加屬性后視圖不能更新的解決辦法以及相關(guān)知識(shí)點(diǎn),需要的朋友們學(xué)習(xí)下。
    2019-02-02
  • Vue extends 屬性的用法示例詳解

    Vue extends 屬性的用法示例詳解

    這篇文章主要為大家介紹了Vue extends 屬性的用法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • 創(chuàng)建項(xiàng)目及包管理yarn create vite源碼學(xué)習(xí)

    創(chuàng)建項(xiàng)目及包管理yarn create vite源碼學(xué)習(xí)

    這篇文章主要為大家介紹了創(chuàng)建項(xiàng)目及包管理yarn create vite源碼學(xué)習(xí)分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • vue中的inject用法及說明

    vue中的inject用法及說明

    這篇文章主要介紹了vue中的inject用法及說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08

最新評(píng)論