189 8069 5689

怎么将容器的状态保存为新的docker镜像

本篇内容主要讲解“怎么将容器的状态保存为新的docker镜像”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么将容器的状态保存为新的docker镜像”吧!

英山网站制作公司哪家好,找成都创新互联!从网页设计、网站建设、微信开发、APP开发、成都响应式网站建设公司等网站项目制作,到程序开发,运营维护。成都创新互联于2013年创立到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选成都创新互联

介绍

docker是一个应用程序,它使得在容器中运行应用程序进程变得简单和容易,这类应用程序就像虚拟机,只有更便携,更加资源友好,更依赖于主机操作系统。 有关详细介绍docker容器的不同组件,请docker生态系统:介绍公共组件 。

在ubuntu 16.04上安装docker有两种方法。 一种方法包括将其安装在操作系统的现有安装上。 其他涉及纺了一个名为工具的服务器docker机即自动安装docker就可以了。

先决条件

要遵循本教程,您需要以下内容:

64位ubuntu 16.04 droplet

使用sudo特权的非root用户初始设置指南的ubuntu 16.04将介绍如何设置起来。)

注意:docker需要的ubuntu 64位版本,以及一个内核版本等于或大于3.10以上。

默认的64位ubuntu 16.04 droplet满足这些要求。

本教程中的所有命令都应以非root用户身份运行。 如果需要该命令的root访问权限,它会在前面加sudo 。 初始设置指南的ubuntu 16.04解释了如何添加用户,并给他们sudo访问。

第1步 – 安装docker

官方ubuntu 16.04存储库中提供的docker安装包可能不是最新版本。 

但首先,让我们更新包数据库:

sudo apt-get update

现在让我们安装docker。 将官方docker资源库的gpg密钥添加到系统:

sudo apt-key adv --keyserver hkp://p80.pool.sks-keyservers.net:80 --recv-keys 58118e89f3a912897c070adbf76221572c52609d

将docker存储库添加到apt源:

echo "deb https://apt.dockerproject.org/repo ubuntu-xenial main" | sudo tee /etc/apt/sources.list.d/docker.list

使用新添加的软件包中的docker软件包更新软件包数据库:

sudo apt-get update

确保你将要从docker repo而不是默认的ubuntu 16.04 repo安装:

apt-cache policy docker-engine

您应该看到类似以下的输出:

apt-cache策略的输出docker-engine

docker-engine:
 installed: (none)
 candidate: 1.11.1-0~xenial
 version table:
  1.11.1-0~xenial 500
  500 https://apt.dockerproject.org/repo ubuntu-xenial/main amd64 packages
  1.11.0-0~xenial 500
  500 https://apt.dockerproject.org/repo ubuntu-xenial/main amd64 packages

请注意, docker-engine没有安装,但安装的候选人是从docker库中的ubuntu 16.04。 该docker-engine版本号可能会不同。

最后,安装docker:

sudo apt-get install -y docker-engine

现在应该安装docker,启动守护进程,启动进程启动。 检查它是否正在运行:

sudo systemctl status docker

输出应类似于以下内容,显示服务是活动的并正在运行:

output
● docker.service - docker application container engine
 loaded: loaded (/lib/systemd/system/docker.service; enabled; vendor preset: enabled)
 active: active (running) since sun 2016-05-01 06:53:52 cdt; 1 weeks 3 days ago
  docs: https://docs.docker.com
 main pid: 749 (docker)

安装docker现在给你不只是docker服务(守护进程),而且docker命令行实用程序或docker客户端。 我们将探讨如何使用docker在本教程后面的命令。

第2步 – 执行没有sudo的docker命令(可选)

默认情况下,在运行docker命令需要root权限-也就是说,你必须前缀命令sudo 。 它也可以由搬运工组,它是在安装docker期间自动创建中的用户运行。 如果你尝试运行docker没有用前缀它命令sudo或不docker组之中,你会得到这样的输出:

output
docker: cannot connect to the docker daemon. is the docker daemon running on this host?.
see 'docker run --help'.

如果你想避免打字sudo只要您运行的docker命令,您的用户名添加到docker组:

sudo usermod -ag docker $(whoami)

您将需要注销droplet并作为同一用户重新启用以启用此更改。

如果需要添加用户到docker ,你没有作为登录组,明确宣布用户名使用:

sudo usermod -ag docker username

本文的其余部分假定您运行的docker作为docker的用户组中的用户命令。 如果您选择不,请前面加上命令sudo 。

第3步 – 使用docker命令

随着docker的安装和工作,现在是时候熟悉命令行实用程序。 使用docker由它传递的选项和命令后跟参数的链条。 语法采用以下形式:

docker [option] [command] [arguments]

要查看所有可用的子命令,请键入:

docker

从docker 1.11.1开始,可用子命令的完整列表包括:

output

 attach attach to a running container
 build  build an image from a dockerfile
 commit create a new image from a container's changes
 cp  copy files/folders between a container and the local filesystem
 create create a new container
 diff  inspect changes on a container's filesystem
 events get real time events from the server
 exec  run a command in a running container
 export export a container's filesystem as a tar archive
 history show the history of an image
 images list images
 import import the contents from a tarball to create a filesystem image
 info  display system-wide information
 inspect return low-level information on a container or image
 kill  kill a running container
 load  load an image from a tar archive or stdin
 login  log in to a docker registry
 logout log out from a docker registry
 logs  fetch the logs of a container
 network manage docker networks
 pause  pause all processes within a container
 port  list port mappings or a specific mapping for the container
 ps  list containers
 pull  pull an image or a repository from a registry
 push  push an image or a repository to a registry
 rename rename a container
 restart restart a container
 rm  remove one or more containers
 rmi  remove one or more images
 run  run a command in a new container
 save  save one or more images to a tar archive
 search search the docker hub for images
 start  start one or more stopped containers
 stats  display a live stream of container(s) resource usage statistics
 stop  stop a running container
 tag  tag an image into a repository
 top  display the running processes of a container
 unpause unpause all processes within a container
 update update configuration of one or more containers
 version show the docker version information
 volume manage docker volumes
 wait  block until a container stops, then print its exit code

要查看特定命令可用的开关,请键入:

docker docker-subcommand --help

要查看有关docker的系统范围的信息,请使用:

docker info

第4步 – 使用docker镜像

docker容器是从docker镜像运行的。 默认情况下,它从docker hub(一个由docker项目管理的docker注册中心)提取这些镜像。 任何人都可以在docker hub上构建和托管docker镜像,所以大多数应用程序和linux发行版都需要运行docker容器,这些镜像托管在docker hub上。

要检查是否可以从docker hub访问和下载图像,请键入:

docker run hello-world

输出,应该包括以下内容,应该表明docker正常工作:

output
hello from docker.
this message shows that your installation appears to be working correctly.
...

您可以通过搜索有关docker hub可用图像docker用命令search子命令。 例如,要搜索ubuntu映像,请键入:

docker search ubuntu

该脚本将抓取docker hub并返回其名称与搜索字符串匹配的所有图像的列表。 在这种情况下,输出将类似于:

output
name        description          stars  official automated
ubuntu       ubuntu is a debian-based linux operating s... 3808  [ok]  
ubuntu-upstart     upstart is an event-based replacement for ... 61  [ok]  
torusware/speedus-ubuntu   always updated official ubuntu docker imag... 25     [ok]
rastasheep/ubuntu-sshd   dockerized ssh service, built on top of of... 24     [ok]
ubuntu-debootstrap    debootstrap --variant=minbase --components... 23  [ok]  
nickistre/ubuntu-lamp    lamp server on ubuntu       6     [ok]
nickistre/ubuntu-lamp-wordpress lamp on ubuntu with wp-cli installed   5     [ok]
nuagebec/ubuntu     simple always updated ubuntu docker images... 4     [ok]
nimmis/ubuntu      this is a docker images different lts vers... 4     [ok]
maxexcloo/ubuntu     docker base image built on ubuntu with sup... 2     [ok]
admiringworm/ubuntu    base ubuntu images based on the official u... 1     [ok]
...

在正式列,ok表示建造和项目背后的公司支持的图像。 一旦你确定你想使用的图像,你可以用它下载到你的电脑pull子,就像这样:

docker pull ubuntu

图像下载后,您可以使用下载的图像与当时运行的容器run命令。 如果图像尚未下载时, docker与执行run命令后,docker客户端将首先下载的图像,然后使用它运行一个容器:

docker run ubuntu

要查看已下载到您的计算机的图像,请键入:

docker images

输出应类似于以下内容:

output
repository   tag     image id   created    size
ubuntu    latest    c5f1cf30c96b  7 days ago   120.8 mb
hello-world   latest    94df4f0ce8a4  2 weeks ago   967 b

正如您将在本教程中,你用来运行容器的图像可以修改和用于产生新的图像,然后可以上传后面看到( 推是技术术语),以docker集线器或其他docker登记。

第5步 – 运行docker容器

该hello-world你在前面跑容器是运行和退出,散发出测试消息后的容器的一个例子。 然而,容器可以比这更有用,它们可以是交互式的。 毕竟,它们类似于虚拟机,只是更加资源友好。

例如,让我们使用ubuntu的最新镜像运行一个容器。 -i和-t参数的组合为您提供了交互shell访问到容器中:

docker run -it ubuntu

您的命令提示符应该更改以反映您现在在容器内工作的事实,并应采取以下形式:

output
root@d9b100f2f636:/#

重要提示:请注意,在命令提示符容器id。 在上面的例子中,它是d9b100f2f636 。

现在你可以在容器中运行任何命令。 例如,让我们更新容器中的包数据库。 无需前缀任何命令sudo ,因为你具有root权限的容器内工作:

apt-get update

然后在其中安装任何应用程序。 让我们安装nodejs,例如。

apt-get install -y nodejs

第6步 – 将容器中的更改提交到docker镜像

默认情况下docker文件系统是临时的。 如果启动docker镜像,您可以像虚拟机一样创建,修改和删除文件。 但是,如果您停止容器并重新启动,所有更改将会丢失:之前删除的所有文件现在都将恢复,并且您创建的所有新文件或修改都不会出现。 这是因为docker镜像比标准虚拟化世界中的图像更像模板。

要了解如何让他们持续通过容器的重启保留在容器内这些变化,你需要使用docker的数据量。

在ubuntu容器中安装nodejs之后,现在有一个容器运行一个映像,但容器不同于用来创建它的映像。

要将容器的状态保存为新图像,请先退出该容器:

exit

然后使用以下命令将更改提交到新的docker映像实例。 -m开关是提交信息,可以帮助您和其他人知道你做什么样的变化,而-a用于指定的作者。 容器id是您在启动交互式docker会话时在教程中前面提到的那个。 除非在docker hub上创建了其他存储库,否则该存储库通常是您的docker hub用户名:

docker commit -m "what did you do to the image" -a "author name" container-id repository/new_image_name

例如:

docker commit -m "added node.js" -a "sunday ogwu-chinuwa" d9b100f2f636 finid/ubuntu-nodejs

注意:当你提交图像时,新的图像保存在本地,也就是您的计算机上。

在本教程的后面,您将学习如何将图像推送到docker注册表(如docker hub),以便您和其他人评估和使用它。

在该操作完成后,列出docker图像现在在您的计算机上应该显示新的图像,以及它的旧图像,它派生自:

docker images

输出应类似于:

output
finid/ubuntu-nodejs  latest    62359544c9ba  50 seconds ago  206.6 mb
ubuntu    latest    c5f1cf30c96b  7 days ago   120.8 mb
hello-world   latest    94df4f0ce8a4  2 weeks ago   967 b

在上面的例子中,ubuntu的的nodejs是新的图像,将其从docker集线器现有的ubuntu图像而得。 大小差异反映了所做的更改。 在这个例子中,更改是nodejs已安装。 所以,下次你需要运行一个容器使用ubuntu的nodejs预安装,你可以只使用新的形象。 图像也可以从所谓的dockerfile构建。 但是这是一个非常复杂的过程,完全超出了本文的范围。

第7步 – 列出docker容器

使用docker一段时间后,您的计算机上将有许多活动(正在运行)和不活动的容器。 要查看活跃的 ,使用方法:

docker ps

您将看到类似于以下内容的输出:

output
container id  image    command    created    status    ports    names
f7c79cc556dd  ubuntu    "/bin/bash"   3 hours ago   up 3 hours        silly_spence

要查看所有的容器-活动和非活动,它传递-a开关:

docker ps -a

要查看您所创建的最新的容器,它传递-l开关:

docker ps -l

停止正在运行或活动的容器就像输入:

docker stop container-id

该container-id可以从输出中发现, docker ps命令。

第8步 – 将docker映像推送到docker存储库

从现有映像创建新映像后的下一个逻辑步骤是与您选择的几个朋友,docker hub的整个世界或您可以访问的其他docker注册表共享它。 要将映像推送到docker hub或任何其他docker注册表,您必须有一个帐户。

本节介绍如何将docker镜像推送到docker hub。 要了解如何创建自己的私人docker注册表,看看如何建立一个私人docker登记在ubuntu 14.04 。

要创建docker hub帐户,注册在docker hub 。 之后,要推送您的映像,首先登录到docker hub。 系统会提示您验证:

docker login -u docker-registry-username

如果指定了正确的密码,身份验证应该会成功。 然后您可以使用以下方式推送您自己的图片:

docker push docker-registry-username/docker-image-name

它需要一段时间来完成,当完成后,输出将类似于以下内容:

output
the push refers to a repository [docker.io/finid/ubuntu-nodejs]
e3fbbfb44187: pushed
5f70bf18a086: pushed
a3b5c80a4eba: pushed
7f18b442972b: pushed
3ce512daaf78: pushed
7aae4540b42d: pushed
..

将图片推送到注册表后,应将其列在您帐户的信息中心上,如下图所示。

怎么将容器的状态保存为新的docker镜像

如果推送尝试导致此类错误,则可能未登录:

output
the push refers to a repository [docker.io/finid/ubuntu-nodejs]
e3fbbfb44187: preparing
5f70bf18a086: preparing
a3b5c80a4eba: preparing
7f18b442972b: preparing
3ce512daaf78: preparing
7aae4540b42d: waiting
unauthorized: authentication required

登录,然后重复推送尝试。

到此,相信大家对“怎么将容器的状态保存为新的docker镜像”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


文章题目:怎么将容器的状态保存为新的docker镜像
分享地址:http://cdxtjz.cn/article/ijhpdj.html

其他资讯