docker前端项目(Docker部署Nuxt.js项目的实现)
docker前端项目
Docker部署Nuxt.js项目的实现Docker官方文档: https://docs.docker.com/
Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。
使用 docker 部署 nuxt.js 项目
1、构建 node 镜像
FROM node:alpine
为啥使用 alpine 版本?
相比于其他 Docker 镜像,它的容量非常小,仅仅只有 5 MB 左右(对比 Ubuntu 系列镜像接近 200 MB),且拥有非常友好的包管理机制。官方镜像来自 docker-alpine 项目。 目前 Docker 官方已开始推荐使用 Alpine 替代之前的 Ubuntu 做为基础镜像环境。这样会带来多个好处。包括镜像下载速度加快,镜像安全性提高,主机之间的切换更方便,占用更少磁盘空间等。
2、设置项目保存目录
RUN mkdir -p /app/src
3、复制项目代码到镜像
COPY ./src /app/src
4、指定命令执行的目录
WORKDIR /app/src
5、设置 host
ENV HOST 0.0.0.0
6、执行项目安装及编译
RUN npm install RUN npm run build RUN npm cache clean --force
7、设置外部访问端口
EXPOSE 3000
8、执行 nuxt 项目运行命令
CMD ["npm", "start"]
完整的 Dockerfile 文件
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、构建镜像
docker build -t nuxt-demo
2、启动容器
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内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
- docker镜像怎么用(Docker和镜像的操作方法)
- dockervolume文件权限(docker volumes 文件映射方式)
- springboot docker 部署(详解docker部署SpringBoot及替换jar包的方法)
- docker容器编排入门教程(简简单单使用Docker部署Confluence)
- docker最新服务条款(解决Mac Docker x509证书的问题)
- docker容器分配(Docker容器数据卷原理及使用方法解析)
- docker快速配置redis集群(基于docker搭建redis集群的方法)
- docker pull 更新本地镜像(Docker 拉取镜像及标签操作 pull | tag)
- rabbitmq docker配置(Docker部署Rabbitmq容器实现过程解析)
- 怎么用docker部署springboot项目(Spring Boot使用Docker分层打包的设置方法)
- dockernginx怎么设置容器(docker nginx + https 子域名配置详细教程)
- docker网络通信(Google和Facebook不使用Docker的原理解析)
- 用docker搭建redis集群(docker实现redis集群搭建的方法步骤)
- docker shell教学(docker安装rockerChat设置聊天室的详细步骤)
- web开发如何正确使用docker(Docker部署web项目的实现)
- docker镜像实例(Docker的镜像制作与整套项目一键打包部署的实现)
- 官宣 全椒籍明星许海峰 奚秀兰 方芳 王璐瑶携手回家 走太平(全椒籍明星许海峰)
- 以前全椒人是怎么过冬的 满满都是回忆(以前全椒人是怎么过冬的)
- NVIDIA显卡份额冲上88 A饭发愁 游戏优化恐没A卡份了(NVIDIA显卡份额冲上88A饭发愁)
- AMD YES A卡还是N卡 A卡和N卡的区别(AMDYESA卡还是N卡)
- 以后显卡多了一个新选择,N卡和A卡外又多了个I卡(以后显卡多了一个新选择)
- 读卖乐园的彩灯(读卖乐园的彩灯)
热门推荐
- php逐行读写文件(PHP实现读取文件夹及批量重命名文件操作示例)
- vue应用转flutter(Vue和Flask通信的实现)
- ajax回调函数不执行
- mysql数据库导入错误怎么处理(MySQL数据库导入导出数据之报错解答实例讲解)
- mysql中null的用法(为什么mysql字段要使用NOT NULL)
- html5滑动刷新(HTML5手指下滑弹出负一屏阻止移动端浏览器内置下拉刷新功能的实现代码)
- jquery隐藏动画教程(jquery插件实现鼠标隐藏)
- docker配置redis集群(基于Docker搭建Redis主从集群的实现)
- php错误提示问题(php提示Creating default object from empty value 的问题解决方法)
- redis在php怎么使用(Windows服务器中PHP如何安装redis扩展)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9