docker结合pm2部署node项目

栏目: 编程工具 · 发布时间: 7年前

内容简介:下载完后后面跟的是在这个新容器中执行的命令
docker pull node

下载完后 docker images 查看一下,稍后用到

二、创建Dockerfile

FROM node
RUN mkdir -p /home/Service
WORKDIR /home/Service    # Bundle app source
COPY . /home/Service
RUN npm install
EXPOSE 8888
CMD npm start   
 ## 如果想运行多条指令可以这样:
## CMD git pull && npm install && npm start

2.1 FROM

FROM node

FROM 是构建镜像的基础源镜像, node 这个是镜像的名称,也就是我们一开始从国内服务器上拉下来的那个 Image 。如果本地没有 Docker 会自己 pull 镜像

2.2 RUN

后面跟的是在这个新容器中执行的命令

#在容器中创建一个目录
RUN mkdir -p /home/Service

2.3 WORKDIR

容器的工作目录

#将容器的工作目录定位到 /home/Service中
WORKDIR /home/Service

2.4 COPY

将本地的东西拷贝到容器的指定目录下

#把本机当前目录下的所有文件拷贝到Image的/home/Service文件夹下
COPY . /home/Service  
RUN npm install

2.5 EXPOSE

将容器内的某个端口导出给主机,用于我们访问

EXPOSE 8888

2.6 CMD

  • 首先:每个 Dockerfile 中只能写一个 CMD ,写多了,后面的会覆盖前面的。
  • 然后: CMD 后面跟的命令是每次容器启动的时候执行的命令。
  • 最后:命令格式可以是数组格式,也可是直接命令行方式,多条命令的时候用 “ && “链接。
CMD [ "npm", "start" ]

三、构建Image

在你 Dockerfile 文件所在的目录下运行下面的命令来构建一个 Image

docker build -t mynodeapp .

点就是指当前目录下的 Dockerfile

构建完后查看一下我们的镜像

docker结合pm2部署node项目

运行镜像

docker run -d -p 8880:8888 mynodeapp
  • -d :表明容器会在后台运行,
  • -p :表示端口映射,把本机的 8880 端口映射到 container8888 端口,这样外网就能通过本机的 8880 端口访问我们的 web 了。
  • 后面的 mynodeapp 是我们镜像的名字

通过 docker ps 查看我们刚运行的 ContainerID

我们先通过 curl 看能不能访问我们的 web

curl -i localhost:8880

如果返回相应的HTTP信息,表示成功

四、结合pm2部署

使用命令 pm2 start app.js 之后, pm2 默认在后台运行, 如果使用了 Docker 后,容器运行并立即退出,需要手动给“ pm2 ”指定参数 --no-daemon

# 在Dockerfile中:

--no-daemon // run pm2 daemon in the foreground if it doesn't exist already

CMD pm2 start app.js --no-daemon // 设置启动方式

#  或者 使用   pm2-docker
CMD pm2-docker start app.js

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

人件(原书第3版)

人件(原书第3版)

[美] Tom DeMarco、[美] Timothy Lister / 肖然、张逸、滕云 / 机械工业出版社 / 2014-8 / 69.00元

在软件管理领域,很少有著作能够与本书媲美。作为经久不衰的畅销书,本书深刻地洞察到软件开发的最大问题不在于技术,而在于人。人的因素并不容易解决,一旦解决了,你将更有可能获得成功。 本书是软件管理领域的传奇经典,被誉为“对美国软件业影响最大的一本书”。全书从管理人力资源、创建健康的办公环境、雇用并留用正确的人、高效团队形成、改造企业文化和快乐工作等多个角度阐释了如何思考和管理软件开发的最大问题—......一起来看看 《人件(原书第3版)》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具