Docker系列:
Docker系列(一): docker介绍&&安装(含离线安装)
Docker系列(二): 搭建docker镜像仓库-Nexus、Harbor
Docker系列(三):Idea使用docker打包和发布springboot项目
目录
①修改/etc/docker/daemon.json(如果没有新建)
一、Docker介绍
(一)、docker是什么
Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源。
Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。
容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app),更重要的是容器性能开销极低。
Docker 从 17.03 版本之后分为 CE(Community Edition: 社区版) 和 EE(Enterprise Edition: 企业版),我们用社区版就可以了。
(二)、应用场景
Web 应用的自动化打包和发布。
自动化测试和持续集成、发布。
在服务型环境中部署和调整数据库或其他的后台应用。
从头编译或者扩展现有的 OpenShift 或 Cloud Foundry 平台来搭建自己的 PaaS 环境。
(三)、docker优点
灵活:即使是复杂的应用程序也可封装。
轻量级:容器利用并共享主机内核。
便携式:您可以在本地构建,部署到云上并在任何地方运行。
可扩展性:您可以增加和自动分发容器副本。
可堆叠:您可以垂直堆叠服务并及时并及时堆叠服务。
(四)、docker架构
Docker 包括三个基本概念:
镜像(Image):Docker 镜像(Image),就相当于是一个 root 文件系统。比如官方镜像 ubuntu:16.04 就包含了完整的一套 Ubuntu16.04 最小系统的 root 文件系统。
容器(Container):镜像(Image)和容器(Container)的关系,就像是面向对象程序设计中的类和实例一样,镜像是静态的定义,容器是镜像运行时的实体。容器可以被创建、启动、停止、删除、暂停等。
仓库(Repository):仓库可看成一个代码控制中心,用来保存镜像。
二、Centos7在线安装docker
(一)、移除已安装的docker
yum remove docker docker-common docker-selinux
(二)、安装依赖包
yum install -y yum-utils device-mapper-persistent-data lvm2
(三)、添加docker-ce仓库配置
yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
(四)、查看docker-ce各版本
yum list docker-ce --showduplicates | sort -r
(五)、安装最新版版docker-ce
yum install docker-ce
(六)、启动docker
systemctl enable docker && systemctl start docker
三、docker常用命令
(一)、docker相关命令
docker info [OPTIONS]
显示 Docker 系统信息,包括镜像和容器数。
docker version [OPTIONS]
显示 Docker 版本信息
-f :指定返回值的模板文件
(二)、本地镜像相关命令
docker images [OPTIONS] [REPOSITORY:[TAG]]
列出本地镜像
OPTIONS说明:
-a :列出本地所有的镜像(含中间映像层,默认情况下,过滤掉中间映像层);
--digests :显示镜像的摘要信息;
-f :显示满足条件的镜像;
--format :指定返回值的模板文件;
--no-trunc :显示完整的镜像信息;
-q :只显示镜像ID
docker rmi [OPTIONS] IMAGE [IMAGE...]
删除本地一个或多少镜像
OPTIONS说明:
-f :强制删除;
--no-prune :不移除该镜像的过程镜像,默认移除;
docker tag [OPTIONS] IMAGE[:TAG] [REGISTRYHOST/][USERNAME/]NAME[:TAG]
标记本地镜像,将其归入某一仓库
docker build [OPTIONS] PATH | URL | -
使用 Dockerfile 创建镜像
OPTIONS说明:
--build-arg=[] :设置镜像创建时的变量;
--cpu-shares :设置 cpu 使用权重;
--cpu-period :限制 CPU CFS周期;
--cpu-quota :限制 CPU CFS配额;
--cpuset-cpus :指定使用的CPU id;
--cpuset-mems :指定使用的内存 id;
--disable-content-trust :忽略校验,默认开启;
-f :指定要使用的Dockerfile路径;
--force-rm :设置镜像过程中删除中间容器;
--isolation :使用容器隔离技术;
--label=[] :设置镜像使用的元数据;
-m :设置内存最大值;
--memory-swap :设置Swap的最大值为内存+swap,"-1"表示不限swap;
--no-cache :创建镜像的过程不使用缓存;
--pull :尝试去更新镜像的新版本;
--quiet, -q :安静模式,成功后只输出镜像 ID;
--rm :设置镜像成功后删除中间容器;
--shm-size :设置/dev/shm的大小,默认值是64M;
--ulimit :Ulimit配置。
--squash :将 Dockerfile 中所有的操作压缩为一层。
--tag, -t: 镜像的名字及标签,通常 name:tag 或者 name 格式;可以在一次构建中为一个镜像
设置多个标签。
--network: 默认 default。在构建期间设置RUN指令的网络模式
举例:
docker build -t <自定义tag名字> . 使用当前目录的 Dockerfile 创建镜像
docker history [OPTIONS] IMAGE
查看指定镜像的创建历史
OPTIONS说明:
-H :以可读的格式打印镜像大小和日期,默认为true;
--no-trunc :显示完整的提交记录;
-q :仅列出提交记录ID。
docker save [OPTIONS] IMAGE [IMAGE...]
将指定镜像保存成 tar 归档文件
OPTIONS 说明:
-o :输出到的文件。
举例:
docker save -o git-es.tar git-es:latest
docker load [OPTIONS]
导入使用 docker save 命令导出的镜像
OPTIONS 说明:
--input , -i : 指定导入的文件,代替 STDIN。
--quiet , -q : 精简输出信息。
举例:
docker load < git-es.tar
docker import [OPTIONS] file|URL|- [REPOSITORY[:TAG]]
从归档文件中创建镜像
OPTIONS说明:
-c :应用docker 指令创建镜像;
-m :提交时的说明文字;
(三)、镜像仓库相关命令
docker login [OPTIONS] [SERVER]
登陆到一个Docker镜像仓库,如果未指定镜像仓库地址,默认为官方仓库 Docker Hub
docker logout [OPTIONS] [SERVER]
登出一个Docker镜像仓库,如果未指定镜像仓库地址,默认为官方仓库 Docker Hub
OPTIONS说明:
-u :登陆的用户名
-p :登陆的密码
docker pull [OPTIONS] NAME[:TAG|@DIGEST]
从镜像仓库中拉取或者更新指定镜像
OPTIONS说明:
-a :拉取所有 tagged 镜像
--disable-content-trust :忽略镜像的校验,默认开启
docker push [OPTIONS] NAME[:TAG]
将本地的镜像上传到镜像仓库,要先登陆到镜像仓库
OPTIONS说明:
--disable-content-trust :忽略镜像的校验,默认开启
docker search [OPTIONS] TERM
从Docker Hub查找镜像
OPTIONS说明:
--automated :只列出 automated build类型的镜像;
--no-trunc :显示完整的镜像描述;
-f <过滤条件>:列出收藏数不小于指定值的镜像
(四)、容器rootfs命令
docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]
从容器创建一个新的镜像
OPTIONS说明:
-a :提交的镜像作者;
-c :使用Dockerfile指令来创建镜像;
-m :提交时的说明文字;
-p :在commit时,将容器暂停。
举例:
将容器a404c6c174a2 保存为新的镜像,并添加提交人信息和说明信息:
docker commit -a "xxx" -m "xxx" a404c6c174a2 mymysql:v1
docker cp [OPTIONS] CONTAINER:SRC_PATH DEST_PATH|-
docker cp [OPTIONS] SRC_PATH|- CONTAINER:DEST_PATH
用于容器与主机之间的数据拷贝
OPTIONS说明:
-L :保持源目标中的链接
举例:
将主机/www/runoob目录拷贝到容器96f7f14e99ab的/www目录下:
docker cp /www/runoob 96f7f14e99ab:/www/
docker diff [OPTIONS] CONTAINER
检查容器里文件结构的更改
(五)、容器操作命令
docker ps [OPTIONS]
列出容器
OPTIONS说明:
-a :显示所有的容器,包括未运行的。
-f :根据条件过滤显示的内容。
--format :指定返回值的模板文件。
-l :显示最近创建的容器。
-n :列出最近创建的n个容器。
--no-trunc :不截断输出。
-q :静默模式,只显示容器编号。
-s :显示总的文件大小。
docker inspect [OPTIONS] NAME|ID [NAME|ID...]
获取容器/镜像的元数据
OPTIONS说明:
-f :指定返回值的模板文件。
-s :显示总的文件大小。
--type :为指定类型返回JSON。
docker top [OPTIONS] CONTAINER [ps OPTIONS]
查看容器中运行的进程信息,支持 ps 命令参数
容器运行时不一定有/bin/bash终端来交互执行top命令,而且容器还不一定有top命令,可以使用docker top来实现查看container中正在运行的进程。
docker attach [OPTIONS] CONTAINER
连接到正在运行中的容器
docker events [OPTIONS]
OPTIONS说明:
-f :根据条件过滤事件;
--since :从指定的时间戳后显示所有事件;
--until :流水时间显示到指定的时间为止;
docker logs [OPTIONS] CONTAINER
OPTIONS说明:
-f : 跟踪日志输出
--since :显示某个开始时间的所有日志
-t : 显示时间戳
--tail :仅列出最新N条容器日志
docker wait [OPTIONS] CONTAINER [CONTAINER...]
阻塞运行直到容器停止,然后打印出它的退出代码。
docker export [OPTIONS] CONTAINER
将文件系统作为一个tar归档文件导出到STDOUT
OPTIONS说明:
- o :将输入内容写到文件。
docker port [OPTIONS] CONTAINER [PRIVATE_PORT[/PROTO]]
列出指定的容器的端口映射,或者查找将PRIVATE_PORT NAT到面向公众的端口
举例:
查看容器mynginx的端口映射情况: docker port mynginx
(六)、容器声明周期管理
docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
创建一个新的容器并运行一个命令
OPTIONS说明:
-a stdin: 指定标准输入输出内容类型,可选 STDIN/STDOUT/STDERR 三项;
-d: 后台运行容器,并返回容器ID;
-i: 以交互模式运行容器,通常与 -t 同时使用;
-P: 随机端口映射,容器内部端口随机映射到主机的端口
-p: 指定端口映射,格式为:主机(宿主)端口:容器端口
-t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;
--name="nginx-lb": 为容器指定一个名称;
--dns 8.8.8.8: 指定容器使用的DNS服务器,默认和宿主一致;
--dns-search example.com: 指定容器DNS搜索域名,默认和宿主一致;
-h "mars": 指定容器的hostname;
-e username="ritchie": 设置环境变量;
--env-file=[]: 从指定文件读入环境变量;
--cpuset="0-2" or --cpuset="0,1,2": 绑定容器到指定CPU运行;
-m :设置容器使用内存最大值;
--net="bridge": 指定容器的网络连接类型,支持 bridge/host/none/container: 四种类型;
--link=[]: 添加链接到另一个容器;
--expose=[]: 开放一个端口或一组端口;
--volume , -v: 绑定一个卷
举例:
运行git-es:latest的镜像,容器名为git-es,,绑定外部端口映射到容器内部端口,并且后台运行
docker run --name git-es -p 8106:8106 -d git-es:latest
docker start [OPTIONS] CONTAINER [CONTAINER...]
启动一个或多个已经被停止的容器
docker stop [OPTIONS] CONTAINER [CONTAINER...]
停止一个运行中的容器
docker restart [OPTIONS] CONTAINER [CONTAINER...]
重启容器
docker kill [OPTIONS] CONTAINER [CONTAINER...]
杀掉一个运行中的容器
OPTIONS说明:
-s :向容器发送一个信号
docker rm [OPTIONS] CONTAINER [CONTAINER...]
删除一个或多个容器。
OPTIONS说明:
-f :通过 SIGKILL 信号强制删除一个运行中的容器。
-l :移除容器间的网络连接,而非容器本身。
-v :删除与容器关联的卷。
docker pause CONTAINER [CONTAINER...]
暂停容器中所有的进程
docker unpause CONTAINER [CONTAINER...]
恢复容器中所有的进程
docker create [OPTIONS] IMAGE [COMMAND] [ARG...]
创建一个新的容器但不启动它
docker exec [OPTIONS] CONTAINER COMMAND [ARG...]
在运行的容器中执行命令
OPTIONS说明:
-d :分离模式: 在后台运行
-i :即使没有附加也保持STDIN 打开
-t :分配一个伪终端
举例:
在容器 mynginx 中开启一个交互模式的终端
docker exec -i -t mynginx /bin/bash
四、其他
(一) 、修改docker镜像仓库地址&添加信任仓库地址
①修改/etc/docker/daemon.json(如果没有新建)
{
"registry-mirrors": [
"https://bxsfpjcb.mirror.aliyuncs.com"
],
"max-concurrent-downloads": 10,
"log-driver": "json-file",
"log-level": "warn",
"log-opts": {
"max-size": "10m",
"max-file": "3"
},
"insecure-registries":
["127.0.0.1","192.168.1.119:5000","192.168.1.119:443"]
}
②重新加载配置并重启docker
systemctl daemon-reload && systemctl restart docker
(二)、离线安装方式
①下载离线包
链接: https://pan.baidu.com/s/1Sww5E-zN4fFPqGTYqamTGQ 提取码: wvx6
②上传离线包到服务器
将文件夹下载并上传centos7服务器,其中将docker-ce.repo文件拷贝到/etc/yum.repos.d/下
③安装
进入到上传的目录,按顺序依次安装containerd.io、docker-ce-cli、container-selinux和docker-cl包
rpm -ivh containerd.io-1.4.3-3.1.el7.x86_64.rpm --nodeps --force
rpm -ivh docker-ce-cli-20.10.2-3.el7.x86_64.rpm --nodeps --force
rpm -ivh container-selinux-2.107-1.el7_6.noarch.rpm --nodeps --force
rpm -ivh docker-ce-20.10.2-3.el7.x86_64.rpm --nodeps --force
④查看docker版本
docker version
⑤启动
systemctl enable docker && systemctl start docker