这个例子的目标是为了向大家展示如何在docker的container里运行node.js程序。我会先创建一个简单的node.js web
app,来构建一个镜像。然后基于这个image运行一个container。从而实现快速部署。
由于网络的原因我的node.js镜像从国内的镜像库下载,而不是docker hub。
先从国内的镜像网站上pull下一下nodejs镜像。
1
|
docker pull hub.c.163.com /nce2/nodejs :0.12.2
|
下载完后查看我们的镜像,找到他的名称,等会我们会用到
创建node.js 程序
创建package.json,并写入相关信息和依赖
1
|
vi package.json
|
1
2
3
4
5
6
7
8
9
10
11
12
13
|
{
"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"
}
}
|
创建server.js
1
|
vi server.js
|
写一个最简单web 这个web基于express框架,返回hello word.注意我们监听的是8888端口
1
2
3
4
5
6
7
8
9
10
11
12
13
|
'use strict' ;
var express = require( 'express' );
var port = 8888;
var app = express();
app.get( '/' , function (req, res) {
res.send( 'hello world\n' );
});
app.listen(port);
console.log( 'running on http://localhost:' + port);
|
创建dockerfile
接下来主角上场了创建dockerfile文件 这个文件是创建镜像所必须的文件
1
|
vi dockerfile
|
docker会依照dockerfile的内容来构建一个镜像。我先给出完整的代码,再一行一行的给出解释
1
2
3
4
5
6
7
8
9
10
11
12
|
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" ]
|
我们来一句一句的解释
1
|
from hub.c.163.com /nce2/nodejs :0.12.2
|
from是构建镜像的基础源镜像,hub.c.163.com/nce2/nodejs:0.12.2 这个是镜像的名称,也就是我们一开始从国内服务器上拉下来的那个image。如果本地没有docker 会自己pull镜像。
1
2
3
|
# create app directory
run mkdir -p /home/service
workdir /home/service
|
第一句run 用于在image里创建一个文件夹,将来用于保存我们的代码。
第二句workdir是将我们创建的文件夹做为工作目录。
1
2
3
|
# bundle app source
copy . /home/service
run npm install
|
第一句的copy是把本机当前目录下的所有文件拷贝到image的/home/service文件夹下。
第二句的run 使用npm 安装我们的app据需要的所有依赖。
1
|
expose 8888
|
由于我们的web app监听的是8888端口,我们把这个端口暴露给主机,这样我就能从外部访问web了。
1
|
cmd [ "npm" , "start" ]
|
这个我相信我不用解释你也能看出来他是做什么的。运行npm start命令,这个命令会运行 node service.js来
启动我们的web app。
构建image
在你dockerfile文件所在的目录下运行下面的命令来构建一个image.
1
|
docker build -t mynodeapp .
|
别忘了最的的那个点
构建完后查看一下我们的镜像
运行镜像
1
|
docker run -d -p 8888:8888 ac5
|
-d 表明容器会在后台运行,-p 表示端口映射,把本机的8888商品映射到container的8888端口这样外网就能通过本机的8888商品访问我们的web了。
后面的ac5是我们image的id因为前3个就已经能定位出这个image所以我就没有把后边的再写出来。
通过docker ps 查看我们刚运行的container的id
打印log 7370就是我们的container id,和image id一样,你也可以全写出来,我比较懒就写前4位,已经足够标识出这个container了
1
|
docker logs 7350
|
如果你想到container里可以执行下面的命令,进入到里边后就可以像操作普通的linux 一样。如果想退出可执行exit命令。
测试
我们先通过curl 看能不能访问我们的web。
1
|
curl -i localhost:8888
|
也可以通过浏览器来看一下
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://www.cnblogs.com/li-peng/p/5827104.html