使用Docker部署Node应用

39次阅读

共计 1483 个字符,预计需要花费 4 分钟才能阅读完成。

上篇《前端也要学 Docker 啊!》介绍了 Docker 及它的三个主要概念:Image(镜像)、Container
(容器)、Registry(仓库) 以及 Docker 安装。

本篇我们来动手实践:在本地创建一个自己的镜像(Node 应用),使用该镜像创建容器并执行容器中的 Node 应用。

创建一个 Node 项目

在根目录创建index.js

//index.js
const Koa = require('koa');
const app = new Koa();

app.use(async ctx => {ctx.body = 'Hello Docker O(∩_∩)O~~';
});

app.listen(3000);

创建 Docker 镜像需要用到 docker build命令,而 docker build 命令又是根据 Dockerfile 配置文件来构建镜像,所以我们要在项目根目录创建一个 Dockerfile 文件:

#Dockerfile
FROM node:10.13-alpine #项目的基础依赖
MAINTAINER chenLong #项目维护者
COPY . . #将本机根目录所有文件拷贝到容器的根目录下 这个可以根据喜好调节路径
EXPOSE 3000 #容器对外暴露的端口
RUN npm i #安装 node 依赖
CMD npm start #在容器环境里执行的命令

你可以到 Docker 官网查看详细的 Dockfile 说明

构建镜像

上面 Node 代码已经完成了,我们使用 yarn init -ynpm init -y 完成 package.json 初始化,然后安装一个 koa 依赖:执行 yarn add koanpm i koa

然后我们在本地跑一下 node 程序:node index.js, 打开浏览器输入 localhost:3000,可以看到浏览器中成功显示了 Hello Docker O(∩_∩)O~~。

程序没问题,我们开始构建这个镜像,执行命令:docker build -t docker-demo/hello-docker:v1 . (注意最后有个 . 是必须的)

  • -t: --tag简写,镜像的名字及标签,通常 name:tag 或者 name 格式;可以在一次构建中为一个镜像设置多个标签。

上面的 docker-demo/hello-docker是我们定义的镜像名称,v1是标签名称(类似版本号)


图中蓝色框表示 Dockerfile 的执行步骤。此时一个名为 docker-demo/hello-docker 的镜像已经创建完成了,现在我们执行 docker images 查看一下:

表示本地的镜像列表中已经有了我们刚才创建的docker-demo/hello-docker

让 Node 程序在 Docker 中跑起来

上面已经创建好了镜像,里面包含着我们写的代码,现在我们需要把代码运行起来。
非常简单,我们使用 docker run 命令使用镜像创建一个容器实例(此刻脑海中浮现 var p1 = new Person())。

我们执行命令: docker run -i -t -p 8080:3000 docker-demo/hello-docker:v1

  • -i: 以交互模式运行容器,通常与 -t 同时使用;
  • -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;
  • -p: 指定端口映射,格式为:主机 (宿主) 端口: 容器端口,这里将容器的 3000 端口与宿主机的 8080 端口映射

打开浏览器,运行localhost:8080:

完美,容器里的代码已经跑起来了!

总结

  1. 在项目根目录创建 Dockerfile 并配置
  2. 使用 docker build 命令创建 Docker 镜像,该命令会根据 Dockerfile 里的配置来构建镜像
  3. 使用 docker run 命令根据镜像创建对应的容器实例并运行

正文完
 0