您的位置:首页 > 运维架构 > Docker

docker 容器

2015-09-07 10:12 746 查看
docker 容器(container)类似于一个轻量级的沙箱,docker 利用容器来运行和隔离应用。

容器是从镜像创建的应用运行实例,可以将其启动、开始、停止、删除,而这些容器都是互相隔离,互不可见的。

可以把容器看做一个简易版的 linux 系统环境(包括 root 用户权限、进程空间、用户空间和网络空间等),以及运行在其中的应用程序打包而成的应用盒子。

镜像自身是只读的。容器从镜像启动的时候,docker会在镜像的最上层创建一个可写成,镜像本身保持不变。

创建容器

>> docker create centos:latest      #创建centos容器
>> docker start  centos_ID          #启动centos容器
>> docker stop   centos_ID          #停止centos容器


新建并启动容器(启动容器有两种方式)

(1)、基于镜像新建一个容器并启动;docker create;docker start。前面两条命令等价于docker run
(2)、将在终止状态的容器重新启动;docker start
例如,下面的命令输出一个'Hello World',之后容器自动终止:
>> docker run centos /bin/echo 'Hello World !!!'


当利用docker run来创建并启动容器时,Docker在后台运行的标准操作包括:

检查本地是否存在指定的镜像,不存在就从公有仓库下载

利用镜像创建并启动一个容器

分配一个文件系统,并在只读的镜像层外面挂载一层可读写层

从宿主主机配置的网桥接口中桥接一个虚拟接口到容器中去

从地址池配置一个IP地址给容器

执行用户指定的应用程序

执行完毕后容器被终止

守护态运行 -d

>> docker run -d centos:latest /bin/bash -c "while true;do echo hello world;sleep 1;done"
>> docker logs container_id    #查看docker输出的信息


终止容器

>> docker stop container_ID         #停止容器
>> docker restart container_ID      #重启容器
>> docker start container_ID        #启动容器
>> docker kill container_ID         #强制杀死容器
>> docker ps -a -q                  #只显示出所有容器的ID


进入容器(attach,exec,nsenter)

在使用-d参数时,容器启动后会进入后台,用户无法看到容器中的信息。某些时候如果需要进入容器进行操作,有多种方法

>> docker attach
>> docker exec
>> nsenter


attach 命令

>> docker run -itd centos
>> docker ps -a
>> docker attach container_ID


exec 命令

可以直接在容器内运行命令。例如进入到刚创建的容器,并启动一个bash
>> docker exec -ti 36ba269d463d /bin/bash
>> ps -ef  | grep bash          #如果多增加一个终端,就可以看到多出一个bash


nsenter 工具

nsenter工具在util-linux包中,下面为源码安装
>> cd /tmp ;
>> wget https://www.kernel.org/pub/linux/utils/util-linux/v2.24/util-linux-2.24.tar.gz >> tar zxf util-linux-2.24.tar.gz
>> ./configure --without-ncurses
>> make nsenter && cp nsenter /usr/local/bin


获取进行PID,并且通过这个PID,连接容器

>> PID=$(docker inspect --format "{{ .State.Pid }}" container_ID)
>> nsenter --target $PID --mount --uts --ipc --net --pid


删除容器

>> docker rm container_ID      #删除容器
>> docker rm -f container_ID   #强制删除正在运行中的容器


导入和导出容器

导出容器

-只导出一个已经创建的容器到一个文件,不管此时这个容器是否处于运行状态,可以使用docker export命令

格式为 docker export CONTAINER
>> docker export container_ID > /tmp/centos.tar
可将这个文件传输到其他机器上,在其他机器上通过导入命令实现容器的迁移


导入容器

导出的文件又可以使用docker images命令导入,成为镜像
>> cat centos.tar | docker import - centps:1
>> docker load    命令来导入镜像存储文件到本地的镜像库
>> docker import  命令来导入一个容器快照到本地镜像库


区别:

容器快照文件将丢弃所有的历史记录和元数据信息(即仅保存容器当时的快照状态)

镜像存储文件将保存完整记录,体积也要大。此外,从容器快照文件导入时可以重新指定标签等元数据信息
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: