zoukankan      html  css  js  c++  java
  • docker学习(三)

    一、容器

    1.启动容器

    启动容器有两种方式一种是基于镜像新建一个容器并启动,另外一个是将在终止状态(stopped)的容器重新启动
    因为 Docker 的容器实在太轻量级了,很多时候用户都是随时删除和新创建容器。所需要的命令主要为 docker run
    例如,下面的命令输出一个 “Hello World”,之后终止容器。
    $ sudo docker run ubuntu:14.04 /bin/echo 'Hello world'
    Hello world
    这跟在本地直接执行 /bin/echo 'hello world' 几乎感觉不出任何区别。
    下面的命令则启动一个 bash 终端,允许用户进行交互。
    $ sudo docker run -t -i ubuntu:14.04 /bin/bash
    root@af8bae53bdd3:/#
    其中, -t 选项让Docker分配一个伪终端(pseudo-tty)并绑定到容器的标准输入上, -i 则让容器的标准输入保持打开。
    在交互模式下,用户可以通过所创建的终端来输入命令,例如
    root@af8bae53bdd3:/# pwd
    /
    root@af8bae53bdd3:/# ls
    bin boot dev etc home lib lib64 media mnt opt proc root run sbin srv sys tmp usr var
    当利用 docker run 来创建容器时,Docker 在后台运行的标准操作包括:
    a.检查本地是否存在指定的镜像,不存在就从公有仓库下载
    b.利用镜像创建并启动一个容器
    c.分配一个文件系统,并在只读的镜像层外面挂载一层可读写层
    d.从宿主主机配置的网桥接口中桥接一个虚拟接口到容器中去
    e.从地址池配置一个 ip 地址给容器
    f.执行用户指定的应用程序
    g.执行完毕后容器被终止
    可以利用 docker start 命令,直接将一个已经终止的容器启动运行
    容器的核心为所执行的应用程序,所需要的资源都是应用程序运行所必需的。除此之外,并没有其它的资源。可以在伪终端中利用 ps 或 top 来查看进程信息。
    root@ba267838cc1b:/# ps
    PID TTY TIME CMD
    1 ? 00:00:00 bash
    11 ? 00:00:00 ps
    可见,容器中仅运行了指定的 bash 应用。这种特点使得 Docker 对资源的利用率极高,是货真价实的轻量级虚拟化。

    2.守护态运行

    更多的时候,需要让 Docker 容器在后台以守护态(Daemonized)形式运行。此时,可以通过添加 -d 参数来实现。
    例如下面的命令会在后台运行容器。
    $ sudo docker run -d ubuntu:14.04 /bin/sh -c "while true; do echo hello world; sleep 1; done"
    1e5535038e285177d5214659a068137486f96ee5c2e85a4ac52dc83f2ebe4147
    容器启动后会返回一个唯一的 id,也可以通过 docker ps 命令来查看容器信息。
    $ sudo docker ps
    CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
    1e5535038e28 ubuntu:14.04 /bin/sh -c 'while tr 2 minutes ago Up 1 minute insane_babbage
    要获取容器的输出信息,可以通过 docker logs 命令。
    $ sudo docker logs insane_babbage
    hello world
    hello world
    hello world
    . . .

    3.终止容器

    可以使用 docker stop 来终止一个运行中的容器。
    此外,当Docker容器中指定的应用终结时,容器也自动终止。 例如对于上一章节中只启动了一个终端的容器,用户通过 exit 命令或 Ctrl+d 来退出终端时,所创建的容器立刻终止。
    终止状态的容器可以用 docker ps -a 命令看到。例如
    sudo docker ps -a
    CONTAINER ID IMAGE COMMAND CREATED STATUS ba267838cc1b ubuntu:14.04 "/bin/bash" 30 minutes ago Exited (0) About 98e5efa7d997 training/webapp:latest "python app.py" About an hour ago Exited (0) 34 处于终止状态的容器,可以通过 docker start 命令来重新启动。
    此外, docker restart 命令会将一个运行态的容器终止,然后再重新启动它

    4.进入容器

    在使用 -d 参数时,容器启动后会进入后台。 某些时候需要进入容器进行操作,有很多种方法,包括使用docker attach 命令或 nsenter 工具等。
    attach命令
    docker attach 是Docker自带的命令。下面示例如何使用该命令。
    $ sudo docker run -idt ubuntu
    243c32535da7d142fb0e6df616a3c3ada0b8ab417937c853a9e1c251f499f550
    $ sudo docker ps
    CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS 243c32535da7 ubuntu:latest "/bin/bash" 18 seconds ago Up 17 seconds $sudo docker attach nostalgic_hypatia
    root@243c32535da7:/#
    但是使用 attach 命令有时候并不方便。当多个窗口同时 attach 到同一个容器的时候,所有窗口都会同步显示。当某个窗口因命令阻塞时,其他窗口也无法执行操作了。
    nsenter命令
    安装
    nsenter 工具在 util-linux 包2.23版本后包含。 如果系统中 util-linux 包没有该命令,可以按照下面的方法从源码安装。
    $ cd /tmp; curl https://www.kernel.org/pub/linux/utils/util-linux/v2.24/util-linux-2.24.tar.gz | tar $ ./configure --without-ncurses
    $ make nsenter && sudo cp nsenter /usr/local/bin
    使用
    nsenter 可以访问另一个进程的名字空间。nsenter 要正常工作需要有 root 权限。 很不幸,Ubuntu 14.4仍然使用的是 util-linux 2.20。安装最新版本的 util-linux(2.24)版,请按照以下步骤:
    $ wget https://www.kernel.org/pub/linux/utils/util-linux/v2.24/util-linux-2.24.tar.gz; tar xzvf util-$ cd util-linux-2.24
    $ ./configure --without-ncurses && make nsenter
    $ sudo cp nsenter /usr/local/bin
    为了连接到容器,你还需要找到容器的第一个进程的 PID,可以通过下面的命令获取。
    PID=$(docker inspect --format "{{ .State.Pid }}" <container>)
    通过这个 PID,就可以连接到这个容器:
    $ nsenter --target $PID --mount --uts --ipc --net --pid
    下面给出一个完整的例子。
    $ sudo docker run -idt ubuntu
    243c32535da7d142fb0e6df616a3c3ada0b8ab417937c853a9e1c251f499f550
    $ sudo docker ps
    CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS 243c32535da7 ubuntu:latest "/bin/bash" 18 seconds ago Up 17 seconds $ PID=$(docker-pid 243c32535da7)
    10981
    $ sudo nsenter --target 10981 --mount --uts --ipc --net --pid
    root@243c32535da7:/#
    更简单的,建议大家下载 .bashrc_docker,并将内容放到 .bashrc 中。
    $ wget -P ~ https://github.com/yeasy/docker_practice/raw/master/_local/.bashrc_docker;
    $ echo "[ -f ~/.bashrc_docker ] && . ~/.bashrc_docker" >> ~/.bashrc; source ~/.bashrc
    这个文件中定义了很多方便使用 Docker 的命令,例如 docker-pid 可以获取某个容器的 PID;而docker-enter 可以进入容器或直接在容器内执行命令。
    $ echo $(docker-pid <container>)
    $ docker-enter <container> ls

    5.导出和导入容器

    导出容器
    如果要导出本地某个容器,可以使用 docker export 命令。
    $ sudo docker ps -a
    CONTAINER ID IMAGE COMMAND CREATED STATUS 7691a814370e ubuntu:14.04 "/bin/bash" 36 hours ago Exited (0) 21 hours ago $ sudo docker export 7691a814370e > ubuntu.tar
    这样将导出容器快照到本地文件。
    导入容器快照
    可以使用 docker import 从容器快照文件中再导入为镜像,例如
    $ cat ubuntu.tar | sudo docker import - test/buntu:v1.0
    $ sudo docker images
    REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
    test/ubuntu v1.0 9d37a6082e97 About a minute ago 171.3 MB
    此外,也可以通过指定 URL 或者某个目录来导入,例如
    $sudo docker import http://example.com/exampleimage.tgz example/imagerepo
    *注:用户既可以使用 docker load 来导入镜像存储文件到本地镜像库,也可以使用 docker import 来导入一个容器快照到本地镜像库。这两者的区别在于容器快照文件将丢弃所有的历史记录和元数据信息(即仅保存容器当时的快照状态),而镜像存储文件将保存完整记录,体积也要大。此外,从容器快照文件导入时可以重新指定标签等元数据信息。

    6.删除容器

    可以使用 docker rm 来删除一个处于终止状态的容器。 例如
    $sudo docker rm trusting_newton
    trusting_newton
    如果要删除一个运行中的容器,可以添加 -f 参数。Docker 会发送 SIGKILL 信号给容器。

    二、仓库

    仓库(Repository)是集中存放镜像的地方。
    一个容易混淆的概念是注册服务器(Registry)。实际上注册服务器是管理仓库的具体服务器,每个服务器上可以有多个仓库,而每个仓库下面有多个镜像。从这方面来说,仓库可以被认为是一个具体的项目或目录。例如对于仓库地址 dl.dockerpool.com/ubuntu 来说, dl.dockerpool.com 是注册服务器地址, ubuntu 是仓库名。大部分时候,并不需要严格区分这两者的概念。

    1.Docker Hub

    目前 Docker 官方维护了一个公共仓库 Docker Hub,其中已经包括了超过 15,000 的镜像。大部分需求,都可以通过在 Docker Hub 中直接下载镜像来实现。
    登录
    可以通过执行 docker login 命令来输入用户名、密码和邮箱来完成注册和登录。 注册成功后,本地用户目录的 .dockercfg 中将保存用户的认证信息。
    用户无需登录即可通过 docker search 命令来查找官方仓库中的镜像,并利用 docker pull 命令来将它下载到本地
    例如以 centos 为关键词进行搜索:
    $ sudo docker search centos
    NAME DESCRIPTION STARS centos The official build of CentOS. 465 tianon/centos CentOS 5 and 6, created using rinse instea... 28
    blalor/centos Bare-bones base CentOS 6.5 image 6 saltstack/centos-6-minimal 6 tutum/centos-6.4 DEPRECATED. Use tutum/centos:6.4 instead. ... 5 ...
    可以看到返回了很多包含关键字的镜像,其中包括镜像名字、描述、星级(表示该镜像的受欢迎程度)、是否官方创建、是否自动创建。 官方的镜像说明是官方项目组创建和维护的,automated 资源允许用户验证镜像的来源和内容。
    根据是否是官方提供,可将镜像资源分为两类。 一种是类似 centos 这样的基础镜像,被称为基础或根镜像。这些基础镜像是由 Docker 公司创建、验证、支持、提供。这样的镜像往往使用单个单词作为名字。还有一种类型,比如 tianon/centos 镜像,它是由 Docker 的用户创建并维护的,往往带有用户名称前缀。可以通过前缀 user_name/ 来指定使用某个用户提供的镜像,比如 tianon 用户。另外,在查找的时候通过 -s N 参数可以指定仅显示评价为 N 星以上的镜像
    下载官方 centos 镜像到本地。
    $ sudo docker pull centos
    Pulling repository centos
    0b443ba03958: Download complete
    539c0211cd76: Download complete
    511136ea3c5a: Download complete
    7064731afe90: Download complete
    用户也可以在登录后通过 docker push 命令来将镜像推送到 Docker Hub。


    2.自动创建
    自动创建(Automated Builds)功能对于需要经常升级镜像内程序来说,十分方便。 有时候,用户创建了镜像,安装了某个软件,如果软件发布新版本则需要手动更新镜像。。而自动创建允许用户通过 Docker Hub 指定跟踪一个目标网站(目前支持 GitHub 或 BitBucket)上的项目,一旦项目发生新的提交,则自动执行创建。
    要配置自动创建,包括如下的步骤:
    a.创建并登陆 Docker Hub,以及目标网站;
    b.在目标网站中连接帐户到 Docker Hub;
    c.在 Docker Hub 中 配置一个自动创建;
    d.选取一个目标网站中的项目(需要含 Dockerfile)和分支;
    e.指定 Dockerfile 的位置,并提交创建。
    之后,可以 在Docker Hub 的 自动创建页面 中跟踪每次创建的状态。

    3.私有仓库

    3.1私有仓库
    有时候使用 Docker Hub 这样的公共仓库可能不方便,用户可以创建一个本地仓库供私人使用。本节介绍如何使用本地仓库。
    docker-registry 是官方提供的工具,可以用于构建私有的镜像仓库

    3.2安装运行 docker-registry
    容器运行
    在安装了 Docker 后,可以通过获取官方 registry 镜像来运行。
    $ sudo docker run -d -p 5000:5000 registry
    这将使用官方的 registry 镜像来启动本地的私有仓库。 用户可以通过指定参数来配置私有仓库位置,例如配置镜像存储到 Amazon S3 服务。
    $ sudo docker run
    -e SETTINGS_FLAVOR=s3
    -e AWS_BUCKET=acme-docker
    -e STORAGE_PATH=/registry
    -e AWS_KEY=AKIAHSHB43HS3J92MXZ
    -e AWS_SECRET=xdDowwlK7TJajV1Y7EoOZrmuPEJlHYcNP2k4j49T
    -e SEARCH_BACKEND=sqlalchemy
    -p 5000:5000
    registry
    `
    此外,还可以指定本地路径(如 /home/user/registry-conf )下的配置文件。
    $ sudo docker run -d -p 5000:5000 -v /home/user/registry-conf:/registry-conf -e DOCKER_REGISTRY_CONFIG=/默认情况下,仓库会被创建在容器的 /tmp/registry 下。可以通过 -v 参数来将镜像文件存放在本地的
    指定路径。 例如下面的例子将上传的镜像放到 /opt/data/registry 目录。
    $ sudo docker run -d -p 5000:5000 -v /opt/data/registry:/tmp/registry registry

    3.3本地安装
    对于 Ubuntu 或 CentOS 等发行版,可以直接通过源安装。
    Ubuntu
    $ sudo apt-get install -y build-essential python-dev libevent-dev python-pip liblzma-dev
    $ sudo pip install docker-registry

    CentOS
    $ sudo yum install -y python-devel libevent-devel python-pip gcc xz-devel
    $ sudo python-pip install docker-registry
    也可以从 docker-registry 项目下载源码进行安装。
    $ sudo apt-get install build-essential python-dev libevent-dev python-pip libssl-dev liblzma-dev libffi-$ git clone https://github.com/docker/docker-registry.git
    $ cd docker-registry
    $ sudo python setup.py install
    然后修改配置文件,主要修改 dev 模板段的 storage_path 到本地的存储仓库的路径。
    $ cp config/config_sample.yml config/config.yml
    之后启动 Web 服务。
    $ sudo gunicorn -c contrib/gunicorn.py docker_registry.wsgi:application
    或者
    $ sudo gunicorn --access-logfile - --error-logfile - -k gevent -b 0.0.0.0:5000 -w 4 --max-requests 100 此时使用访问本地的 5000 端口,看到输出 docker-registry 的版本信息说明运行成功。
    *注: config/config_sample.yml 文件是示例配置文件。

    3.4在私有仓库上传、下载、搜索镜像
    创建好私有仓库之后,就可以使用 docker tag 来标记一个镜像,然后推送它到仓库,别的机器上就可以
    下载下来了。例如私有仓库地址为 192.168.7.26:5000 。
    先在本机查看已有的镜像。
    $ sudo docker images
    REPOSITORY TAG IMAGE ID CREATED VIRTUAL ubuntu latest ba5877dc9bec 6 weeks ago 192.7 MB
    ubuntu 14.04 ba5877dc9bec 6 weeks ago 192.7 MB
    使用 docker tag 将 ba58 这个镜像标记为 192.168.7.26:5000/test (格式为 docker tag
    IMAGE[:TAG] [REGISTRYHOST/][USERNAME/]NAME[:TAG] )。

    $ sudo docker tag ba58 192.168.7.26:5000/test
    root ~ # docker images
    REPOSITORY TAG IMAGE ID CREATED VIRTUAL ubuntu 14.04 ba5877dc9bec 6 weeks ago 192.7 MB
    ubuntu latest ba5877dc9bec 6 weeks ago 192.7 MB
    192.168.7.26:5000/test latest ba5877dc9bec 6 weeks ago 192.7 MB
    使用 docker push 上传标记的镜像。
    $ sudo docker push 192.168.7.26:5000/test
    The push refers to a repository [192.168.7.26:5000/test] (len: 1)
    Sending image list
    Pushing repository 192.168.7.26:5000/test (1 tags)
    Image 511136ea3c5a already pushed, skipping
    Image 9bad880da3d2 already pushed, skipping
    Image 25f11f5fb0cb already pushed, skipping
    Image ebc34468f71d already pushed, skipping
    Image 2318d26665ef already pushed, skipping
    Image ba5877dc9bec already pushed, skipping
    Pushing tag for rev [ba5877dc9bec] on {http://192.168.7.26:5000/v1/repositories/test/tags/latest}
    用 curl 查看仓库中的镜像。
    $ curl http://192.168.7.26:5000/v1/search
    {"num_results": 7, "query": "", "results": [{"description": "", "name": "library/miaxis_j2ee"}, {"description": 这里可以看到 {"description": "", "name": "library/test"} ,表明镜像已经被成功上传了。
    现在可以到另外一台机器去下载这个镜像。
    $ sudo docker pull 192.168.7.26:5000/test
    Pulling repository 192.168.7.26:5000/test
    ba5877dc9bec: Download complete
    511136ea3c5a: Download complete
    9bad880da3d2: Download complete
    25f11f5fb0cb: Download complete
    ebc34468f71d: Download complete
    2318d26665ef: Download complete
    $ sudo docker images
    REPOSITORY TAG IMAGE ID CREATED VIRTUAL 192.168.7.26:5000/test latest ba5877dc9bec 6 weeks ago 192.7
    可以使用 这个脚本 批量上传本地的镜像到注册服务器中,默认是本地注册服务器 127.0.0.1:5000 。例如:
    $ wget https://github.com/yeasy/docker_practice/raw/master/_local/push_images.sh; sudo chmod a+x push_$ ./push_images.sh ubuntu:latest centos:centos7
    The registry server is 127.0.0.1
    Uploading ubuntu:latest...
    The push refers to a repository [127.0.0.1:5000/ubuntu] (len: 1)
    Sending image list
    Pushing repository 127.0.0.1:5000/ubuntu (1 tags)
    Image 511136ea3c5a already pushed, skipping
    Image bfb8b5a2ad34 already pushed, skipping
    Image c1f3bdbd8355 already pushed, skipping
    Image 897578f527ae already pushed, skipping
    Image 9387bcc9826e already pushed, skipping
    Image 809ed259f845 already pushed, skipping
    Image 96864a7d2df3 already pushed, skipping
    Pushing tag for rev [96864a7d2df3] on {http://127.0.0.1:5000/v1/repositories/ubuntu/tags/latest}
    Untagged: 127.0.0.1:5000/ubuntu:latest
    Done
    Uploading centos:centos7...
    The push refers to a repository [127.0.0.1:5000/centos] (len: 1)
    Sending image list
    Pushing repository 127.0.0.1:5000/centos (1 tags)
    Image 511136ea3c5a already pushed, skipping
    34e94e67e63a: Image successfully pushed
    70214e5d0a90: Image successfully pushed
    Pushing tag for rev [70214e5d0a90] on {http://127.0.0.1:5000/v1/repositories/centos/tags/centos7}
    Untagged: 127.0.0.1:5000/centos:centos7
    Done

    4.仓库配置文件

    Docker 的 Registry 利用配置文件提供了一些仓库的模板(flavor),用户可以直接使用它们来进行开发或生产部署。
    模板
    在 config_sample.yml 文件中,可以看到一些现成的模板段
    common :基础配置
    local :存储数据到本地文件系统
    s3 :存储数据到 AWS S3 中
    dev :使用 local 模板的基本配置
    test :单元测试使用
    prod :生产环境配置(基本上跟s3配置类似)
    gcs :存储数据到 Google 的云存储
    swift :存储数据到 OpenStack Swift 服务
    glance :存储数据到 OpenStack Glance 服务,本地文件系统为后备
    glance-swift :存储数据到 OpenStack Glance 服务,Swift 为后备
    elliptics :存储数据到 Elliptics key/value 存储
    用户也可以添加自定义的模版段。
    默认情况下使用的模板是 dev ,要使用某个模板作为默认值,可以添加 SETTINGS_FLAVOR 到环境变量中,例如
    export SETTINGS_FLAVOR=dev
    另外,配置文件中支持从环境变量中加载值,语法格式为 _env:VARIABLENAME[:DEFAULT] 。
    实例配置
    common:
      loglevel: info
      search_backend: "_env:SEARCH_BACKEND:"
      sqlalchemy_index_database:
        "_env:SQLALCHEMY_INDEX_DATABASE:sqlite:////tmp/docker-registry.db"
    prod:
      loglevel: warn
      storage: s3
      s3_access_key: _env:AWS_S3_ACCESS_KEY
      s3_secret_key: _env:AWS_S3_SECRET_KEY
      s3_bucket: _env:AWS_S3_BUCKET
      boto_bucket: _env:AWS_S3_BUCKET
      storage_path: /srv/docker
      smtp_host: localhost
      from_addr: docker@myself.com
      to_addr: my@myself.com
    dev:
      loglevel: debug
      storage: local
      storage_path: /home/myself/docker
    test:
      storage: local
      storage_path: /tmp/tmpdockertmp

  • 相关阅读:
    方法是Objective-C独有的一种结构,只能在Objective-C中声明、定义和使用,C语言不能声明、定义和使用
    NSDate
    runtime
    iOS开发常用的工具
    程序的国际化
    经常使用的iOS SDK库和第三方库
    RunLoop是什么?
    狼若回头,必有理由
    第1年1月21日 Guard Malloc
    第1年1月10日 flv格式
  • 原文地址:https://www.cnblogs.com/muxi0407/p/12011206.html
Copyright © 2011-2022 走看看