二.为什么说Docker是容器化技术?百度百科:Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows操作系统的机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。
docker官网:http://www.docker.com
三.Docker 理念
- 容器化技术的特点:
- 标准化:每个容器都是标准化、可移植的,因为他们直接运行在宿主机的内核上
- 隔离:容器互相隔离,互不干扰,独立运行
- 高性能:容器性能开销极低,可以实现分钟级甚至秒级的部署和启动
- 版本:CE(Community Edition:社区版)和 EE(Enterprise Edition:企业版)
四.Docker 架构Build,Ship and Run Any App,Anywhere,在任何地方构建、 发布并运行任何应用程序(一次封装,到处运行)
docker 由三部分组成:
- Client 客户端
- docker 主机
- Registry 镜像仓库服务器
docker daemon:
- docker 安装后,会以后台运行、守护进程的形式存在
- images 镜像: 镜像可以用来创建 docker 容器,一个镜像可以创建很多容器
- containers: 镜像和容器的关系类似面向对象设计中的类和对象, 镜像是容器的模板,容器是基于镜像创建出来的。 容器可以被创建、启动、停止、删除等等。
Registry:
- 镜像注册服务器 https://hub.docker.com 一个 docker Registry(仓库注册服务器) 中可以包含多个 Repository(仓库); 每个仓库可以包含多个标签/版本(Tag);每个标签对应一个镜像。 仓库分为公开仓库(Public)和私有仓库(Private)两种形式,公开仓库就是 docker 官方仓库,私有仓库是自己搭建的 docker 私服
五.CentOS7 安装 docker (1)安装需要的软件包:Client:
- docker 终端 安装好 docker 中,同时包含了 docker 客户端,客户端负责执行 docker 命令, 发送给 docker 主机中的 docker 守护进程,例如:从仓库下载镜像,通过镜像创 建容器等等
yum install -y yum-utils device-mapper-persistent-data lvm2
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
yum makecache fas
yum install -y docker-ce docker-ce-cli containerd.io
注意第一次安装可能会出现错误,重新执行一下安装的命令就好了
systemctl start docker # 启动docker
systemctl enable docker # 设置开机自启动
docker version
systemctl stop docker
yum remove -y docker-ce
rm -rf /var/lib/docker
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://ny5dsu6o.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker
七.Docker 常用命令
(1).Docker 基本命令
-
版本信息:
docker version
-
详细信息:
docker info
-
帮助文档:
docker --help 列出所有的docker命令
-
启动Docker服务:
systemctl start docker
-
关闭Docker服务:
systemctl stop docker
-
查看Docker状态:
systemctl status docker
-
重启Docker服务:
systemctl restart docker
-
设置Docker服务跟随虚拟机开机自启:
systemctl enable docker
-
取消Docker服务跟随虚拟机开机自启:
systemctl disable docker
-
查看所有的本机镜像:
docker images [-q|--no-trunc]
,-q:查看镜像ID --no-trunc:查看完成的镜像ID
-
查找镜像:
docker search 镜像名称
-
下载镜像:
docker pull 镜像名称:版本号
,不加版本号默认是latest最新版
-
删除镜像:
docker rmi [-f] 镜像名|镜像ID:版本号
,删除指定版本镜像,版本为latest版本号可以省略,[-f]:强制删除
-
批量删除:
docker rmi [-f] mysql tomcat redis
,除多个镜像,使用空格间隔不同的镜像名称
我就不演示了
- 删除全部镜像:
docker rmi -f $(docker images -q)
我就不演示了
- 查看镜像详情:
docker inspect 镜像名|镜像ID
-
列出所有正在运行的容器,不包含已停止的容器(容器怎么运行可以看后面):
docker ps
-
列出当前所有已经创建的容器:
docker ps [-aq]
-
创建容器:
docker create 镜像名称
# 根据镜像名创建一个容器
docker create --name tomcat1 镜像名称
# 根据镜像创建名为 tomcat1 的容器
docker create 镜像 id
# 根据镜像 id 新建一个容器
- 启动、停止、重启容器:
docker start 容器名|容器ID
docker stop 容器名|容器ID
docker restart 容器名|容器ID
docker kill 容器名|容器ID
根据容器名强制停止一个容器
-
创建并启动容器:
docker run --name tomcat2 tomcat
当本地镜像存在时,相当于 docker create + docker start
当本地镜像不存在时,相当于 docker pull + docker create + docker start
-
删除容器:
docker rm 容器名称
#删除未启动的容器
docker rm -f 容器名称
#强制删除已启动的容器
docker rm -f $(docker ps -qa)
#删除所有容器,包括正在运行的容器
我就不演示了
docker ps -a -q | xargs docker rm
#删除所有容器,不包括正在运行的容器
我就不演示了
-
交互式启动:
docker run -it --name qiu 镜像名|镜像ID
-
进入容器:
docker exec -it 容器ID|容器名称 /bin/bash
-
退出容器:
ctrl + p + q
# 不停止退出容器
exit
#容器停止退出,此时执行
- 启动守护式容器:
docker run -d --name qiu 镜像名|镜像ID
推荐直接使用:docker run -itd --name qiu 镜像名|镜像ID
docker pull centos:7
(4)做一个例子
将宿主机根目录中的 qiu 挂载到容器根目录中的 qiu
(5)挂载数据卷docker run -itd -v /qiu:/qiu --name myMysql mysql
-v:挂载数据卷格式:
/宿主机目录(文件):/容器内目录(文件)
目录必须是绝对路径
如果目录不存在,
则自动创建
可以挂载多个数据卷
(6)查看数据卷是否挂载成功
docker inspect myMysql
首先进入容器,在容器的数据卷挂载目录中创建文件并写入内容
然后退出容器,查看宿主机挂载目录,可以看到同步更新的文件
首先停止容器
然后在宿主机修改共享数据 接下来启动前面的容器,
查看共享数据文件,发现数据在容器中同步
首先删除容器
然后在宿主机修改共享数据
接着重新创建容器并挂载数据卷
发现数据在容器中恢复
docker run -it -v /dataVolumeHost31:/dataVolumeContainer31 -v /dataVolumeHost32:/dataVolumeContainer32 --name centos3 centos:7
docker run -it -v /dataVolumeHost:/dataVolumeContainer4 --name centos4 centos:7
docker run -it -v /dataVolumeHost:/dataVolumeContainer5 --name centos5 centos:7
创建并运行tomcat容器
docker run -d -p 8080:8080 -v /docker/tomcat/webapps:/usr/local/tomcat/webapps -v /docker/tomcat/logs:/usr/local/tomcat/logs --name qiu_tomcat tomcat:8.5
准备一个index.html页面,使用 ftp 工具上到 /docker/tomcat/webapps/qbb 中
浏览器访问一下:http://192.168.137.72:8080/qbb/
(2)部署MySQL也可以查看一下tomcat的日志:
docker logs -tf --tail 20 atguigu_tomcat
docker run -d -p 3306:3306 -v /docker/mysql/conf:/etc/mysql/conf.d -v /docker/mysql/logs:/logs -v /docker/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root --name atguigu_mysql mysql:5.7
docker commit 容器名 镜像名称:版本号
docker save -o 压缩文件名称 镜像名称:版本号
docker load -i 压缩文件名称
/docker/tomcat/webapps/qbb
copy到 qiu_tomcat这个容器下的/usr/local/tomcat/webapps/ROOT
目录
docker cp /docker/tomcat/webapps/qbb qiu_tomcat:/usr/local/tomcat/webapps/ROOT
docker exec -it qiu_tomcat /bin/bash
,查看index.html是否赋值付过来了
③浏览器访问一下:http://192.168.137.72:8080/
④生成镜像;注意:要先退出容器(exit)
docker commit -a "qiuqiu<startqbb@163.com>" -m "create image from container" qiu_tomcat qbb/mytomcat:1.0
mkdir -p /opt/docker
docker save -o /opt/docker/qbb_mytomcat_v1.0 qbb/mytomcat:1.0
docker rm -f qiu_tomcat
docker rmi 9ddc19a406d0
docker load -i /opt/docker/qbb_mytomcat_v1.0
docker run -d -p 8080:8080 --name mytomcat qbb/mytomcat:1.0
docker pull nacos/nacos-server
:下载nacos镜像
docker run --env MODE=standalone --name nacos -d -p 8848:8848 nacos/nacos-server
:以单机的方式启动nacos
ip:8848/nacos
:浏览器访问一下,账号:nacos 密码:nacos
docker pull bladex/sentinel-dashboard
:下载sentinel镜像
docker run --name sentinel -d -p 8858:8858 bladex/sentinel-dashboard
:启动sentinel
ip:8858
:浏览器访问一下,账号:sentinel 密码:sentinel
cd /
:到linux根目录
mkdir -p /docker/nginx/conf
:创建多级目录,挂载nginx配置文件
docker run -d -p 80:80 -v /docker/nginx/conf/nginx.conf:/etc/nginx/nginx.conf -v /docker/nginx/logs:/var/log/nginx -v /docker/nginx/html:/usr/share/nginx/html --name=atguigu_nginx nginx:latest
:下载镜像,创建容器并启动
systemctl enable docker
docker run -d --restart=always --name 设置容器名 使用的镜像
docker update --restart=always 容器ID(或者容器名)
docker update <容器id,可多个,空格分隔如:111 2222 222> --restart=no 或always