一.Docker的由来
Docker 最初是 dotCloud 公司创始人Solomon Hykes 在法国期间发起的一个公司内部项目。
2010年的专门做PAAS平台,但是到了2013年的时候,像亚马逊,微软,Google都开始做PAAS平台。
到了2013年,公司资金链断裂,不得不倒闭,于是将公司内的核心技术对外开源,核心技术就是Docker。
由于开源了Docker,到了2014年的时候,得到了各轮融资,于是公司开始全神贯注的维护Docker。
二.Docker的思想
Docker是一种容器化技术,也是一种虚拟化技术
封装:将需要的操作系统,环境,软件封装到一个镜像中。
标准化:
运输的标准化:Docker提供了中央仓库,所有官方的镜像都放在了这个中央仓库中,当需要使用某一个镜像时,通过相应的方式拉取即可。
命令的标准化:Docker提供了一些列的命令,帮助我们去获取镜像,管理容器等等操作。
提供了REST的API:基于标准REST的API衍生出了很多的图形化界面,如Rancher等。
隔离性:Docker在运行镜像时,会在Linux的内核中,单独的开辟一片空间,这片空间不会影响到其他程序。容器是完全使用沙箱机制,相互隔离,容器性能开销极低。
镜像(Image):Docker 镜像(Image),就相当于是一个 root 文件系统。比如官方镜像 ubuntu:16.04 就包含了完整的一套 Ubuntu16.04 最小系统的 root 文件系统。
容器(Container):镜像(Image)和容器(Container)的关系,就像是面向对象程序设计中的类和对象一样,镜像是静态的定义,容器是镜像运行时的实体。容器可以被创建、启动、停止、删除、暂停等。
仓库(Repository):仓库可看成一个代码控制中心,用来保存镜像。
三、Docker的安装
3.1 下载Docker依赖的环境
安装Docker,需要先将依赖的环境全部下载,就像Maven依赖JDK一样。
yum -y install yum-utils device-mapper-persistent-data lvm2
3.2 指定Docker镜像源
默认情况下,下载Docker会从国外服务器下载,速度较慢,我们可以设置为阿里云镜像源,速度更快。
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
3.3 安装Docker
采用yum的方式安装。
yum makecache fast
yum -y install docker-ce
3.4 启动Docker并测试
安装成功后,需要手动启动,设置为开机自启,并测试。
# 启动Docker服务
systemctl start docker
# 设置开机自动启动
systemctl enable docker
# 查看Docker服务状态
systemctl status docker
#不开机自动启动docker
systemctl disable docker
#停止docker
systemctl stop docker
# 重启
systemctl restart docker
四、Docker的中央仓库【重点
】
Docker官方的中央仓库:这个仓库是镜像最全的,但是下载速度较慢。
https://hub.docker.com/
国内的镜像网站:网易蜂巢,daoCloud等,下载速度快,但是镜像相对不全。
登录
Hub · DaoCloud (推荐使用)
在公司内部会采用私服的方式拉取镜像,需要添加配置,如下……
# 设置从哪个镜像源下载镜像
vi /etc/docker/daemon.json
# 设置从ustc下载镜像, 速度快
{
"registry-mirrors": ["https://docker.mirrors.ustc.edu.cn"]
}
# 重启docker服务
systemctl restart docker
# 需要创建或修改/etc/docker/daemon.json,并添加如下内容,"ip:port"可以编写多个。
{"registry-mirrors": ["https://registry.docker-cn.com"],"insecure-registries": ["ip:port"]
}
# 重启docker服务
systemctl restart docker
五、镜像的操作【重点
】
5.1 搜索镜像
搜索中央仓库镜像
docker search 镜像名称
5.2 拉取镜像
从中央仓库拉取镜像到本地
docker pull 镜像名称[:tag]
# 举个栗子:docker pull daocloud.io/library/tomcat:8.5.15-jre8
5.3 查看本地全部镜像
查看本地已经安装过的镜像信息,包含标识,名称,版本,更新时间,大小
docker images
5.4 删除本地镜像
镜像会占用磁盘空间,可以直接手动删除,
标识
通过 查看获取
docker rmi 镜像的标识 | 镜像名称:tag
docker rmi b8dfe9ade316
docker rmi daocloud.io/library/tomcat:8.5.15-jre8
5.5 镜像的导入导出
如果出现网络故障,可以采过硬盘的方式传输镜像,虽然不规范,但是有效。
但是这种方式导出的镜像名称和版本都是null,需要手动修改
# 将本地的镜像导出
docker save -o 导出的路径 镜像id
doeker save -o /usr/local/abc.tar b8dfe9ade316
# 加载本地的镜像文件
docker load -i 镜像文件
docker load -i /usr/local/abc.tar
# 修改镜像名称
docker tag 镜像id 新镜像名称:版本
docker tag b8dfe9ade316 mytomcat:1.0
六、容器操作【重点
】
6.1 运行容器
运行容器需要指定具体镜像,如果镜像不存在,会直接下载
# 简单操作
docker run 镜像的标识 | 镜像名称[:tag]
docker run b8dfe9ade316
docker run daocloud.io/library/tomcat:8.5.15-jre8
# 常用的参数
docker run -di -p 宿主机端口:容器端口 --name 容器名称 镜像的标识|镜像名称[:tag]
docker run -di -p 8090:8080 --name my_container b8dfe9ade316
# -i 表示运行容器
# -d:代表后台运行容器(守护式进程)
# -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用。
# -it : 创建交互式进程
# -p 宿主机端口:容器端口:为了映射当前Linux的端口和容器的端口
# --name 容器名称:指定容器的名称
守护式进程: 创建容器,自动后台运行容器
交互式进程:创建容器,自动进入容器,退出容器后,自动关闭容器
6.2 查看正在运行的容器
查看全部正在运行的容器信息
docker ps [-qa]
# -a:查看全部的容器,包括没有运行
# -q:只查看容器的标识
6.3 查看容器日志
查看容器日志,以查看容器运行的信息
docker logs -f 容器id
# -f:可以滚动查看日志的最后几行
6.4 进入容器内容部
可以进入容器内部进行操作
docker exec -it 容器id bash
docker exec -it 容器名称 bash
6.5 复制内容到容器
将宿主机的文件复制到容器内部的指定目录
docker cp 文件名称 容器id:容器内部路径
6.6 重启&启动&停止&删除容器
容器的启动,停止,删除等操作,后续经常会使用到
# 重新启动容器
docker restart 容器id
# 启动停止运行的容器
docker start 容器id
# 停止指定的容器(删除容器前,需要先停止容器)
docker stop 容器id
# 停止全部容器
docker stop $(docker ps -qa)
# 删除指定容器
docker rm 容器id
# 删除全部容器
docker rm $(docker ps -qa)
七、Docker应用
7.1 Docker安装Tomcat
运行Tomcat容器,为部署SSM工程做准备
docker run -d -p 8080:8080 --name tomcat daocloud.io/library/tomcat:8.5.15-jre8
7.2 Docker安装MySQL
运行MySQL容器,为部署SSM工程做准备
docker run -d -p 3307:3306 --name mysql -e MYSQL_ROOT_PASSWORD=123456 daocloud.io/library/mysql:5.7.4
# 宿主机中通过 3366连接 容器中的mysql
[root@localhost logs]# mysql -uroot -P 3366 -proot -h 192.168.1.135