# docker 简介

enter image description here   docker 是一个开源的应用容器引擎,可以为我们提供安全、可移植、可重复的自动化部署的方式。docker 采用虚拟化的技术来虚拟化出应用程序的运行环境。如上图一样。docker 就像一艘轮船。而轮船上面的每个小箱子可以看成我们需要部署的一个个应用。使用 docker 可以充分利用服务器的系统资源,简化了自动化部署和运维的繁琐流程,减少很多因为开发环境中和生产环境中的不同引发的异常问题。从而提高生产力。   docker 三个核心概念如下:

  • 镜像(images):一个只读的模板,可以理解为应用程序的运行环境,包含了程序运行所依赖的环境和基本配置。相当于上图中的每个小箱子里面装的东西。

  • 仓库(repository):一个用于存放镜像文件的仓库。可以看做和 gitlab 一样。

  • 容器(container):一个运行应用程序的虚拟容器,他和镜像最大的区别在于容器的最上面那一层是可读可写的。 相当于上图中的每个小箱子里。

# docker 安装

# mac

官网下载地址 (opens new window),点击下载即可。

# liunx

打开终端 输入

curl https://releases.rancher.com/install-docker/17.12.sh | sh

等待安装完成。检查是否安装成功。 环境已经安装完毕。现在来开始部署应用吧。

# docker 实战

# 准备工作

# 初始化一个 NodeJs 程序

以下操作必须已经安装了 NodeJS。如果没有安装请参照之前的教程传送门 (opens new window) 首先创建一个空文件夹。并创建以下文件:

  • server.js
  • package.json
  • Dockerfile
  • .dockerignore
mkdir docker_demo
cd docker_demo
touch server.js
touch package.json
touch Dockerfile
touch .dockerignore

然后在 server.js 写入

const Koa = require('koa');
const app = new Koa();

app.use(async ctx => {
   ctx.body = 'Hello docker';
});

app.listen(3000);

在 package.json 中写入

{
 "name": "docker_demo",
 "version": "0.1.0",
 "private": true,
 "scripts": {
   "start": "node server.js"
 },
 "dependencies": {
   "koa": "^2.5.0"
}
}

测试程序。控制台输入

npm start

浏览器打开本地测试 (opens new window),如果如图所示。表示 demo 创建成功。请继续往下。

# 创建 dockerfile 文件

Dockerfile 是由一系列命令和参数构成的脚本,一个 Dockerfile 里面包含了构建整个 image 的完整命令。Docker 通过 docker build 执行 Dockerfile 中的一系列命令自动构建 image. 在.dockerignore 文件里面写入代码。表示过滤该类型的文件。类似 git 的.gitignore

# Logs
logs
*.log
npm-debug.log*

# Runtime data
pids
*.pid
*.seed

# Directory for instrumented libs generated by jscoverage/JSCover
lib-cov

# Coverage directory used by tools like istanbul
coverage

# nyc test coverage
.nyc_output

# Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files)
.grunt

# node-waf configuration
.lock-wscript

# Compiled binary addons (http://nodejs.org/api/addons.html)
build/Release

# Dependency directories
node_modules
jspm_packages

# Optional npm cache directory
.npm

# Optional REPL history
.node_repl_history
.idea
.node_modules
node_modules
.vscode

在 Dockerfile 文件中写入以下代码:

#制定node镜像的版本
FROM node:8.9-alpine
#声明作者
MAINTAINER robin
#移动当前目录下面的文件到app目录下
ADD . /app/
#进入到app目录下面,类似cd
WORKDIR /app
#安装依赖
RUN npm install
#对外暴露的端口
EXPOSE 3000
#程序启动脚本
CMD ["npm", "start"]

# 构建镜像

使用 build 命令构造镜像,注意后面那个.不能少。

docker build -t docker_demo .
robin:docker_demo robin$ docker build -t docker_demo .
Sending build context to Docker daemon  39.94kB
Step 1/7 : FROM node:8.9-alpine
---> 406f227b21f5
Step 2/7 : MAINTAINER robin
---> Using cache
---> 78d6cdbcfee2
Step 3/7 : ADD . /app/
---> 2cb30678612d
Step 4/7 : WORKDIR /app
Removing intermediate container e51377081039
---> c2b7d0f37d2d
Step 5/7 : RUN npm install
---> Running in da0c3946ca8d
npm notice created a lockfile as package-lock.json. You should commit this file.
added 38 packages in 3.323s
Removing intermediate container da0c3946ca8d
---> eecee87f10e2
Step 6/7 : EXPOSE 3000
---> Running in f3973cc168a4
Removing intermediate container f3973cc168a4
---> 2671a4c6deb4
Step 7/7 : CMD ["npm", "start"]
---> Running in dec529f754aa
Removing intermediate container dec529f754aa
---> 6ec73793d353
Successfully built 6ec73793d353
Successfully tagged docker_demo:latest

等待镜像构造完成。然后使用 images 命令查看镜像。

此时可以看到 images 已经构造完成。现在开始启动 images,并测试。

#启动镜像 -d表示后台执行,-p 9000:3000表示指定本地的9000端口隐射到容器内的3000端口,docker_demo为镜像名称
docker run -d -p 9000:3000 docker_demo
#查看容器
docker ps

此时浏览器打开 http://localhost:9000/,如果如图所示。表示容器运行正常。

如果此时本地无法打开。可以使用 log 命令查看日志。根据日志修改对应出现的对方。

# 绑定 docke hub

镜像已经存在了我们本机硬盘,那我们实际中要么上传到服务器呢?这里通常有 2 个方法。一直是自己搭建镜像仓库比如(harbor),还有就是官方的 docke hub,类似 gitlab。我们这里先以 docke hub 为列。harbor 放在下篇博客。首先需要注册 docke hub 账号,官网注册地址 (opens new window)。然后登陆。

robin:docker_demo robin$ docker login
Login with your Docker ID to push and pull images from Docker Hub. If you don't have a Docker ID, head over to https://hub.docker.com to create one.
Username:xxxxxx
Password:
Login Succeeded
robin:docker_demo robin$

登陆成功之后。需要给当前 images。添加 tag,并 push

#格式docker tag 标签名 用户名/标签名
docker tag docker_demo robin365/docker_demo
#格式docker push 用户名/标签名
docker push robin365/docker_demo

完成之后,可以登陆docke hub (opens new window)查看刚刚 push 的镜像。我们可以设置这个镜像是否公开。Public:所有人都可以下载。Private:表示自己才能下载。

这样我们已经把 images 上传到 docke hub 了,在我们需要用到这个 images 的时候可以直接通过 docker pull 命令下载使用了。

到此本教程结束。实际项目中部署可能会出现各种各样的问题,我们需要多查看 log。根据 log 去做相应修改。后面我也会整理出有关 docke 在部署 nodejs 应用中的一些比较容易出错的地方。

# dockerc 常用命令

#查看当前docker版本
docker -v
#查看当前本地所有镜像
docker images
#构造镜像,用法docker build -t 镜像名称 .
docker build -t docker_demo .
#用于容器与主机之间的数据拷贝。用法docker cp 主机文件地址 容器内地址。12d7f14v45cv为容器id。
docker cp /www/runoob 12d7f14v45cv:/www/
#创建一个新的容器并运行,-d为后台执行,-p 9000:3000前面为主机端口,后面是容器端口。docker_demo镜像名
docker run -d -p 9000:3000 docker_demo
#启动已被停止的容器
docker start docker_demo
#关闭已被启动的容器
docker stop docker_demo
#重新启动容器
docker restart docker_demo
#杀掉一个运行中的容器。
docker kill -s KILL docker_demo
#删除一个或多少容器。-f :通过SIGKILL信号强制删除一个运行中的容器-l :移除容器间的网络连接,而非容器本身-v :-v 删除与容器关联的卷
docker rm -f docker_demo、docker_demo1
#在运行的容器中执行命令。104e28f2f072容器id
sudo docker exec -it 104e28f2f072 /bin/bash
#列出容器。 -a:所有容器包含没有运行的
docker ps
#获取容器获取容器的日志 104e28f2f072容器id,-t:显示时间戳
docker logs -f -t 104e28f2f072
#登陆镜像仓库
docker login
#获取镜像
docker pull
#上传镜像
docker push
#查看指定镜像的创建历史。
docker history docker_demo

# 基于 Docker 部署 nodejs 应用

# 背景

公司基于 Vue.js 的项目最近需要部署到云端,因此需要先行在公司内部 Docker 环境下验证相关技术,因而有本文之前提。 本文展示在 Docker 容器中,应用部署 Nodejs 程序。

# 获取基础镜像

Docker Hub 中有官方 node 镜像 (opens new window),按照自己的需求直接获取对应版本的 image 即可。我获取的是8.0-alpine版本,因为基于 alpine 的 node 镜像足够小,仅有 63.7 MB。

# 获取源码

从源码库上,获取到整个源代码工程。(过程略)

# 编写 Dockerfile

首先,我们确立文档模型。目录结构如下:

~/nodejs
    Order/        [nodejs源码目录]
    Dockerfile

Dockerfile 内容如下

# 引用镜像
FROM node:8.0-alpine

# 作者
MAINTAINER yubing

# 执行命令,创建文件夹
RUN mkdir -p /home/Order

# 将Order目录拷贝到镜像里
ADD ./Order /home/Order

# 指定工作目录
WORKDIR /home/Order

# 安装依赖及构建node应用
RUN npm install
RUN npm build

# 配置系统变量,指定端口
ENV HOST 0.0.0.0
ENV PORT 8081

# 将端口8081开放
EXPOSE 8081

# 容器启动命令
CMD ["npm", "start"]

# 构建镜像

在 Dockerfile 所在目录执行 docker build 命令,构建镜像。 docker build --rm -t orderui:20180531 . 其中,--rm 是删除构建过程中,产生的临时镜像,-t 是指定镜像名称及标识,如:orderui:20180531,最后. 代表默认选择 Dockerfile 为构建文件。

# 创建容器

docker run -p 8081:8081 --name orderui -d orderui:20180531 -p 是指定端口映射,--name 给容器命名,-d 后台执行

稍等片刻,等 npm start 执行完毕后,即可访问。

# demo

# 部署 node

https://www.cnblogs.com/pass245939319/p/8473861.html