服务器之家:专注于服务器技术及软件下载分享
分类导航

云服务器|WEB服务器|FTP服务器|邮件服务器|虚拟主机|服务器安全|DNS服务器|服务器知识|Nginx|IIS|Tomcat|

服务器之家 - 服务器技术 - 服务器知识 - Docker部署Nuxt.js项目的实现

Docker部署Nuxt.js项目的实现

2021-06-09 17:36ZeFeng Blog 服务器知识

这篇文章主要介绍了Docker部署Nuxt.js项目的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

Docker官方文档: https://docs.docker.com/

Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。

使用 docker 部署 nuxt.js 项目

 

1、构建 node 镜像

?
1
FROM node:alpine

为啥使用 alpine 版本?

相比于其他 Docker 镜像,它的容量非常小,仅仅只有 5 MB 左右(对比 Ubuntu 系列镜像接近 200 MB),且拥有非常友好的包管理机制。官方镜像来自 docker-alpine 项目。 目前 Docker 官方已开始推荐使用 Alpine 替代之前的 Ubuntu 做为基础镜像环境。这样会带来多个好处。包括镜像下载速度加快,镜像安全性提高,主机之间的切换更方便,占用更少磁盘空间等。

2、设置项目保存目录

?
1
RUN mkdir -p /app/src

3、复制项目代码到镜像

?
1
COPY ./src /app/src

4、指定命令执行的目录

?
1
WORKDIR /app/src

5、设置 host

?
1
ENV HOST 0.0.0.0

6、执行项目安装及编译

?
1
RUN npm install RUN npm run build RUN npm cache clean --force

7、设置外部访问端口

?
1
EXPOSE 3000

8、执行 nuxt 项目运行命令

?
1
CMD ["npm", "start"]

完整的 Dockerfile 文件

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
FROM node:alpine
 
RUN mkdir -p /app/src
COPY ./src /app/src
WORKDIR /app/src
 
ENV HOST "0.0.0.0"
 
RUN sed -i "s/dl-cdn.alpinelinux.org/${ALPINE_REPOSITORIES}/g" /etc/apk/repositories
 
RUN apk add --no-cache make gcc g++ python
 
RUN npm install
RUN npm run build
RUN npm cache clean --force
 
RUN apk del make gcc g++ python
 
EXPOSE 3000
CMD ["npm", "start"]

当在项目中使用 sass 或者 scss 时,需依赖 python 环境,所以需要安装 python,当然在编译相关资源后,可以删除相应的依赖以减小镜像体积。

运行 Docker

 

1、构建镜像

?
1
docker build -t nuxt-demo

2、启动容器

?
1
docker run -dt -p 3000:3000 nuxt-demo

3、访问

打开浏览器,访问 127.0.0.1:3000

1、可以用 Docker Compose 对容器进行编排,快速的部署多容器应用。
2、可以用 nginx 对容器进行代理,避免直接以端口的形式访问容器。

到此这篇关于Docker部署Nuxt.js项目的实现的文章就介绍到这了,更多相关Docker部署Nuxt.js内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://www.cnblogs.com/cczlovexw/p/12916310.html

延伸 · 阅读

精彩推荐