DevOps

DevOps(Development+Operations)强调共同对业务目标负责,以实现用户价值作为唯一的评判标准:保证产品功能及时实现、成功部署和稳定使用;

  • 是一种重视软件开发人员(Dev)和IT运维技术人员(Ops)之间沟通合作的文化、运动或惯例,改善团队之间的协作关系;
  • 是一组过程、方法与系统的统称,包含开发、测试和运维;
  • 用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合;
  • 透过自动化“软件交付”和“架构变更”的流程,使得构建、测试、发布软件能够更加地快捷、频繁和可靠,按时交付软件产品和服务;

总的说来:

  • DevOps 是把人员、流程、产品进行结合,给用户提供持续价值的一个过程,既涉及到人员、流程、工具,也涉及到产品。
  • DevOps 最终目的是给客户提供持续交付的价值,流程包括:产品的规划跟踪、软件开发、构建测试、产品部署、运维、监控和优化。
  • 通常把 DevOps 这些流程通过一个流水线的方式串联起来称为一个 DevOps 的流水线,其核心目标就是持续给用户交付有价值的产品。

简而言之,DevOps不仅涉及技术背景,还包括非技术的文化方面。

在软件开发和应用周期中,提供了一个机制或模式来培育“协作”意识,帮助不同角色的成员紧密协作,充分利用现有资源,遵循交付的商业价值,共同对“输出”负责,对质量负责。

DevOps的好处与价值

对于业务与产品而言,DevOps的好处更多基于持续部署与交付。

从组织结构而言,DevOps是部门间沟通协作的一组流程和方法,有助于改善公司组织文化、提高员工的参与感。

  • 代码的提交直接触发:消除等待时间,快速反馈
  • 每个变化对应一个交付管道:使问题定位和调试变得简单
  • 全开发流程高效自动化:稳定,快速,交付结果可预测
  • 持续进行自动化回归测试:提升交付质量
  • 设施共享并按需提供:资源利用最大化

可能的几个关注点

DevOps绝不是推荐一定要在某一方面达到极致,而是从“整体”入手,充分激发“体系”的最佳效率。

  • 虽然真正实现DevOps的成本高昂,但任何时候都是实现DevOps的最佳时机,因为随着业务发展,成本一定是越来越高的;
  • 组织文化上的变革,鼓励不同的个体与部门共同协作,减少“内耗”;
  • 合适的DevOps人员(最起码保证在“向DevOps转换阶段”中,研发人员知晓运维,运维人员了解业务);
  • 统一的标准、环境、工具、流程,例如:开发/测试环境尽可能地和生产环境保持一致;
  • 自动化和持续交付,简化重复性工作和减少不必要的等待
  • 涉及多个技术支撑:敏捷开发、持续集成&部署、微服务、容器、云环境等;
  • 个体和团队的成效都放在整个产品开发&运维生命周期内来进行评价;

DevOps能力环

DevOps与持续集成、持续交付

DevOps的应用场景往往是一个庞大复杂的背景和流程的场景,大都包含一个持续交付流水线。

  • 开发人员:IDE、Git等开发和编译工具
  • 版本控制系统:分支策略、语义化版本
  • 构建服务器:持续集成、代码质量检查
  • 工件库:存放二进制包
  • 系统的包管理器:编译或测试环境系统上管理二进制包
  • 环境一致性
  • 预发布或生产:预发布环境与生产环境互换(蓝绿发布)
  • 发布管理:在高程度自动化测试的基础上实践自动化或半自动化(人工介入)部署
  • 问题管理系统
  • 。。。。。。

    因此,DevOps 是一个完整的面向IT运维的工作流,以 IT 自动化以及持续集成(CI)、持续部署(CD)为基础,来优化程式开发、测试、系统运维等所有环节。

    DevOps的技术要点由“持续集成/部署“”一线贯穿,主干开发是进行持续集成的前提,自动化以及代码周边集中管理是实施持续集成的必要条件。

    换而言之,DevOps 是持续集成思想的延伸,持续集成/部署是 DevOps 的技术核心,在没有自动化测试、持续集成/部署之下,DevOps就是空中楼阁。

一个完整的过程

  1. 开发团队接到任务,需要完成一个变更
  2. 为了更加顺利地开发,将这个变更分拆为几个小变更
  3. 开发人员在本地开发并且测试,如果使用了测试驱动开发,在编写功能代码之前会先编写测试,然后编写能够让测试通过的实际代码
  4. 开发人员将代码提交到企业内部的Git版本控制系统上
  5. 构建服务器获取这个变更并初始化构建流程,单元测试之后,变更可以被发布到二进制库里
  6. 配置管理系统根据“策略”,在测试环境中安装应用了新的变更
  7. 新安装触发自动化回归测试,测试成功后,质量保证团队开始做人工测试
  8. 人工测试通过后,质量保证团队将“已通过”标识给予这个变革
  9. 变更在预发布环境中进行验收测试
  10. 验收测试完成后,预发布环境被切换成生产环境,而生产环境变为新的预发布环境

典型的CICD流水线过程

  1. 项目开发编写代码,然后把代码推送到 GitLab 里存储,通过 GitLab 的 hook 使 Jenkins 执行一些 CI 的过程,比如做一些单元测试,构建 Docker image
  2. 再把这个 Docker image 调用 helm 部署到开发环境或测试环境
  3. 在测试环境里通过 Jenkins 触发一个集成测试的功能
  4. 完成后就可以把它部署到生产环境
  5. 通过 Kubernetes addon 的方式,把 Prometheus、Grafana 等监控组件部署到集群里,实现一整套从 CI 到 CD 的监控过程

DevOps黄金思维圈

时刻关注正在做什么,尝试识别问题范围,找出解决方案和改善途径。

Why---》How---》What

Why(目的、理念)

持续且快速、可靠的自动交付软件给用户:

  1. 实现价值的持续交付,赢得市场竞争
  2. 提升研发(增值活动)的时间,极大化增值活动产出

How(方法、措施)

  • 建设自动化、可重复、可靠的持续交付流水线(IT服务供应链)
  • 主要包括代码管理、持续集成、自动化测试、自动化部署、基础设施自动化管理等方面的工程能力

What(现象、成果)

  1. 每次代码提交都需要经过流水线验证
  2. 每次部署的版本都经过多环境验证
  3. 部署频率可以得到提升
  4. 周期时间(从代码提交到部署上线)的时间可以到分钟级
  5. 部署失败率低
  6. 部署失败的修复时间短,影响小

初见

一些图示

关系与演进

涉及的工具

DevOps的目标不是单靠一款工具就能实现的。

在各个阶段,每个都有其单独对应的目标。

依赖于组织的选择,有着各种各样的工具可以在相应的背景和趋势下,实现当前业务目标,满足中远期的需求。

Action is the antidote to despair!




欢迎转载和引用,但请在明显处保留原文链接和原作者信息!


本博客内容多为个人工作与学习的记录,少部分内容来自于网络并略有修改,已尽力标明原文链接和转载说明。如有冒犯,即刻删除!





以所舍,求所获,有所依,方所成。

DevOps - DevOps基础概念梳理的更多相关文章

  1. java SE 基础概念梳理(一)

     (一)First 摘要:Java概述.Java开发环境搭建.程序开发流程 Java概述  Java的应用 开发QQ.迅雷程序(桌面应用软件)开发淘宝.京东(互联网应用软件) Java的擅长 互联网: ...

  2. 一篇文全面了解DevOps:从概念、关键问题、兴起到实现需求

    一篇文全面了解DevOps:从概念.关键问题.兴起到实现需求 转自:一篇文全面了解DevOps:从概念.关键问题.兴起到实现需求 2018-06-06 目前在国外,互联网巨头如Google.Faceb ...

  3. 【转帖】使用容器化和 Docker 实现 DevOps 的基础知识

    使用容器化和 Docker 实现 DevOps 的基础知识 https://www.kubernetes.org.cn/6730.html 2020-02-24 15:20 灵雀云 分类:容器 阅读( ...

  4. Anliven - 基础知识梳理汇总 - 软件测试

    基础知识梳理 - 软件测试 - 概念 基础知识梳理 - 软件测试 - 分类 基础知识梳理 - 软件测试 - 流程 基础知识梳理 - 软件测试 - 用例 基础知识梳理 - 软件测试 - 方法 基础知识梳 ...

  5. TCP/IP基础概念及通信过程举例

    TCP/IP基础概念及通信过程举例 出现 上个世纪60年代,由于中央集中式网络的容灾性较弱,以美国国防部为中心的一家组织研究出分组交换网络.后来为了验证分组交换技术的实用性,ARPANET出现了,并且 ...

  6. MySQL 基础知识梳理

    MySQL 的安装方式有多种,但是对于不同场景,会有最适合该场景的 MySQL 安装方式,下面就介绍一下 MySQL 常见的安装方法,包括 rpm 安装,yum 安装,通用二进制安装以及源码编译安装, ...

  7. CCNA-Part1:网络基础概念

    由于身处一家网络公司,日常项目中设计到的网络概念较多,恰逢之后公司组织相关培训.借此机会,打算写下一系列文章用于之后梳理并回顾.文章主要涉及 NA,NP 中所覆盖的知识.由于网络分为较多方向,如路由交 ...

  8. Spring Cloud Security OAuth2.0 认证授权系列(一) 基础概念

    世界上最快的捷径,就是脚踏实地,本文已收录[架构技术专栏]关注这个喜欢分享的地方. 前序 最近想搞下基于Spring Cloud的认证授权平台,总体想法是可以对服务间授权,想做一个基于Agent 的无 ...

  9. Golang 基础之基础语法梳理 (三)

    大家好,今天将梳理出的 Go语言基础语法内容,分享给大家. 请多多指教,谢谢. 本次<Go语言基础语法内容>共分为三个章节,本文为第三章节 Golang 基础之基础语法梳理 (一) Gol ...

  10. Golang 基础之基础语法梳理 (一)

    大家好,今天将梳理出的 Go语言基础语法内容,分享给大家. 请多多指教,谢谢. 本次<Go语言基础语法内容>共分为三个章节,本文为第一章节 Golang 基础之基础语法梳理 (一) Gol ...

随机推荐

  1. [转]CLion 2019去掉灰色参数提示(parameters hints)

    众所周知,clion是一个很好用的c plus plus IDE,刚装好的clion默认的设置多少有一些不符合口味的地方,在查看代码或者敲代码的时候看到如下这样的灰色提示,我是有点受不了的: 之前用的 ...

  2. 解决git clone 速度慢的问题

    解决git clone 速度慢的问题 1.原因 git clone特别慢是因为github.global.ssl.fastly.net域名被限制了. 只要找到这个域名对应的ip地址,然后在hosts文 ...

  3. ElasticSearch接口

    DSL语法 DSL为ES过滤数据时的语法,可用于查询.删除等操作 基本构成 默认分页查询,size默认为10.ES查询默认最大文档数量限制为10000,可通过 index.max_result_win ...

  4. JVM实战—8.如何分析jstat统计来定位GC

    大纲 1.使用jstat了解线上系统的JVM运行状况 2.使用jmap和jhat了解线上系统的对象分布 3.如何分析JVM运行状况并合理优化 4.使用jstat分析模拟的BI系统JVM运行情况 5.使 ...

  5. Solution Set -「NOIP Simu.」20221111

    \(\mathscr{A}\sim\) 遗忘十字路   Cover:「CF 1746D」Paths on the Tree.   Tag:「C.性质/结论」   最原始的思路自然是 DP. 令 \(f ...

  6. .NET 9.0 使用 Vulkan API 编写跨平台图形应用

    前言 大家好,这次我来分享一下我自己实现的一个 Vulkan 库,这个库是用 C# 实现的,主要是为了学习 Vulkan 而写的. 在学习 Vulkan 的过程中,我主要参考 veldrid,它是一个 ...

  7. WPF中webview2鼠标移动窗体

    WPF里webview2会一直处于其他控件最上层,是个历史遗留问题. 为了能在webview2里鼠标移动让窗体跟着移动位置代码如下: async Task InitializeAsync() { Ap ...

  8. java线程池优化

    ThreadPoolExecutor机制 一.概述 1.ThreadPoolExecutor作为java.util.concurrent包对外提供基础实现,以内部线程池的形式对外提供管理任务执行,线程 ...

  9. 微服务技术架构、监控、Docker、服务治理等详解

    1.什么是微服务 1)一组小的服务(大小没有特别的标准,只要同一团队的工程师理解服务的标识一致即可) 2)独立的进程(java的tomcat,nodejs等) 3)轻量级的通信(不是soap,是htt ...

  10. w3cschool-网站建设

    W3C 简介 什么是 W3C? W3C 指万维网联盟(World Wide Web Consortium) W3C 创建于1994年10月 W3C 由 Tim Berners-Lee 创建 W3C 是 ...