Nuxt.js项目Docker部署和pm2部署

搜索框传播样式-白色版.png

pm2部署

pm2是一个node进程守护 、监控、自动重启以及生成日志的软件,它能够帮你很好的管理node项目。

安装node、pm2等必要依赖

# 淘宝npm
npm install -g cnpm --registry=https://registry.npm.taobao.org
# pm2 安装
npm install pm2 -g
# 软链接(注意软链接路径必须是绝对路径)
ln -s /usr/local/node8.11.4/bin/pm2  /usr/local/bin/pm2

nuxt项目打包

  • 执行npm run build,未报异常说明能够正常运行部署,接着Ctrl+C中止nuxt便可,若本地再次运行使用npm startnpm run dev,会覆盖刚才打包的内容。
该命令执行后,会在项目的 .nuxt生成dist目录,此时只须要把下面的文件复制到服务器对应的目录下便可
# 运行 npm run build 后,复制下面的4个文件到服务器
.nuxt
static
nuxt.config.js
package.json

项目运行

须要注意的是,--name后面的名字是package.json中第一行的name

# 在上传到服务器的目录下运行,状态为online,说明部署成功
pm2 start npm --name "nuxt-django" -- run start --watch

相关命令

# 列表 PM2 启动的全部的应用程序
pm2 list
# 显示指定应用程序的日志
pm2 logs [app-name]
# 中止全部的应用程序
pm2 stop all
# 重启全部应用
pm2 restart all

docker部署

Dockerfile

  • 新建Dockerfile内容以下
FROM node:9.0.0
MAINTAINER www.gaozhe.net
ENV NODE_ENV=production
ENV HOST 0.0.0.0
RUN mkdir -p /app
COPY . /app
WORKDIR /app
EXPOSE 3000
# 国内环境使用,非国内环境使用会报错
RUN npm config set registry https://registry.npm.taobao.org
RUN npm installCMD ["npm", "start"]

构建

  • 文件上传
把打包后的四个文件上传到服务器对应文件夹下,将上面新建的Dockerfile也放在此目录下

# 打包为镜像,上传文件的目录下运行
docker build -t testimage .

运行

  • 运行容器
docker run -dti --network=host --restart=always --name test testimage
  • 查看是否成功部署
# 未打印异常说明启动成功
docker logs test
# 查看nuxt默认端口3000是否开启成功
netstat -ntlp | grep 3000

参考文档