作为一个docker的初学者,为了学习更加深刻,写下这篇文章来分享自己学习中的点滴,文章中所提及的不一定是对的,希望大家能够指出来,我会持续更新,高手轻喷...
Docker简介:
Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。一个完整的Docker有以下几个部分组成:
- Docker Client客户端
- Docker Daemon守护进程
- Docker Image镜像
- Docker Container容器
环境准备:
- linux宿主机(可以联网)
- 需要部署到linux服务器里的nodejs项目
一:Docker 安装
以Centos7为例,且Docker要求操作系统必须为64位,且centos内核版本为3.1及以上。
使用 root 权限登录 Centos
查看系统内核版本信息(确保内核版本大于3.1):
uname -r
确保 yum 包更新到最新:
yum update
安装需要的软件包, yum-util 提供yum-config-manager功能,另外两个是devicemapper驱动依赖的
yum install -y yum-utils device-mapper-persistent-data lvm2
设置阿里云的yum源:
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
安装最新版本的社区版docker:
yum install docker-ce
启动docker服务,并设置开机启动:
#启动docker服务:
systemctl start docker
#设置docker服务开机启动
systemctl enable docker
#查看服务状态:
systemctl status docker
出现以下画面则说明docker服务启动成功:检验是否安装成功:
docker version
出现client和service两部分表示docker安装启动都成功了
到此为止docker服务已经安装成功了~
二:部署项目
1.从u盘中复制项目文件到Linux系统文件夹中:
- 插入u盘,
fdisk -l
获取U盘名(我的是sdb4) - 在/mnt下创建usb挂载目录:
mkdir /mnt/usb
- 将u盘挂载到/mnt/usb中:
mount /dev/sdb4 /mnt/usb
- 在/home目录下新建文件夹用来存放项目文件:
mkdir /home/hakim-app
- 复制:
cp -r /mnt/usb/mytest/* /home/hakim-app
- 最后要记得解绑usb并拔出u盘:
umount /dev/sdb4
#进入/home/hakim-app目录
cd /home/hakim-app
#查看所有文件
ls
若出现下图所示,则表示复制成功:2.拉取node基础镜像
由于此次我部署的是nodejs项目,所以需要拉取node的基础镜像,我们可以到https://hub.docker.com上查看所有的node的Dockerfile文件。
这边我使用docker pull node
来拉取node的基础镜像(默认拉取最新版本,若小伙伴需要拉取某个固定版本的镜像可以使用docker pull node:tag
)。
通过docker images
来查看基础镜像是否已经安装成功。
3.创建项目镜像
创建文件Dockerfile用来构建镜像
#到项目路径下创建Dockerfile文件
touch Dockerfile
#编辑Dockerfile
vim Dockerfile
Dockerfile的编写如下:(若不会写,请移步编写Dockerfile)
#所依靠的基础镜像
FROM node:latest
# 维护者信息
MAINTAINER hakim 614765***@qq.com
#创建文件夹用来存放项目源码和挂载卷
RUN mkdir /home/Service
#下面命令的运行目录
WORKDIR /home/Service
#将项目文件全部复制到镜像的/home/Service中
COPY . /home/Service
#下载npm依赖包
RUN npm install
#挂载两个数据卷
VOLUME /home/Service/db/
VOLUME /home/Service/files/
#对外连接的端口号
EXPOSE 3000
#容器启动命令
CMD ["npm","start"]
注意:
- 此处有一个数据卷(VOLUME)的概念:
数据卷存在于宿主机中,独立于容器,和容器的生命周期是分离的,数据卷存在于宿主机的文件系统中,数据卷可以目录也可以是文件,容器可以利用数据卷与宿主机进行数据共享,实现了容器间的数据共享和交换。
数据卷的特点:
- 容器启动的时候初始化的,如果容器使用的镜像包含了数据,这些数据也会拷贝到数据卷中。
- 容器对数据卷的修改是及时进行的。
- 数据卷的变化不会影响镜像的更新。数据卷是独立于联合文件系统,镜像是基于联合文件系统。镜像与数据卷之间不会有相互影响。
- 数据卷是宿主机中的一个目录,与容器生命周期隔离。
- 作为数据卷的一般都是数据库文件、配置文件、或者是上传的文件的保存文件夹这类会变化的文件或文件夹。
- 使用Dockerfile复制文件到镜像中去的时候不要复制需要被挂载到数据卷的文件夹或文件。所以在上例中的db和files文件夹作为数据卷需要挂在的文件不需要被复制到镜像中去。
总而言之:数据卷共享了宿主机的目录给容器,当容器被删除的时候,数据卷依旧存在在宿主机上,不会被删除,实现了数据的持久化。
在Dockerfile的当前目录下,运行
#docker build -t 容器名字 .
docker build -t hakim .
(最后有一个点,表示的是Dockerfile这个文件)去执行Dockerfile里面的命令,创建一个名为hakim的容器。
启动容器:
docker run -d -p 8080:3000 hakim
最后关键的地方就是数据卷的挂载(理解了很久):
我们先进入容器内部看看容器内部的样子:
docker exec -it [容器id] bash
我们可以看到有db和files两个文件夹,这是我们挂载的空的数据卷
运行命令docker inspect [容器id]
查找到我们挂载的卷的宿主机位置
最后一步就是将这些数据卷的文件copy到宿主机的相对位置即可实现与容器的数据共享,如下:
打开浏览器:
192.168.3.X:8080
(输入宿主机的IP地址+docker容器运行时的端口号)即可访问docker容器中的服务:项目到这边也就基本简单部署成功了。
请务必保证自己能够动手完成整个实验,只看文字很简单,真正操作的时候会遇到各种各样的问题,解决问题的过程才是收获的过程。