目录
2. CentOS7用阿里云Docker Yum源在线安装Docker
3.8 使用Dockerfile创建新的镜像(注意:末尾有一个点,表示当前路径)
4.8 创建\启动\进入容器(run=create+start)
1. Docker是什么?
Docker是一个由GO语言写的程序运行的“容器”(Linux containers, LXCs);
它是完整的一套容器管理系统。
Docker提供了一组命令,让用户更加方便直接地使用容器技术,而无需要过多关心底层内核技术。
注1:什么是容器
一个容器就相当于一个虚拟机。
注2:docker用途,目前有三大类
1、提供一次性的环境。比如,本地测试他人的软件、持续集成的时候提供单元测试和构建的环境。
2、提供弹性的云服务。因为 Docker 容器可以随开随关,很适合动态扩容和缩容。
3、组建微服务架构。通过多个容器,一台机器可以跑多个服务,因此在本机就可以模拟出微服务架构。
2. CentOS7用阿里云Docker Yum源在线安装Docker
见另一篇笔记
3. 镜像
Docker 运行容器前需要本地存在对应的镜像, 如果镜像不存在, Docker 会尝试先从默认镜像仓库下载。
(默认使用 Docker Hub 公共注册服务器中的仓库), 用户也可以通过配置,使用自定义的镜像仓库。
镜像相关操作:
3.1 配置加速器
国内从Docker Hub下载镜像速度很慢,我们可以配置阿里云专属加速器来解决。
3.1.1 浏览器访问并登陆阿里云(淘宝或支付宝帐号登陆也可以)
https://www.aliyun.com/
3.1.2 登陆后,进入阿里云“控制台”,搜索“容器镜像服务”,然后点击菜单:“镜像中心”-->“镜像加速器”
最后,将容器右边的“加速器地址”复制下来即可
https://oyi1xr7k.mirror.aliyuncs.com(这里是我的加速器地址)
3.1.3 设置容器镜像服务的密码(可选)
容器镜像服务(Container Registry)提供多地域镜像托管能力,稳定的国内外镜像构建服务,便捷的镜像授权功能;
方便用户进行镜像全生命周期管理。在开通流程中,您需要设置独立于账号密码的Registry登录密码,便于镜像的上传、下载。
注:此步骤为可选,如果需要使用阿里云来管理你的镜像 ,此步骤必须设置。
3.1.4 修改docker相关配置
vi /etc/docker/daemon.json
添加下面内容(地址替换成上面的加速器地址):
"registry-mirrors":["你的阿里云专属加速器地址"]
例如:
{"registry-mirrors":["https://g72i77c9.mirror.aliyuncs.com"]}
注:在这里可以先将registry-mirrors换成自己的阿里云专属加速器地址后,在复制到工具里面去执行(方便)
3.1.5 重新加载daemon
systemctl daemon-reload
3.1.6 重启docker
systemctl restart docker
3.2 搜索镜像
$ docker search 镜像名称
例如:docker search mysql
3.3 下载镜像
docker pull 镜像名
例如, 获取一个 centos 系统的基础镜像可以使用如下的命令
——未指定版本一般会使用latest(最新的)版本
$ docker pull centos
——或者直接指定版本
$ docker pull centos:版本号
3.4 查看宿主机上的镜像
$ docker images
注1:查看image位置
## /var/lib/docker为docker默认安装目录
cd /var/lib/docker/containers
ls
3.5 删除镜像
$ docker rmi 镜像ID/标签
例如:
$ docker rmi 2ca708c1c9cc
$ docker rmi centos:latest 或 docker rmi centos:版本号
注1:如果提示镜像被使用,需要先停止某个ID的容器,那么要先删除容器再删除镜像。或者强制删除镜像
$ docker rmi -f centos:版本号
-f, -force: 强制删除镜像, 即使有容器依赖它
注意, 通常并不推荐使用-f参数来强制删除一个存在容器依赖的镜像。 正确的做法是,先删除依赖该镜像的所有容器, 再来删除镜像。
3.6 保存镜像
$ docker commit -m="description about images" --author="author" {container_id} {repository/images_name:tag}
3.7 推送镜像到代码仓库(以阿里云docker平台为例)
$ docker login --username=your_username registry.cn-beijing.aliyuncs.com
$ docker tag [ImageId] registry.cn-beijing.aliyuncs.com/[命名空间]/[仓库名称]:[镜像版本号]
$ docker push registry.cn-beijing.aliyuncs.com/[命名空间]/[仓库名称]:[镜像版本号]
3.8 使用Dockerfile创建新的镜像(注意:末尾有一个点,表示当前路径)
$ docker build -t "repository/images_name:tag".
4. Docker容器
容器是Docker的另一个核心概念。简单来说,容器是镜像的一个运行实例。所不同的是;镜像是静态的只读文件,而容器带有运行时需要的可写文件层,同时,容器中的应用进程处于运行状态
如何理解:
类 = 实例 镜像 = 容器
常用操作:
4.1 启动、停止、重启容器命令
$ docker start 容器ID|name|name:tag ——启动
$ docker stop 容器ID|name|name:tag ——停止
$ docker restart 容器ID|name|name:tag ——重启
4.2 查看当前运行的容器
$ docker ps
4.3 查看所有容器
$ docker ps -a
4.4 删除容器
$ docker rm 容器ID
注:主要支持的选项包括:
-f, --force=false 是否强行终止并删除一个运行中的容器。
-1, --link=false :删除容器的连接 ,但保留容器。
-v, --volumes=false :删除容器挂载的数据卷。
4.5 创建容器(重点)
$ docker create -it centos:latest
$ docker create -it --name tomcat01 centos:latest
① 命令说明
create:关键字
centos:latest:即镜像名字:版本(或镜像ID),将使用指定镜像创建容器。另外,Docker会检查本地是否存在指定的镜像;
不存在就从公有仓库下载
-it:是两个参数,-i:interactive容器具有交互功能,-t:容器将提供伪终端。
--name:指定生成的容器的名字,允许空,如果不指定会自动生成。
② 此时,通过如下命令,可以查看到刚刚创建的容器
$ docker ps - a
③ create命令新建的容器处于停止状态,可以使用start命令来启动它
$ docker start 容器ID
4.6 启动容器(重点)
$ docker start 容器ID/name
注:docker ps 查看已启动容器,注意:此时容器状态为UP,Exited,Created
4.7 进入容器(重点)
$ docker exec -it 容器ID/容器NAME /bin/bash
## 简写$ docker exec -it 容器ID/容器NAME bash
注:只有在容器启动的时候即UP状态才能进入容器终端
4.8 创建\启动\进入容器(run=create+start)
# 新建->启动->进入容器
$ docker run -it centos:latest /bin/bash
# 指定了端口号
$ docker run -it -p 7001:8001 centos:latest /bin/bash
# 使用 -P 标记时,Docker 会随机映射一个 49000~49900 的端口
$ docker run -it -P --name tomcat03 centos:latest /bin/bash
# 此命令没有进入容器,可以之后再进入
更多的时候,需要让 Docker 容器在后台以守护态( Daemonized )形式运行 此时,可以通过添加-d参数来实现:
$ docker run -it -d --name webapp centos:latest
$ docker exec -it webapp /bin/bash
参数说明:
-p:端口映射,格式为:主机(宿主)端口:容器端口
-P: 注意是大写P,使用 -P 标记时,Docker 会随机映射一个 49000~49900 的端口
-d:后台运行模式
--name:容器的名字
4.9 退出容器
退出时如果想继续运行容器:按顺序按【ctrl+p】,【ctrl+q】
如果不想继续运行:按【ctrl+d】或输入exit
4.10 宿主机和docker容器之间复制文件
$ docker cp 宿主机绝对路径 容器id:路径