Docker部署nuxtjs

2020-04-27 16:59:23

参考地址 NuxtJS使用Docker容器部署

1.普通Nuxt编译/发布流程

编译命令

NuxtJS 框架提供了如下命令用作开发或部署

命令描述
nuxt启动一个热加载的Web服务器(开发模式) localhost:3000。
nuxt build利用webpack编译应用,压缩JS和CSS资源(发布用)
nuxt start以生产模式启动一个Web服务器 (nuxt build 会先被执行)
nuxt generate编译应用,并依据路由配置生成对应的HTML文件 (用于静态站点的部署)。

你可以将这些命令添加至 package.json

"scripts": {
  "dev": "nuxt",
  "build": "nuxt build",
  "start": "nuxt start",
  "generate": "nuxt generate"
}

然后通过 NPM进行编译

npm run dev //启动热加载开发模式
npm run build //编译

发布目录所需文件

将一下文件拷贝至服务器目录/app |名称|描述| |-|-| |.nuxt|编译后生成的目录,开发模式和发布模式通用,注意发布前使用npm run build 防止将dev目录发布| |static| 静态资源文件,通过/可直接访问| |package.json|npm 包管理配置文件| |nuxt.config.js|Nuxt.js 默认的配置涵盖了大部分使用情形,可通过 nuxt.config.js 来覆盖默认的配置。| |node_modules|依赖模块|

安装NPM包

服务器需要node环境

cd /app
npm install

内网环境你也可以把node_modules直接复制到/app目录

最后启动Nuxt

npm run start

Listening on: http://your-ip:80/

nuxt.config.js server配置介绍 端口 HTTPS socket等

2.Docker 部署Nuxt

使用Dockerfile构建具备Node环境的容器镜像

1.容器基于 Dockerhub Node alpine官方镜像进行构建
2.并且安装busyboxbash工具

Busybox 官网 BusyBox 是一个集成了三百多个最常用Linux命令和工具的软件

创建文件 Dockerfile

#使用node:8.16-alpine 作为基础进行构建
FROM node:8.16-alpine 

#创建/app 目录作为部署目录,创建容器实例时,挂载此目录
RUN mkdir -p /app

#更改alpine的安装源指向阿里源
RUN echo "http://mirrors.aliyun.com/alpine/v3.9/main/" > /etc/apk/repositories

#安装 bash 和 busybox
RUN apk update \
        && apk upgrade \
        && apk add --no-cache bash \
        bash-doc \
        bash-completion \
        && /bin/bash \
        && apk add --no-cache busybox \
        && rm -rf /var/cache/apk/*
#移动工作目录到 /app
WORKDIR /app

#设置node环境变量为production
ENV NODE_ENV=production

#设置容器启动时执行的命令
ENTRYPOINT [ "npm","start" ]

生成镜像

执行命令时,需要cd到Dockerfile所在目录,特别注意命令最后有一个. 我之前被坑过 docker build -t yourImageName:yourVersionTag .

启动docker容器,挂载宿主目录

1.复制.nuxtstaticpackage.jsonnuxt.config.js 到 /root/nuxt-ssr目录(宿主机目录)
2.执行命令

docker run --name nuxt -p 8080:80 -d --restart=unless-stopped -v /root/docker-mount/dev-ssr:/app  yourImageName:yourVersionTag

命令参数 --name ssr 给容器起个别名 ssr
-p 8080:80 映射容器的80端口到主机8080端口,也可以不给,但是windows下不能直接ping通容器
-d 创建容器后,在后台运行,如果不加退出会话后,容器会终止运行 --restart=unless-stopped 指定容器在异常终止后重启,防止挂掉没人管 -v /root/nuxt-ssr:/app 挂载宿主目录/root/nuxt-ssr到容器的/app目录

完成

现在访问localhost:8080即你的nuxt容器了


  • 2017-09-11 09:22:09

    nginx配置返回文本或json

     有些时候请求某些接口的时候需要返回指定的文本字符串或者json字符串,如果逻辑非常简单或者干脆是固定的字符串,那么可以使用nginx快速实现,这样就不用编写程序响应请求了,可以减少服务器资源占用并且响应性能非常快

  • 2017-09-11 11:30:09

    linux 获取经过N层Nginx转发的访问来源真实IP

    通常情况下我们使用request.getRemoteAddr()就可以获取到客户端ip,但是当我们使用了nginx作为反向代理后,由于在客户端和web服务器之间增加了中间层,因此web服务器无法直接拿到客户端的ip,通过$remote_addr变量拿到的将是反向代理服务器的ip地址。如果我们想要在web端获得用户的真实ip,就必须在nginx这里作一个赋值操作,如下:

  • 2017-09-11 16:15:11

    Nginx日志管理

    通过访问日志,你可以得到用户地域来源、跳转来源、使用终端、某个URL访问量等相关信息;通过错误日志,你可以得到系统某个服务或server的性能瓶颈等。因此,将日志好好利用,你可以得到很多有价值的信息。

  • 2017-09-11 16:34:14

    Nginx如何保留真实IP和获取前端IP

    squid,varnish以及nginx等,在做反向代理的时候,因为要代替客户端去访问服务器,所以,当请求包经过反向代理后,在代理服务器这里这个IP数据包的IP包头做了修改,最终后端web服务器得到的数据包的头部的源IP地址是代理服务器的IP地址,这样一来,后端服务器的程序给予IP的统计功能就没有任何意义,所以在做代理或集群的时候必须解决这个问题,这里,我以nginx做集群或代理的时候如何给后端web服务器保留(确切的说是传递)客户端的真实IP地址。

  • 2017-09-11 16:35:22

    ngx_http_realip_module使用详解

    网络上关于ngx_http_realip_module的文章千篇一律,全是在说怎么安装,最多贴一个示例配置,却没有说怎么用,为什么这么用,官网文档写得也十分简略,于是就自己探索了一下。

  • 2017-09-11 16:39:43

    基于Nginx dyups模块的站点动态上下线

    在分布式服务下,我们会用nginx做负载均衡, 业务站点访问某服务站点的时候, 统一走nginx, 然后nginx根据一定的轮询策略,将请求路由到后端一台指定的服务器上。