• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    上一篇:nginx如何将http访问的网站改成https访问
    下一篇:在IDEA 2020.3.1中部署Tomcat并且创建第一个web项目的过程详解
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    Docker部署Nuxt.js项目的实现 Docker,部署,Nuxt.js,项,目的,