DevOps的涵盖面非常广,因为这个概念的火热,又有很多文章和技术都在把DevOps的帽子扣在自己头上,让很多人迷惑不解。其实,DevOps的知识体系如果从顶层上来分解,只有2块:方法论和工具链。方法论这块,因为DevOps的很多理念脱胎于敏捷,所以你所能了解到的各种敏捷理念,实践和方法都可以作为DevOps知识体系的一部分,关于这部分后续我单独写一篇文章来谈。今天想要和大家聊聊的关于DevOps工具链这块内容。

前段时间看到有人整理了一个这样的DevOps工具链周期表,说实话,上学的时候就最烦背元素周期表了,看着这个玩意儿我只是想吐(声明:不是说这个玩意儿不好哈,挺好的东西,就是戳中了吐点而已)。

人类不善于记忆复杂的数据和零散的知识,所以需要简化简化再简化,一图解千言:

简而言之,实现DevOps工具链你只需要3个核心基础架构:

– SCM 配置管理系统

– Automation 自动化系统

– Cloud 云(或者说可伸缩的,自服务的,虚拟化系统)

SCM 配置管理系统

配置管理是DevOps最底层的基础设施,无论是Configuration As Code 还是 Infrastructure As Code 强调的都是用管理代码的方式来管理环境,将环境版本化对于无论快速创建,还是可稳定的重复创建这些DevOps的基本要求来说都是最重要的基础。

在周期表的左侧第二列所列出的就是各种可供选择的配置管理系统,如:GIT, SVN, Mercurial, GitHub, Bitbucket 等。对于实施DevOps来说,选择哪种SCM的一个重要考虑点就是后续的Automation和Cloud这两个环节中的其它工具对这些工具的集成情况如何。作为这两年的明星Git来说,这一切都不是问题,当然是最好的选择。

SCM中所放置的内容又可以再分成2个层次,分别为

  • AppCode:就是你的应用代码
  • EnvCode:就是环境相关的代码,这部分内容又可以进一步细化成环境配置(Config)和配置数据(ConfigData)。
    • 环境配置:是那些针对当前应用基本上固定的环境配置
    • 环境数据:是那些需要在部署的同时根据情况调整的数据,如:配置文件,开发/测试/生产环境的地址等等。

Automation 自动化系统

自动化在DevOps中的作用不用多说了,这部分的主线一般由各种类型的Build系统来实现,如:Jekins, Team City, Travis CI, CC等等。但仅仅有这些还不够,为了能够完成应用从开发环境到生产环境的迁移,我们还必须处理如编译,自动化测试,依赖恢复,容器构建,打包,编排等很多操作,所以还需要配置如:Junit, Xunit, FitNesse, Selenium, NuGet, NPM,JMeter等许多其它的工具来实现;但这些工具都只是在自动化系统中实现某一部分的功能,一般都是由Build系统来驱动,并依赖于SCM中所提供的各种代码来实现的。

在我的那张图中,所有这些内容最终会汇总到一个叫做MOF的节点,作为后续进入环境的起点。MOF是DMTF这个标准化组织提出的一个工具和厂商无关的描述性语言,当前已经被很多厂商所接受并正在工具中逐步实现,DMTF的厂商列表可以在这里查到:

http://www.dmtf.org/cn/about/list

说实话,各种DevOps部署工具的标准化做的非常不好,基本上你使用了某种工具就被绑定了,虽然DMTF提出了这个标准一段时间了,一些主流的工具对它的支持仍然有限,如:Puppet 和 Chef等。对于用户来说,熟悉了某种工具也不太愿意更换其它的,所以对于DMTF的前景我是持怀疑态度的。这是一场博弈,对于用户来说,有标准总比没有好,多了解一些总是好事。

Cloud云

虚拟化和云计算的出现应该是催生DevOps的重要因素,没有云所提供的弹性,自服务等特性,很多DevOps的理念只能停留在纸面上。

对于实施DevOps来说,我们需要了解的就是各种云所提供的API,因为无论是自动化系统还是前面的SCM的产出最终都需要调用这些API来完成最终应用部署。

这部分的内容很多,就不展开了。


写这篇文章的原因很简单,就是觉得东西太多,需要梳理,其中如有不妥之处,还望各位多多指正。希望这篇文章至少能帮大家找到了解DevOps工具链的入手之处,形成自己的知识体系,逐步扩展。

请关注微信公众号 【devopshub】,获取更多关于DevOps研发运维一体化的信息

一个都不能少: DevOps的3大核心基础架构的更多相关文章

  1. Coursera台大机器学习基础课程1

    Coursera台大机器学习基础课程学习笔记 -- 1 最近在跟台大的这个课程,觉得不错,想把学习笔记发出来跟大家分享下,有错误希望大家指正. 一 机器学习是什么? 感觉和 Tom M. Mitche ...

  2. Java轻量级业务层框架Spring两大核心IOC和AOP原理

    IoC(Inversion of Control): IOC的基本概念是:不创建对象,但是描述创建它们的方式.在代码中不直接与对象和服务连接,但在配置文件中描述哪一个组件需要哪一项服务.容器负责将这些 ...

  3. css核心基础总结篇

    今日这篇是整合前面的css补充知识的. 我觉得前面的关于css的知识补充进去有点乱,今日整理整理一下. 层叠样式表 层叠是什么意思?为什么这个词如此重要,以至于要出现在它的名称里. 层叠可以简单地理解 ...

  4. Android应用的核心基础

    Android4开发入门经典 之 第二部分:Android应用的核心基础 Android应用中的组件 Application Components Android应用中最主要的组件是: 1:Activ ...

  5. Servlet---JavaWeb技术的核心基础,JavaWeb框架的基石(一)

    初学JavaWeb开发,请远离各种框架,从Servlet开始.         Web框架是开发者在使用某种语言编写Web应用服务端是关于架构的最佳实践.很多Web框架是从实际的Web项目抽取出来的, ...

  6. 大数据基础知识问答----hadoop篇

    handoop相关知识点 1.Hadoop是什么? Hadoop是一个由Apache基金会所开发的分布式系统基础架构.用户可以在不了解分布式底层细节的情况下,开发分布式程序.充分利用集群的威力进行高速 ...

  7. 【原创】大数据基础之Zookeeper(2)源代码解析

    核心枚举 public enum ServerState { LOOKING, FOLLOWING, LEADING, OBSERVING; } zookeeper服务器状态:刚启动LOOKING,f ...

  8. C#复习笔记(2)--C#1所搭建的核心基础

    通过对C#1所搭建的核心基础的深入了解,可以知道之后的C#版本在C#1的基础上做了很多扩展,而这些扩展都是基于C#搭建的核心基础而来的. 委托 一.编写委托的过程 委托经常和C语言的“函数指针”挂钩. ...

  9. Java入门到精通——框架篇之Spring源码分析Spring两大核心类

    一.Spring核心类概述. Spring里面有两个最核心的类这是Spring实现最重要的部分. 1.DefaultListableBeanFactory 这个类位于Beans项目下的org.spri ...

随机推荐

  1. hdu 5441 (并查集)

    题意:给你n个点,m条边构成无向图.q个询问,每次一个值,求有多少条路,路中的边权都小于这个值 a->b 和 b->a算两种 思路:把权值从小到大排序,询问从小到大排序,如果相连则用并查集 ...

  2. 【UVA–11997 K Smallest Sums 】

    ·哦,这题要用优先队列?那大米饼就扔一个手写堆上去吧! ·英文题,述大意:       输入n个长度为n的序列(题中是k,2<=k<=750).一种结果定义为:从每个序列中都要挑选一个数加 ...

  3. 解读Raft(一 算法基础)

    最近工作中讨论到了Raft协议相关的一些问题,正好之前读过多次Raft协议的那paper,所以趁着讨论做一次总结整理. 我会将Raft协议拆成四个部分去总结: 算法基础 选举和日志复制 安全性 节点变 ...

  4. Splay讲解

    Splay讲解 Splay是平衡树的一种,是一种二叉搜索树,我们先讲解一下它的核心部分. Splay的核心部分就是splay,可能有些人会说什么鬼?这样讲解是不是太不认真了?两个字回答:不是.第一个S ...

  5. 浅谈Java中的equals和==与hashCode

    转载:https://www.cnblogs.com/dolphin0520/p/3592500.html 参考:http://blog.csdn.net/yinzhijiezhan/article/ ...

  6. 索引法则--少用OR,它在连接时会索引失效

    Mysql 系列文章主页 =============== 1 准备数据 1.1 建表 DROP TABLE IF EXISTS staff; CREATE TABLE IF NOT EXISTS st ...

  7. axios的兼容性处理

    一.简介 看看官网的简介: "Promise based HTTP client for the browser and node.js" 译:基于 Promise 的 HTTP ...

  8. Parallel.For 平行算法 使用

    之前看到Parallel的用法,觉得很高深,很腻害,今天专门抽空研究了一下,发现还是很easy的. .NET Framework 4.0 新加的功能,所以4.0之前的无法使用哦. 下面介绍一下,Par ...

  9. 实践详细篇-Windows下使用VS2015编译安装Caffe环境(CPU ONLY)

    学习深度学习背景 最近在做一款抢票软件,由于12306经常检测账号状态,抢票抢着抢着就需要重新登录了,然后登录是需要验证码的.所以我最开始是想到了使用java基于感知哈希算法pHash做相似度匹配识别 ...

  10. Printer for Me

    今天,良心系部终于给我配了打印机^^. 办公室门外还挂了牌子.