Docker实战(一)之使用Docker镜像
镜像是Docker三大核心概念中最为重要的,自Docker诞生之日起“镜像”就是相关社区最为热门的关键字。
Docker运行容器前需要本地存在对应的镜像,如果镜像没有保存至本地,Docker会尝试先从默认镜像仓库中下载,用户也可以通过配置,使用自定义的镜像仓库。
1.获取镜像
docker pull ubuntu 获取ubuntu最新镜像
如果要获得指定的ubuntu镜像可以写成这样 docker pull ubuntu:14.04
注意:
一般来说,镜像的latest标签意味着该镜像的内容会跟踪最新的非稳定版本而发布,内容是不稳定的。当前Ubuntu最新的发行版本为16.04,latest镜像实际上就是16.04镜像,用户可以下载ubuntu:16.04镜像并查看,两者的数字摘要值是否一致的。从稳定性上考虑,不要在生产环境中忽略镜像标签信息或使用默认的latest标记的镜像。
2.查看镜像信息
(1)使用image命令查看镜像信息
docker images 该命令可以查看docker容器所有的镜像
在列出的信息中,可以看到以下几个字段的信息:
来自哪个仓库,比如ubuntu仓库用来保存ubuntu的镜像;
镜像的标签信息,比如latest标注不同的版本信息.标签只是标记,并不能标识镜像内容;
镜像的ID,如nginx的ID为cd5239a0906a,当两个镜像的ID相同时,说明它们目前实际上指向同一个镜像;
创建时间,说明镜像最后的更新时间;
镜像大小,优秀的镜像往往体积都比较小;
其中镜像ID非常重要,它唯一标识镜像,在使用镜像ID的时候,一般可以使用该ID的前很多个字符组成的可区分串来代替完整的ID。'
(2)使用tag命令添加镜像标签
为了方便在后续工作中使用特定的镜像,还可以使用docker tag命令来为本地镜像任意添加新的标签。例如添加一个新的myubuntu:latest镜像标签:
docker tag ubuntu:latest myubuntu:latest
docker images
(3).使用inspect命令查看详细信息
使用docker inspect命令可以获取该镜像的详细信息,包括制作者,适应架构,各层数字摘要等:
docker inspect ubuntu:14.04
返回的是一个JSON格式的消息,如果我们只要其中一项内容时,可以使用参数-f来指定,例如,获取镜像的Os:
docker inspect -f {{.Os}}
(4).使用history命令查看镜像历史
例如,查看ubuntu:14.04镜像的创建过程,可以使用如下命令:
docker history ubuntu:14.04
注意过长的命令被自动截断了,可以使用前面提到的--no-trunc选项来输出完整命令
3.搜寻镜像
使用docker search命令可以搜索远端仓库中共享的镜像,默认搜索官方仓库中的镜像。用法为docker search 镜像名
例如搜寻tomcat的镜像
可以看到返回了很多包含关键字的镜像,其中包括镜像名字,描述,星级(表示该镜像受欢迎程度)、是否官方创建、是否自动创建等。
默认的输出结果将按照星级评价进行排序。
4.删除镜像
(1)使用标签删除镜像
例如我要删除之前定义的mybuntu:latest镜像,可以使用下面的命令:
docker rmi myubuntu:latest
当镜像只剩下一个标签的时候就要特别小心,此时再使用docker rmi命令会彻底删除镜像。
例如删除的标签为ubuntu:14.04的镜像,由于该镜像没有额外的标签指向它,执行docker rmi命令,可以看出它会删除这个镜像文件的所有层:
(2)使用id删除镜像
注意:当有该镜像创建的容器存在时,镜像文件默认是无法被删除的,例如,先利用ubuntu:14.04镜像创建一个简单的容器并输出一句话
示例如下:
docker ps -a 命令可以看到本机上存在的所有容器:
可以看出,后台存在一个退出状态的容器,是刚基于ubuntu:14.04镜像创建的。
试图删除该镜像,Docker会提示有容器正在运行,无法删除:
如果想要强行删除镜像,可以使用-f参数。
注意:通常并不推荐使用-f参数来强制删除一个存在容器依赖的镜像。正确的做法是先删除依赖该镜像的所有容器,再来删除镜像。
比如我要删除nginx
我通过docker ps -a命令查看所有容器
找到ID
执行如下命令即可删除依赖容器最后再删除nginx镜像
docker rm e69099851e18
删除容器成功后再执行如下删除镜像命令
5.创建镜像
创建镜像的方法主要有三种:基于已有的镜像的容器创建、基于本地模板导入、基于Dockerfile创建。
(1)基于容器创建
该方法主要是使用docker commit命令。命令格式为docker commit 主要选项有:
-a, --author--"":作者信息
-c, --change--[]:提交的时候执行Dockerfile指令,包括CMD|ENTRYPOINT|ENV|EXPOSE|LABLE|ONBUILD|USER|VOLUME|WORKDIR等;
-m, --message="" 提交的信息
-p, --pause=true:提交时暂停容器运行。
下面演示如何使用命令创建一个新镜像。首先启动一个镜像,并在其中进行修改操作,例如创建一个test文件,之后退出:
docker run -it ubuntu:14.04 /bin/bash
touch test
exit
退出后执行docker ps -a命令获得容器ID
记住这个ID:471e0c7a7176
此时该容器跟原ubuntu:14.04镜像相比,已经发送了改变,可以使用docker commit 命令来提交一个新的镜像。提交时可以使用ID或名称来指定容器。
docker commit -m "Added a new file" -a "Docker Newbee" 471e0c7a7176 test:0.1
顺利的话,会返回新创建的镜像ID信息,例如7273577e3795e15cf04d715c29283acaf8d61de8be0409ec2eb03f2d776b883b
此时查看本地镜像列表,会发现新创建的镜像已经存在了。
(2)基于本地模板导入
用户可以直接从一个操作系统模板文件导入一个镜像,主要使用docker import 命令。
模板网址:https://openvz.org/Download/template/precreated
wget http://download.openvz.org/template/precreated/ubuntu-14.04-x86_64-minimal.tar.gz 远程下载模板
下载成功后执行该命令即可实现基于本地模板导入镜像:
cat ubuntu-14.04-x86_64-minimal.tar.gz | docker import - ubuntu:14.04
查看镜像:
docker images
6.存入镜像和载入镜像
用户可以使用docker save和docker load命令来存入和载入镜像。
1.存出镜像
如果要导出镜像到本地文件,可以使用docker save命令。例如,导出本地的ubuntu:14.04镜像为文件ubuntu_14.04.tar,如下所示:
docker save -o ubuntu_14.04.tar ubuntu:14.04
2.载入镜像
可以使用docker load将导出的tar文件再导入到本地镜像库,例如从文件ubuntu_14.04.tar导入镜像到本地镜像列表,如下所示:
docker load --input ubuntu_14.04.tar 或docker load < ubuntu_14.04.tar
这将导入镜像及其相关的元数据信息(包括标签等)。导入成功后,可以使用docker images命令进行查看。
7.上传镜像
可以使用docker push命令进行镜像上传,默认上传到Docker Hub官方仓库(需要登录)。命令格式为:
docker push NAME[:TAG] | [REGISTRY_HOST[:REGISTRY_PORT]/]NAME[:TAG]
用户在Docker Hub网站注册后可以上传自制的镜像。例如用户user上传本地的test:latest镜像,可以先添加user/test:latest,然后用docker push命令上传镜像:
docker tag test:latest user/test:latest
第一次上传时,会提示输入登录信息或进行注册。
Docker实战(一)之使用Docker镜像的更多相关文章
- Docker实战(二)之操作Docker容器
容器是Docker的另外一个核心概念.简单来说,容器是镜像的一个运行实例.所不同的是,镜像是静态的只读文件,而容器带有运行时需要的可写文件层.如果认为虚拟机是模拟运行的一整套操作系统系统(包括内核,应 ...
- Docker实战(三)之访问Docker仓库
仓库是集中存放镜像的地方,分为公共仓库和私有仓库.一个容易与之混肴的概念是注册服务器.实际上注册服务器是存放仓库的具体服务器,一个注册服务器上可以有多个仓库,而每个仓库下面可以有多个镜像.从这方面来说 ...
- Docker 实战(二)——centos7镜像安装nginx,将安装nginx的centos容器生成新的镜像,并导出
Docker centos7镜像安装nginx 1.安装docker 使用yum安装docker不再重复:见 Linux常用命令 2.pull centos 1)在docker仓库中搜索centos ...
- Docker实战(7):Docker无日志(无*-json.log文件)
出现这种情况基本都是docker 版本太旧,我的处理方案就是将docker 版本升级到最新,然后重新docker run 一遍就会有了.注意:docker 升级后,原来images,容器会出现一些小问 ...
- Docker实战之Consul集群
前言 最近参加了几场 Java 面试,发现大多数的微服务实践还是 Eureka 偏多,鉴于笔者的单位选型 Consul,这里对 Consul 做简单总结. 该篇是 Docker 实战系列的第三篇.传送 ...
- 详解docker实战之搭建私有镜像仓库 - kurbernetes
1.实战目的 搭建企业私有的镜像仓库,满足从开发环境推送和拉取镜像.当我们使用k8s来编排和调度容器时,操作的基本单位是镜像,所以需要从仓库去拉取镜像到当前的工作节点.本来使用公共的docker hu ...
- 实战docker,编写Dockerfile定制tomcat8镜像,实现web应用在线部署
最初在tomcat上部署web应用的方式,是通过maven的maven-compiler-plugin插件先打成war包,再将war包复制到tomcat的webapps目录下,后来用上了tomcat7 ...
- Docker 实战—使用 Dockerfile 构建镜像
Dockerfile 指令详解请访问:https://www.cnblogs.com/cloudfloating/p/11737447.html 使用 Alpine Linux 作为基础镜像 Alpi ...
- netcore 创建腾讯云私有镜像 发布到docker 实战
上一篇博客写的 netcoer上传到docker ,编译 并发布,传送门:FineUICore基础版部署到docker实战 这是一种笨方法,理想的方法是,在本地编译成镜像,然后推送到镜像仓库,服务器的 ...
随机推荐
- Android DiskLruCache完全解析,硬盘缓存的最佳方案
Android DiskLruCache完全解析,硬盘缓存的最佳方案 概述 记得在很早之前,我有写过一篇文章Android高效加载大图.多图解决方案,有效避免程序OOM,这篇文章是翻译自Andro ...
- HwUI下载地址
下载地址:HwUI.0.0.1.zip
- python 函数私有方法
#coding:utf-8 class A(object): def _test1(self): print('this is _test1') def test2(self): print('thi ...
- 深入浅出图解【计算机网络】 之 【TCP可靠传输的实现2: 超时重传+拥塞控制】
[前言]上一篇文章介绍了关于TCP的基础知识,以及建立(释放)连接和滑动窗口的概念. 本篇文章将延续上一篇的思路,继续介绍TCP实现可靠传输的机制. 超时重传 上一篇文章里介绍过TCP采用停止等待协议 ...
- C#(简单递归)和实现IComparable接口
递归: using System; using System.Collections.Generic; using System.Linq; using System.Text; using Syst ...
- 前端学习之HTML(1)
HTML标签学习 2018-10-31 记录一下学习的网站 http://www.w3school.com.cn http://www.runoob.com/ <!DOCTYPE html> ...
- VMware安装vnwaretools
1. 在VMware Fusion 6.0.4下安装Ubuntu镜像:ubuntu-14.04.1-desktop-amd64.iso 2. 点击虚拟机菜单栏-安装VMware Tools 3. 进入 ...
- [转]XSS的原理分析与解剖:第四章(编码与绕过)
0×01前言 很抱歉,这第四章被我推了几个月,今天是元旦难得有空,就把第四章写下.我先把主要使用的编码说下,介绍完会说下绕过. 本文建议与<杂谈如何绕过WAF>一同阅读. 0×02 URL ...
- web service概念、架构及相关知识
原文:http://blog.csdn.net/liu_shi_jun/article/details/51121597 一.WebService的定义 WebService有好几种定义: W3C组织 ...
- oracle 用户创建、修改、删除
创建用户: create user test identified by test; 修改密码: 1.alter user test identified by mima; 2.passw[ord] ...