Docker的思想
1.集装箱
会将所有需要的内容放到不同的集装箱中,谁需要谁来取。解决了测试和开发环境不同导致的问题。
2.标准化
1.运输的标准化:Docker有一个码头,所有集装箱放在这个码头上面,就是相当于maven的中央仓库。
谁需要这个环境就谁去取就可以了。
2.命令的标准化:Docker提供了一些列的命令,帮助我们去获取集装箱。
3.提供了REST的API:衍生出了很多的图形化界面,Rancher。
3.隔离性:
Docker会在linux的内核中单独开辟一片空间,不会影响到其他程序的运行。
中央仓库(超级码头)
镜像就是(集装箱)
容器(运行起来的镜像)
1.下载关于Docker的依赖环境
yum -y install yum-utils device-mapper-persistent-data lvm2
2.设置下载Docker的镜像源
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
3.安装Docker
yum makecache fast
yum -y install docker-ce
4.启动Docker,并设置为开机自动启动,测试
启动Docker服务
systemctl start docker
设置开机自动启动
systemctl enable docker
测试
docker run hello-world
2.3 Docker的中央仓库
Docker官方的中央仓库: 这个仓库是镜像最全的,但是下载速度较慢。
https://hub.docker.com/
国内的镜像网站:网易蜂巢、daoCloud。。。
https://c.163yun.com/hub#/home
https://hub.daocloud.io/ (推荐使用)
在公司内部会采用私服的方式拉取镜像。(添加配置)
需要在/etc/docker/daemon.json
{
“registry-mirrors”: [“https://registry.docker-cn.com”],
“insecure-registries”: ["ip:port]
}
ip:port
公司私服的ip和port
重启两个服务
systemctl daemon-reload
systemctl restart docker
- 拉取镜像到本地
docker pull 镜像名称[:tag]
举个例子 tomcat
docker pull daocloud.io/library/tomcat:8.5.15-jre8(默认是去中央仓库去拉取,手动写路径)
- 查看全部本地的镜像
docker images
- 删除本地镜像
docker rmi 镜像的标识
- 镜像的导入导出(不规范)
将本地的镜像导出
docker save -o 导出的路径 镜像id
加载本地的镜像文件
docker load -i 镜像文件
修改镜像名称
docker tag 镜像id 新镜像名称:版本
2.5 容器的操作
- 运行容器
简单操作
docker run 镜像的标识|镜像名称[tag]
常用的参数
docker run -d -p 宿主机端口:容器端口 --name 容器名称 镜像的标识|镜像名称[tag]
-d: 代表后台运行容器
-p: 宿主机端口:容器端口: 为了映射当前Linux的端口和容器的端口
–name 容器名称: 指定容器的名称
- 查看正在运行的容器
docker ps [OPTIONS]
OPTIONS说明:
-a: 代表查看全部的容器,包括没有运行
-q: 只查看容器的标识
-f: 根据条件过滤显示的内容
–format: 指定返回值的模板文件
-l: 显示最近创建的容器
-n: 列出最近创建的n个容器
–no-trunc: 不截断输出
-s: 显示总的文件大小
- 查看容器的日志
docker logs -f 容器id
-f: 可以滚动查看日志的最后几行
- 进入到容器内部
docker exec -it 容器id bash
- 删除容器(删除容器前,需要先停止容器)
docker stop 容器id
停止指定的容器
docker stop $(docker ps -qa)
停止全部容器
docker rm 镜像id
删除指定容器
docker rm $(docker ps -qa)
删除全部容器
#6. 启动容器
docker start 容器id
三.Docker应用
3.1 准备SSM工程
MySQL数据库的连接用户名和密码改变了,修改db.propreties
项目重新打包
mvn clean package -DskipTests
项目地址
链接: https://pan.baidu.com/s/1F4xTLoOFCMb7rl1VUrBASA 密码: bgjw
3.2 准备MySQL容器
运行MySQL容器
docker run -d -p 3306:3306 --name mysql -e MYSQL_ROOT_PASSWORD=root daocloud.io/library/mysql:5.7.4
3.3 准备Tomcat容器
运行Tomcat容器,在上面容器操作中已经搞定,只需要将SSM项目的war包部署到Tomcat容器内部
可以通过命令将宿主机的内容复制到容器内部
docker cp 文件名称 容器id:容器内部路径
举个例子
docker cp ssm.war fe:/usr/local/tomcat/webapps/
3.4数据卷
为了部署SSM的工程,需要使用到cp的命令将宿主机内的ssm.war文件复制到容器内部。
数据卷:将宿主机的一个目录映射到容器的一个目录中。
可以在宿主机中操作目录中的内容,那么容器内部映射的文件,也会跟着一起改变。
- 创建数据卷
docker volume create 数据卷名称
创建数据卷之后默认会存放在一个目录下 /var/lib/docker/volumes/数据卷名称/_data
- 查看数据卷的详细信息
docker volume inspect 数据卷名称
- 查看全部数据卷
docker volume ls
- 删除数据卷
docker volume rm 数据卷名称
- 应用数据卷
当你映射数据卷时,如果数据卷不存在。Docker会帮你自动创建
docker run -v 数据卷名称:容器内部路径 镜像id
直接指定一个路径作为数据卷的存放位置。这个路径下是空的。
docker run -v 路径:容器内部的路径 镜像id
四.Docker自定义镜像
中央仓库上的镜像,也是Docker的用户自己上传过去的。
- 创建一个Dockerfile文件,并且指定自定义镜像信息。
Dockerfile文件中常用的内容
from: 指定当前自定义镜像依赖的环境
copy: 将相对路径下的内容复制到自定义镜像中
workdir: 声明镜像的默认工作目录
cmd: 需要执行的命令(在workdir下执行的,cmd可以写多个,只以最后一个为准)
举个例子,自定义一个tomcat镜像,并且将ssm.war部署到tomcat中
from daocloud.io/library/tomcat:8.5.15-jre8
copy ssm.war /usr/local/tomcat/webapps
- 将准备好的Dockerfile和相应的文件拖拽到Linux操作系统中,通过Docker的命令制作镜像
docker build -t 镜像名称:[tag] .