Docker
docker三要素
1.镜像
docker镜像(Image)就是一个只读的模板。镜像可以用来创建docker容器,一个镜像可以创建很多容器。
DOCKER | 面向对象 |
---|---|
镜像 | 类 |
容器 | 对象 |
2.容器
docker利用容器(container)独立运行的一个或一组应用。容器使用镜像创建的运行实例。
它可以被启动、开始、停止、删除。每个容器都是相互隔离的,保证安全的平台。
可以吧容器看做是一个简易版的linux环境(包括root用户权限、进程空间、用户空间和网络空间等)和运行在其中的应用程序。
容器的定义和镜像几乎一模一样,也是一堆层的统一视角,位移区别在于容器的最上面那一层是可读可写的。
3.仓库
仓库(Repository)是集中存放镜像文件的场所。
仓库(Repository)和仓库注册服务器(Registry)是有区别的。仓库注册服务器上往往存放着多个仓库,每个仓库又包含了多个镜像,每个镜像有不同的标签。
仓库分为公开仓库和私有仓库两种形式。
最大的公开仓库是Docker Hub
安装
原理
docker是一个Client-Server结构的系统,Docker守护进程运行在主机上,然后通过Socket连接从客户端访问,守护进程从客户端接受命令并管理运行在主机上的容器。容器,是一个运行时的环境,就是我们前面说到的集装箱。
常用命令
1.帮助命令
查看版本:
docker version 或者
docker --version
查看信息
docker info
查看帮助:
docker --help
2.镜像命令
docker images
:列出本地主机的镜像
REPOSITORY:表示镜像的仓库源
TAG:镜像的标签
IMAGE ID:镜像ID
CREATEED:镜像创建时间
SIZE:镜像大小
docker images -a
:列出本地所有镜像
docker images -q
:只显示镜像ID
docker search tomcat
:搜索某个镜像
docker search -s 30 tomcat
:搜索某个点赞量大于30镜像
docker pull
:下载镜像
docker rmi imagesID
:删除镜像
docker rmi -f imagesID
:强制删除镜像
docker rmi -f 镜像名1:TAG 镜像名2:TAG
:删除多个镜像
docker rmi -f $(docker images -q)
:删除全部镜像
docker run -it 0f3e07c0138f
:新建并运行镜像ID为0f3e07c0138f的容器
--name=容器新名字
:为容器指定一个名称
-i`:已交互模式运行容器,通常与-t同时使用
-t
:为容器重新分配一个伪输入终端,通常与-i同时使用
`-P:随机端口映射
`-p:指定端口映射
docker ps
:列出所有正在运行容器
docker ps -a
:列出当前所有正在运行的容器和历史运行过的
docker ps -l`:上次运行的容器
docker ps -n`:显示最近n个创建的容器
docker ps -q
:只显示容器编号
exit
容器停止退出
ctrl+P+Q
:容器不停止退出
docker start 容器ID
:启动容器
docker rm
:删除容器
docker rm -f $(docker ps -a -q)
:一次删除所有容器
docker ps -a -q | xargs docker rm`:一次删除多个容器
docker run -d centos
:以后台模式启动一个容器
docker logs -f -t --tail 容器ID
:查看容器日志
-t
:是加入时间戳
-f
:跟随最新的日志打印
-tail 数字
:显示最后多少条
docker top 容器ID
:查看容器内运行的进程
docker inspect 容器ID
:查看容器内细节
docker attach 容器ID
:直接进入容器启动命令的终端,不会启动新的进程
docker exec 容器ID
:是在容器中打开新的终端,并且可以启动新的进程
docker cp 容器ID : 容器内路径 目的主机路径
:从容器内拷贝文件到主机上
docker镜像
是什么
Union(联合文件系统),联合文件系统是一种分层、轻量级并且高性能的文件系统,他支持对文件系统的修改作为一次提交来一层层的叠加。
加载原理
docker的镜像实际上由一层层的文件系统组成
特点
docker镜像都是只读的,当容器启动时,一个新的可写层被加载到镜像的顶部。这一层被称为容器层,容器层之下的都叫镜像层。