Docker的思想
- 集装箱:会将所有需要的内容放到不同的集装箱中,谁需要这些环境就直接拿到这个集装箱就可以了。
- 标准化:
- 运输的标准化:Docker有一个码头,所有上传的集装箱都放在了这个码头上,当谁需要某一个环境,就直接指派大鱼去搬运这个集装箱就可以了。
- 命令的标准化:Docker提供了一些列的命令,帮助我们去获取集装箱等等操作。
- 提供了REST的API:衍生出了很多的图形化界面,Rancher。
- 隔离性:Docker在运行集装箱内的内容时,会在Linux的内核中,单独的开辟一片空间,这片空间不会影响到其他程序。
- 中央仓库|注册中心:超级码头,上面放的就是集装箱
- 镜像:就是集装箱
- 容器:运行起来的镜像
中央仓库:集中放置镜像的地方
镜像:集装箱
容器:运行起来的镜像
Docker的安装
yum -y install yum-utils device-mapper-persistent-data lvm2
指定Docker镜像源(默认是外国源 我们可以设置为阿里云)
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
安装Docker
yum makecache fast yum -y install docker-ce
启动Docker并测试
# 启动Docker服务 systemctl start docker # 设置开机自动启动 systemctl enable docker # 测试 运行hello-world 镜像 根据这个镜像 创建容器 docker run hello-world
Docker的中央仓库【
重点
】
Docker官方的中央仓库:这个仓库是镜像最全的,但是下载速度较慢。
https://hub.docker.com/(opens new window)
国内的镜像网站:网易蜂巢,daoCloud等,下载速度快,但是镜像相对不全。
https://c.163yun.com/hub#/home(opens new window)
http://hub.daocloud.io/ (opens new window)(推荐使用)
镜像的操作
拉取镜像
docker pull 镜像名称[:tag]
# 举个栗子:docker pull daocloud.io/library/tomcat:9.0.0.M22
查看本地全部镜像
docker images
删除本地镜像
docker rmi 镜像的标识
容器操作
运行容器
# 简单操作 docker run 镜像的标识|镜像名称[:tag] # 常用的参数 docker run -d -p 宿主机端口:容器端口 --name 容器名称 镜像的标识|镜像名称[:tag] # -d:代表后台运行容器 # -p 宿主机端口:容器端口:为了映射当前Linux的端口和容器的端口 # --name 容器名称:指定容器的名称
查看正在运行的容器
docker ps [-qa] # -a:查看全部的容器,包括没有运行 # -q:只查看容器的标识
查看容器日志
查看容器日志,以查看容器运行的信息
docker logs -f 容器id # -f:可以滚动查看日志的最后几行
进入容器内容部
可以进入容器内部进行操作
docker exec -it 容器id bash
复制内容到容器
将宿主机的文件复制到容器内部的指定目录
docker cp 文件名称 容器id:容器内部路径
将容器内部的文件复制到宿主机
docker cp 容器id:容器目录 宿主机目录
重启&启动&停止&删除容器
# 重新启动容器 docker restart 容器id # 启动停止运行的容器 docker start 容器id # 停止指定的容器(删除容器前,需要先停止容器) docker stop 容器id # 停止全部容器 docker stop $(docker ps -qa) # 删除指定容器 docker rm 容器id # 删除全部容器 docker rm $(docker ps -qa)
提交运行时容器成为镜像
docker commit -a='作者' -m='备注' 运行时容器ID 新镜像名称
查看容器元信息
docker inspect 容器id
设置容器自动启动
docker update --restart=always 容器id
Docker应用
docker 安装 Tomcat
运行Tomcat容器,为部署SSM工程做准备
docker run -d -p 8080:8080 --name tomcat daocloud.io/library/tomcat:9.0.0.M22
Docker安装MySQL
运行MySQL容器,为部署SSM工程做准备
注意:如果之前在服务器上已经安装过MySQL了,并且MySQL是正在运行的,那么使用docker运行mysql就会出错!!!
我们需要停止服务器上正在运行的mysql,并且设置为禁止开机启动!
使用命令:
systemctl stop mysqld.service systemctl disable mysqld.service
然后才可以使用docker运行mysql,否则之前运行的mysql和docker运行的端口有冲突!
docker run -d -p 3306:3306 --name mysql -e MYSQL_ROOT_PASSWORD=root daocloud.io/library/mysql:5.7.5-m15
部署SSM工程
- 修改SSM工程环境,设置为Linux中Docker容器的信息
- 通过Maven的package重新打成war包
- 将Windows下的war包复制到Linux中
- 通过docker命令将宿主机的war包复制到容器内部
- 测试访问SSM工程
数据卷
为了部署SSM的工程,需要使用到cp的命令将宿主机内的ssm.war文件复制到容器内部。
数据卷:将宿主机的一个目录映射到容器的一个目录中。
可以在宿主机中操作目录中的内容,那么容器内部映射的文件,也会跟着一起改变
创建数据卷
创建数据卷之后,默认会存放在一个目录下 /var/lib/docker/volumes/数据卷名称/_data
docker volume create 数据卷名称
查看数据卷详情
查看数据卷的详细信息,可以查询到存放路径,创建时间等等
docker volume inspect 数据卷名称
查看全部数据卷
查看全部数据卷信息
docker volume ls
删除数据卷
删除指定数据卷
docker volume rm 数据卷名称
容器映射数据卷
映射有两种方式:
- 通过数据卷名称映射,如果数据卷不存在。Docker会帮你自动创建,会将容器内部自带的文件,存储在默认的存放路径中。
- 通过路径映射数据卷,直接指定一个路径作为数据卷的存放位置。但是这个路径下是空的。
# 通过数据卷名称映射 docker run -v 数据卷名称:容器内部的路径 镜像id # 通过路径映射数据卷 docker run -v 路径:容器内部的路径 镜像id # 举个例子: docker run -d -p 8080:8080 -v /root/webapps/:/usr/local/tomcat/webapps --name tomcat e71