Docker应用容器引擎介绍与搭建-阿里云开发者社区

开发者社区> 喵了个咪_> 正文

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

简介: Docker相信大家都不默认,没有实践过的童鞋也应该听过他的大名,笔者最近挺长一段使用都在使用Docker解决各种问题,而在最近也吧Kubernetes的坑爬完实践了起来,那么从今天开始笔者会带来关于Docker容器化相关的博文,一同探索Docker为什么这么火热,我们怎么去实践使用它.
+关注继续查看

Docker相信大家都不默认,没有实践过的童鞋也应该听过他的大名,笔者最近挺长一段使用都在使用Docker解决各种问题,而在最近也吧Kubernetes的坑爬完实践了起来,那么从今天开始笔者会带来关于Docker容器化相关的博文,一同探索Docker为什么这么火热,我们怎么去实践使用它.

附上:

喵了个咪的博客: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相关的一些命令

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

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
Docker实战(九)之数据库应用
目前,主流数据库包括关系型和非关系型两种。 关系型数据库是建立在关系模型基础上的数据库,借助于集合代数等数学概念金额方法来处理数据库中的数据,支持复杂的事务处理和结构化查询。代表实现有MySQL 、Oracle、PostGreSQL、MariaDB、SQLServer等。
1159 0
怎么设置阿里云服务器安全组?阿里云安全组规则详细解说
阿里云服务器安全组设置规则分享,阿里云服务器安全组如何放行端口设置教程
8409 0
Exceptionless 5.0.0本地Docker快速部署介绍
Exceptionless 是一个开源的实时的好用的日志收集框架,它将日志收集变得简单易用并且不需要了解太多的相关技术细节及配置。但是之前的版本将其Web和API绑定在了Windows平台通过IIS运行,对于已经步入云原生时代的我们显得有点格格不入。
1814 0
JavaScript轻应用网络模块介绍
JavaScript轻应用提供了网络管理相关的功能,APP可以通过JSAPI获取网络相关的信息,并且可以接收网络连接、断开的事件。
48 0
谷歌助力,快速实现 Java 应用容器化
原文地址:梁桂钊的博客 博客地址:http://blog.720ui.com 欢迎关注公众号:「服务端思维」。一群同频者,一起成长,一起精进,打破认知的局限性。 Google 在 2018 年下旬开源了一款新的 Java 工具 Jib,可以轻松地将 Java 应用程序容器化。
1172 0
应用容器化优化指南 - Golang篇
前言 随着容器技术的兴起,越来越多不同类型的应用开始使用容器的方式进行交付。Golang作为服务器端非常热门的一门语言同时也是容器技术的主要编写语言备受关注。那么将一个Golang应用进行容器化的时候,需要注意哪些事情,在出现问题时该如何进行调优和诊断呢? 先谈谈Golang本身的设计 Golang是谷歌发布的第二款开源编程语言。
3241 0
借助阿里云ECS实现传统.NET应用容器化(上)
我们都知道.NET Core应用可以跑在Docker上,那.NET Framework 4.x应用呢?借助阿里云ECS主机(Windows Server 2019 with Container版本),一切变得So Easy!
303 0
+关注
喵了个咪_
后端程序员,开源PHP框架PhalApi核心开发者,编写录制phalapi教程,phalcon爱好者编写phalcon教程以及zephir文档翻译,热爱交流沟通,喜欢go语言,欢迎大家一起交流沟通,探讨技术,座右铭:代码即真理,你的真理是什么呢?
166
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
《2021云上架构与运维峰会演讲合集》
立即下载
《零基础CSS入门教程》
立即下载
《零基础HTML入门教程》
立即下载