文档章节

Docker应用容器引擎介绍与搭建

喵了_个咪
 喵了_个咪
发布于 2018/05/05 14:53
字数 1603
阅读 234
收藏 13

附上:

喵了个咪的博客:w-blog.cn

官方Git地址:https://github.com/moby/moby

1. 为什么Docker会火

  • 截止到现在Docker在github上的star数有48570
  • 阿里云,腾讯云,AWS,都推出了自己的Docker平台
  • 70%的调查企业已经正在使用或考虑使用Docker;

大家回顾以往的经理往往比较火的软件系统(比如Hadoop)都是解决了一个领域上痛点,Docker也不例外,就笔者总结有如下痛点是Docker解决的:

  • 复杂的环境搭建 笔者之前安装一个软件可能有各种依赖关系极为复杂(比如:APPRTC),Docker可以吧环境依赖打包在一起只需要一条命令就可以开箱使用
  • 隔离性 - 每个用户实例之间相互隔离, 互不影响。 比如你的程序A需要使用PHP7.0,程序B需要使用PHP7.2,但是程序A不能使用PHP7.2,在虚拟的时候你只能选择开两台,使用docker就可以在同一台服务器互不影响的情况下顺利运行
  • 可配额/可度量 - 每个用户实例可以按需提供其计算资源,所使用的资源可以被计量。 笔者在运营环境出过一次事故,大致是A应用除了点问题导致CPU吃高,其他程序全部都无法访问,有的docker可以定额分配资源限制不重要的程序不会影响到重要的程序
  • 移动性 - 用户的实例可以很方便地复制、移动和重建以及回滚。
  • 基本不增加额外的性能消耗 Docker直接移植于Linux内核之上,通过运行Linux进程将底层设备虚拟隔离,这样系统性能的损耗也要比虚拟机低的多,几乎可以忽略。同时,Docker应用容器的启停非常高效,可以支持大规模的分布系统的水平扩展,真正给企业开发带来福音。
  • DevOps持续迭代交付 Docker技术将应用以集装箱的方式打包交付,使应用在不同的团队中共享,通过镜像的方式应用可以部署于任何环境中。这样避免了各团队之间的协作问题的出现,成为企业实现DevOps目标的重要工具。以容器方式交付的Docker技术支持不断地开发迭代,大大提升了产品开发和交付速度。

正如中国惠普云计算集成云技术首席专家刘艳凯所说的那样:“任何一项技术的发展和它受到的追捧,都是因为它能够解决困扰人们的问题”,Docker就是用来解决这个问题的

2. 搭建安装

这里选择使用Centos来安装Docker

  1. 安装所需的包。yum-utils提供了yum-config-manager 效用,并device-mapper-persistent-data和lvm2由需要 devicemapper存储驱动程序。
> yum install -y yum-utils device-mapper-persistent-data lvm2
  1. 使用以下命令设置release存储库。即使您想从edge和test存储库安装构建,也总是需要release存储库。
> yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
  1. 可选:启用edge和test存储库。这些存储库包含在docker.repo上面的文件中,但默认情况下处于禁用状态。您可以将它们与稳定的存储库一起启用
> yum-config-manager --enable docker-ce-edge
> yum-config-manager --enable docker-ce-test

您可以通过使用该标志运行命令来禁用edge和test存储库 。

> yum-config-manager --disable docker-ce-edge

安装Docker CE

通过以下命令可以直接安装最新版本的Docker-ce

> yum install docker-ce

如果启用了多个Yum存储库,则安装或更新时未指定版本yum install或 yum update命令始终会安装尽可能高的版本,这可能不适合您的稳定性需求。

在生产系统上,您应该安装特定版本的Docker CE,而不是始终使用最新版本。列出可用的版本。

此示例使用该sort -r命令按版本号对结果进行排序,从最高到最低。

> yum list docker-ce --showduplicates | sort -r

docker-ce.x86_64            18.02.0.ce-1.el7.centos             docker-ce-edge  
docker-ce.x86_64            18.01.0.ce-1.el7.centos             docker-ce-edge  
docker-ce.x86_64            17.12.1.ce-1.el7.centos             docker-ce-stable
docker-ce.x86_64            17.12.1.ce-1.el7.centos             docker-ce-edge  
docker-ce.x86_64            17.12.0.ce-1.el7.centos             docker-ce-stable
docker-ce.x86_64            17.12.0.ce-1.el7.centos             docker-ce-edge  
docker-ce.x86_64            17.11.0.ce-1.el7.centos             docker-ce-edge  
docker-ce.x86_64            17.10.0.ce-1.el7.centos             docker-ce-edge  

列表的内容取决于启用了哪些存储库,并且特定于您的CentOS .el7版本(在此示例中,由版本的后缀指示)。选择一个特定的版本进行安装。第二列是版本字符串。您可以使用整个版本字符串。第三列是存储库名称,它指示软件包来自哪个存储库。要安装特定版本,请将版本字符串附加到包名称并用连字符(-)分隔。

注意:版本字符串是软件包名称加上第一个连字符的版本。在上面的例子中,完全的包名是docker-ce-17.03.0.ce

为了后面可是搭建Kubernetes可以参考个更新日志里面的描述

kubernetes/CHANGELOG-1.8.md at master · kubernetes/kubernetes · GitHub

Kubernetes 1.8  <--Docker 1.11.2 to 1.13.1 and 17.03.2

这里选择Rancher认证过的17.03.2并且K8S支持版本

# 先安装docker-ce-selinux-17.03.2.ce,否则安装docker-ce会报错
> yum install https://download.docker.com/linux/centos/7/x86_64/stable/Packages/docker-ce-selinux-17.03.2.ce-1.el7.centos.noarch.rpm 
> yum install docker-ce-17.03.2.ce

启动Docker并且设置开机自启。

> systemctl start docker
> systemctl enable docker

docker通过运行hello-world 映像验证安装是否正确。

> docker run hello-world
# 如下输出证明已经完成了Docker环境的搭建
Hello from Docker!

3 总结

第一步已经完成已经可以使用Docker环境了,下一步我们需要熟悉Docker相关的一些命令

注:笔者能力有限有说的不对的地方希望大家能够指出,也希望多多交流!

© 著作权归作者所有

共有 人打赏支持
喵了_个咪
粉丝 327
博文 150
码字总数 199180
作品 4
杨浦
技术主管
私信 提问
开源技术微讲堂:Kubernetes 系列

Kubernetes (通常称为K8s) 是一个开源系统,它可以被用于自动部署,扩展和管理容器化应用程序,提供跨主机集群的自动部署、扩展以及运行应用程序容器的平台。Kubernetes 以其先进的理念、活跃...

developerWorks中国
2017/12/11
0
0
每天5分钟玩转Docker容器技术(一)

写在最前面 《每天5分钟玩转Docker容器技术》是一个有关容器技术的教程,有下面两个特点: 系统讲解当前最流行的容器技术 从容器的整个生态环境到各种具体的技术,从整体到细节逐一讨论。 重...

2017/12/25
0
0
第1章 容器技术和Docker简介

容器技术。docker。 到底什么是docker? 虚拟机和容器的区别。创建虚拟机,不同应用在不同虚拟机内进行隔离。容器技术进行隔离。 不需要虚拟化这一层虚拟的操作系统,只需要在本地操作系统之...

天涯明月笙
2018/07/09
0
0
【笔记】基于Docker在MacBook安装Informix Developer Edition

序言 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互...

军雷
2018/06/03
0
0
Docker 这九个不同的应用场景,你都用到了吗?

Docker 是一个开源的容器引擎,可以轻松的为任何应用创建一个轻量级的、可移植的、自给自足的容器。开发者和系统管理员在笔记本上编译测试通过的容器可以批量地在生产环境中部署,包括 VMs(...

编辑部的故事
2017/10/31
0
4

没有更多内容

加载失败,请刷新页面

加载更多

阿里云vpc、快照、镜像、重置密码_重启_关机、磁盘扩容

VPC 专有网络VPC(Virtual Private Cloud)是用户基于阿里云创建的自定义私有网络, 不同的专有网络之间二层逻辑隔离,用户可以在自己创建的专有网络内创建和管理云产品实例,比如ECS、负载均...

李超小牛子
18分钟前
1
0
阿里高级技术专家:研发效能的追求永无止境

背景 大约在5年前,也就是2013年我刚加入阿里的时候,那个时候 DevOps 的风刚吹起来没多久,有家公司宣称能够一天发布几十上百次,这意味着相比传统软件公司几周一次的发布来说,他们响应商业...

阿里云官方博客
47分钟前
1
0
Android 的 ViewModel 机制源码解析

Android ViewModel 的好处是会随 Activity 销毁调用它的 clear() 方法。 我们分析一下它是怎么做到的。 1. 例子使用: a、 创建类 TestMvvmViewModel 继承 ViewModel,重写 onCleared() ,把...

亭子happy
58分钟前
2
0
WEB 开发总结

事务处理 事务的4个基本特征 1.Atomic(原子性),事务中包含的操作被看做是一个整体的业务单元,这个业务单元中的操作要么全部成功,要么全部失败,不会出现部分成功,部分失败的场景。 2....

北漂的我
今天
3
0
thinkphp5 利用七牛云 将amr格式语音文件转为mp3

$card_id 是我的本地的文件 将问价名字的后缀名去掉注意access_token的有效期public function ceshi1($card_id){ $mediaid = substr($card_id, 0, -4); $accessKey = ...

小小小壮
今天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部