源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Docker实践--部署Nodejs应用

  • 时间:2022-06-21 19:25 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Docker实践--部署Nodejs应用
这个例子的目标是为了向大家展示如何在Docker的container里运行Node.js程序。我会先创建一个简单的Node.js web app,来构建一个镜像。然后基于这个Image运行一个container。从而实现快速部署。 由于网络的原因我的Node.js镜像从国内的镜像库下载,而不是Docker Hub。 先从国内的镜像网站上pull下一下nodejs镜像。      <div class="sucaicode"> <pre class="brush:bash;"> docker pull hub.c.163.com/nce2/nodejs:0.12.2</pre> </div> [img]http://img.1sucai.cn/uploads/article/2018010710/20180107100134_0_94584.png[/img] 下载完后查看我们的镜像,找到他的名称,等会我们会用到 [img]http://img.1sucai.cn/uploads/article/2018010710/20180107100134_1_82053.png[/img] [b]创建Node.js 程序[/b] 创建package.json,并写入相关信息和依赖 <div class="sucaicode"> <pre class="brush:bash;"> vi package.json</pre> </div> <div class="sucaicode"> <pre class="brush:js;"> { "name": "webtest", "version": "1.0.0", "description": "Node.js on Docker", "author": "lpxxn", "main": "server.js", "scripts": { "start": "node server.js" }, "dependencies": { "express": "^4.13.3" } }</pre> </div> [b]创建server.js[/b] <div class="sucaicode"> <pre class="brush:bash;"> vi server.js</pre> </div> 写一个最简单web 这个web基于express框架,返回Hello word.注意我们监听的是8888端口 <div class="sucaicode"> <pre class="brush:bash;"> 'use strict'; var express = require('express'); var PORT = 8888; var app = express(); app.get('/', function (req, res) { res.send('Hello worldn'); }); app.listen(PORT); console.log('Running on http://localhost:' + PORT); </pre> </div> [b]创建Dockerfile[/b] 接下来主角上场了创建Dockerfile文件 这个文件是创建镜像所必须的文件 <div class="sucaicode"> <pre class="brush:bash;"> vi Dockerfile</pre> </div> Docker会依照Dockerfile的内容来构建一个镜像。我先给出完整的代码,再一行一行的给出解释 <div class="sucaicode"> <pre class="brush:bash;"> FROM hub.c.163.com/nce2/nodejs:0.12.2 # Create app directory RUN mkdir -p /home/Service WORKDIR /home/Service # Bundle app source COPY . /home/Service RUN npm install EXPOSE 8888 CMD [ "npm", "start" ] </pre> </div> 我们来一句一句的解释   <div class="sucaicode"> <pre class="brush:bash;"> FROM hub.c.163.com/nce2/nodejs:0.12.2</pre> </div> FROM是构建镜像的基础源镜像,hub.c.163.com/nce2/nodejs:0.12.2 这个是镜像的名称,也就是我们一开始从国内服务器上拉下来的那个Image。如果本地没有Docker 会自己pull镜像。 <div class="sucaicode"> <pre class="brush:bash;"> # Create app directory RUN mkdir -p /home/Service WORKDIR /home/Service</pre> </div> 第一句RUN 用于在Image里创建一个文件夹,将来用于保存我们的代码。 第二句WORKDIR是将我们创建的文件夹做为工作目录。  <div class="sucaicode"> <pre class="brush:bash;"> # Bundle app source COPY . /home/Service RUN npm install</pre> </div> 第一句的COPY是把本机当前目录下的所有文件拷贝到Image的/home/Service文件夹下。 第二句的RUN 使用npm 安装我们的app据需要的所有依赖。 <div class="sucaicode"> <pre class="brush:bash;"> EXPOSE 8888</pre> </div> 由于我们的web app监听的是8888端口,我们把这个端口暴露给主机,这样我就能从外部访问web了。 <div class="sucaicode"> <pre class="brush:bash;"> CMD [ "npm", "start" ]</pre> </div> 这个我相信我不用解释你也能看出来他是做什么的。运行npm start命令,这个命令会运行 node service.js来 启动我们的web app。 [b]构建Image[/b] 在你Dockerfile文件所在的目录下运行下面的命令来构建一个Image. <div class="sucaicode"> <pre class="brush:bash;"> docker build -t mynodeapp .</pre> </div> 别忘了最的的那个点 [img]http://img.1sucai.cn/uploads/article/2018010710/20180107100135_2_25442.png[/img] 构建完后查看一下我们的镜像 [img]http://img.1sucai.cn/uploads/article/2018010710/20180107100135_3_83820.png[/img] 运行镜像 <div class="sucaicode"> <pre class="brush:bash;"> docker run -d -p 8888:8888 ac5</pre> </div> -d 表明容器会在后台运行,-p 表示端口映射,把本机的8888商品映射到container的8888端口这样外网就能通过本机的8888商品访问我们的web了。 后面的ac5是我们Image的ID因为前3个就已经能定位出这个Image所以我就没有把后边的再写出来。 通过docker ps 查看我们刚运行的Container的ID [img]http://img.1sucai.cn/uploads/article/2018010710/20180107100136_4_6721.png[/img] 打印log  7370就是我们的Container ID,和Image ID一样,你也可以全写出来,我比较懒就写前4位,已经足够标识出这个Container了 <div class="sucaicode"> <pre class="brush:bash;"> docker logs 7350</pre> </div> [img]http://img.1sucai.cn/uploads/article/2018010710/20180107100136_5_19214.png[/img] 如果你想到Container里可以执行下面的命令,进入到里边后就可以像操作普通的linux 一样。如果想退出可执行exit命令。 [img]http://img.1sucai.cn/uploads/article/2018010710/20180107100137_6_87921.png[/img]  测试 我们先通过curl 看能不能访问我们的web。 <div class="sucaicode"> <pre class="brush:bash;"> curl -i localhost:8888</pre> </div> [img]http://img.1sucai.cn/uploads/article/2018010710/20180107100137_7_88286.png[/img] 也可以通过浏览器来看一下 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程素材网。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部