如何一步步通过Docker部署Node.js应用?

摘要:一步步学会用docker部署应用 docker是一种虚拟化技术,可以在内核层隔离资源。因此对于上层应用而言,采用docker技术可以达到类似于虚拟机的沙盒环境。这大大简化了应用部署,让运维人员无需陷入无止境繁琐的依赖环境及系统配置中;另一方
一步步学会用docker部署应用 docker是一种虚拟化技术,可以在内核层隔离资源。因此对于上层应用而言,采用docker技术可以达到类似于虚拟机的沙盒环境。这大大简化了应用部署,让运维人员无需陷入无止境繁琐的依赖环境及系统配置中;另一方面,容器技术也可以充分利用硬件资源,做到资源共享。 本文将采用docker技术部署一个简单的nodejs应用,它包括一个简单的前置网关nginx、redis服务器以及业务服务器。同时使用dockerfile配置特定镜像,采用docker-compose进行容器编排,解决依赖、网络等问题。 docker基础 本文默认机器已安装docker环境,即可以使用docker和docker-compose服务,如果本地没有安装,则参考: 安装docker及docker-compose,可参考 Install Docker Compose docker compose 技术可以查看官方文档 Docker Compose docker源 默认docker采用官方镜像,国内用户下载镜像速度较慢,为了更好的体验,建议切换源。 OSX系统通过添加 ~/.docker/daemon.json文件, { "registry-mirrors": ["http://f1361db2.m.daocloud.io/"] } 即可,镜像源地址可替换,随后重启docker服务即可。 linux系统通过修改 /etc/docker/daemon.josn文件,一样可以替换源。 docker简单操作 源切换完毕之后,就可以尝试简单的容器操作。 首先,运行一个简单的容器: docker run -it node:8-slim node run命令,根据某个版本的node镜像运行容器,同时执行 “node”命令,进入node命令行交互模式。 docker run -d node:8-slim node 执行 -d 选项,让容器以daemon进程运行,同时返回容器的hash值。根据该hash值,我们可以通过命令行进入运行的容器查看相关状态: docker exec -it hashcode bash hashcode可以通过 docker ps -l 找到对应容器的hashcode 关于镜像的选择以及版本的确定,可以通过访问官方 https://hub.docker.com/ 搜索,根据结果寻找 official image使用,当然也可根据下载量和star数量进行选择。 对于镜像的tag,则根据业务需求进行判断是否需要完整版的系统。如nodejs镜像,仅仅需要node基础环境而不需要其他的系统预装命令,因此选择了 node:-slim 版本。 Dockerfile 从源下载的镜像大多数不满足实际的使用需求,因此需要定制镜像。镜像定制可以通过运行容器安装环境,最后提交为镜像: docker run -it node:8-slim bash root@ff05391b4cf8:/# echo helloworld > /home/text root@ff05391b4cf8:/# exit docker commit ff05391b4cf8 node-hello 然后运行该镜像即可。 另一种镜像定制可以通过Dockerfile的形式完成。Dockerfile是容器运行的配置文件,每次执行命令都会生成一个镜像,直到所有环境都已设置完毕。 Dockerfile文件中可以执行命令定制化镜像,如 “FROM、COPY、ADD、ENV、EXPOSE、RUN、CMD”等,具体dockerfile的配置可参考相关文档。 Dockerfile完成后,进行构建镜像: docker build -t node:custom:v1 . 镜像构建成功后即可运行容器。 docker-compose 关于docker-compose,将在下文示例中进行说明。 示例:搭建nodejs应用 本文所有代码已开源至github docker-compose.yml 在docker-compose.yml中配置相关服务节点,同时在每个服务节点中配置相关的镜像、网络、环境、磁盘映射等元信息,也可指定具体Dockerfile文件构建镜像使用。
阅读全文