Docker(Nginx)部署Vue

简介:目标使用docker将vue生成的dist文件,结合nginx生成镜像,然后运行;

1、首选确保vue项目正确运行,并能正确打包dist文件;
第一个是运行命令,第二个是打包命令
2、查看已经生成的dist文件
在这里插入图片描述
3、将dist文件打包为rar文件或者zip文件,本文使用rar文件
在这里插入图片描述
4、确保服务器已经安装docker;
新建文件夹:/home/questionaire-app/
将dist.rar 上传到该目录下,并解压到当前目录下;

unrar x dist.rar

5、在/home/questionaire-app/下新建nginx配置文件default.conf,新建Dockerfile文件;
1)编辑default.conf文件

server {
    listen       80;
    server_name  127.0.0.1;
 
    #charset koi8-r;
    #access_log  /var/log/nginx/log/host.access.log  main;
 
    location / {
        root   /usr/share/nginx/html;
        try_files $uri $uri/ /index.html
        index  index.html index.htm;
    }
 
    location /prod-api/ {
        proxy_pass  http://127.0.0.1:18080/;
    }
 
    #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;
    }
 
    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ \.php$ {
    #    proxy_pass   http://127.0.0.1;
    #}
 
    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    #location ~ \.php$ {
    #    root           html;
    #    fastcgi_pass   127.0.0.1:9000;
    #    fastcgi_index  index.php;
    #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
    #    include        fastcgi_params;
    #}
 
    # deny access to .htaccess files, if Apache's document root
    # concurs with nginx's one
    #
    #location ~ /\.ht {
    #    deny  all;
    #}
}

代理可以根据需求配置,不强求
在这里插入图片描述

2)编辑Dockerfile文件:

# 使用nginx镜像
FROM nginx
# 作者
MAINTAINER cmh
# 删除nginx 默认配置
RUN rm /etc/nginx/conf.d/default.conf
# 添加我们自己的配置 default.conf 在下面
ADD default.conf /etc/nginx/conf.d/
# 把刚才生成dist文件夹下的文件copy到nginx下面去
COPY dist/  /usr/share/nginx/html/

最终该目录下是这样的:
在这里插入图片描述

6、生成镜像并运行

1)生成镜像
“ . ” 这个点不要省略

docker build -t mall-admin-vue .

在这里插入图片描述
2)运行容器

docker run -d --name mall-admin-vue -p 8088:80 mall-admin-vue

7、测试:
浏览器通过ip+端口访问
在这里插入图片描述
参考文档:https://blog.csdn.net/cmh1008611/article/details/144793141

### 回答1: 要将 Vue 项目部署Docker 上,可以使用以下步骤: 1. 编写 Dockerfile 文件:创建一个包含 NginxDocker 镜像,并将 Vue 项目文件复制到镜像中。 2. 构建 Docker 镜像:使用 Dockerfile 构建 Docker 镜像,例如可以使用命令:`docker build -t my-nginx-vue-image .` 3. 运行 Docker 容器:使用刚刚构建的 Docker 镜像来创建和运行一个 Docker 容器,例如可以使用命令:`docker run -d -p 80:80 my-nginx-vue-image` 4. 访问 Vue 项目:现在可以通过浏览器访问 Vue 项目,例如可以在浏览器中输入 `http://localhost` 来访问项目。 这样,您就可以在 Docker部署 Vue 项目了。 ### 回答2: 在将Vue项目部署到生产环境中,我们需要将Vue项目打包为静态资源,然后将静态资源放置到Web服务器上。在这里,我们介绍如何使用DockerNginxVue项目部署到Web服务器中。 第一步,将Vue项目打包为静态资源。我们可以使用Vue CLI提供的打包命令将Vue项目打包为生产版本。在终端中运行命令: ``` npm run build ``` 执行该命令后,Vue项目会将打包好的静态文件放置到dist目录下。 第二步,创建Docker文件。我们需要编写一个Dockerfile文件,并定义好环境变量和Docker镜像的基础镜像。在这里我们以Node.js作为基础镜像,Dockerfile文件的内容如下: ``` # 使用node.js基础镜像 FROM node:14.15.0-alpine3.10 as builder # 设置工作目录 WORKDIR /app # 复制package.json及package-lock.json到工作目录 COPY package*.json ./ # 安装依赖 RUN npm install # 将源码复制到工作目录 COPY . . # 进行构建 RUN npm run build # 运行时镜像的基础镜像 FROM nginx:1.19.6-alpine # 复制构建出的静态资源到镜像中 COPY --from=builder /app/dist /usr/share/nginx/html # 复制Nginx配置文件 COPY nginx.conf /etc/nginx/nginx.conf # 暴露80端口 EXPOSE 80 ``` 第三步,编写Nginx配置文件。我们需要将Nginx配置文件复制到Docker镜像中,如下所示: ``` # nginx.conf # 在http下添加gzip配置 http { gzip on; gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript; server { listen 80; server_name localhost; # 静态资源文件所在目录 root /usr/share/nginx/html; # 让Nginx支持Vue路由 location / { try_files $uri $uri/ /index.html; } } } ``` 第四步,构建Docker镜像。我们需要在终端中运行构建镜像的命令。在终端中进入Dockerfile所在的目录,并执行以下命令: ``` docker build -t my-vue-app:latest . ``` 命令中,“my-vue-app”是镜像的名称,“latest”是镜像的标签。如果构建成功,会在镜像列表中看到该镜像。 第五步,启动Docker容器。我们需要运行以下命令将镜像启动为Docker容器: ``` docker run --name my-vue-app -d -p 80:80 my-vue-app:latest ``` 命令中,“my-vue-app”是容器的名称,“-d”表示在后台运行,“-p 80:80”表示将容器的80端口映射到主机的80端口。如果成功运行容器,可以在浏览器中访问Vue项目。 ### 回答3: Docker 是一个强大的容器化工具,而 Nginx 是一个流行的跨平台 Web 服务器软件,可以很好地与 Docker 结合使用以部署 Vue 项目。 以下是一些步骤来完成这个过程: 1. 第一步是创建 Vue 项目。在根目录下创建一个 Dockerfile 文件,并在其中添加以下代码: ``` # 使用了一个 Node.js 镜像,以安装项目的依赖 FROM node:latest as build-stage WORKDIR /app COPY package*.json ./ RUN npm install COPY ./ . RUN npm run build # 使用了一个 nginx 镜像,替换默认的 nginx.conf 文件,以及项目的 build 文件夹 FROM nginx:latest COPY --from=build-stage /app/dist/ /usr/share/nginx/html COPY nginx.conf /etc/nginx/nginx.conf ``` 2. 在项目根目录下添加 nginx.conf 文件并进行配置。例如: ``` user nginx; worker_processes auto; error_log /var/log/nginx/error.log; pid /var/run/nginx.pid; events { worker_connections 1024; } http { # 后端服务接口地址 upstream backend { server backend:80; } include /etc/nginx/mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout 65; server { listen 80; location / { root /usr/share/nginx/html; index index.html; try_files $uri $uri/ /index.html; } # 反向代理 location /api { rewrite /api/(.*) /$1 break; proxy_pass http://backend; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; } } } ``` 3. 接下来,通过 Docker 命令构建镜像并运行容器: ``` // 构建镜像 docker build -t vue-nginx . // 运行容器 docker run -it -p 80:80 --rm --name vue-nginx-container vue-nginx ``` 到此为止,Vue 项目就已经成功部署Docker 容器中并通过 Nginx 服务器运行了。 总的来说,使用 DockerNginx 部署 Vue 项目可以大大简化部署流程,并提供更好的容错能力和安全性。在实践中,这种部署方式已被广泛采用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值