DevOps基础的认识与工具实践
什么是DevOps
- DevOps 强调的是高效组织团队之间如何通过自动化的工具协作和沟通来完成软件的生命周期管理,从而更快、更频繁地交付更稳定的软件
- Devops 包含了敏捷开发,测试,运维
- DevOps 是组织架构变革,更是团队文化和思想观念的变革
DevOps 的价值
- 填补开发,测试,运维之间的信息鸿沟,改善团队组织文化,提高参与感
- DevOps 是把人员、流程、产品进行结合,给用户提供持续价值的一个过程,既涉及到人员、流程、工具,也涉及到产品
- DevOps 最终目的是给客户提供持续交付的价值,流程包括:产品的规划跟踪、软件开发、构建测试、产品部署、运维、监控和优化。
- 简化重复性工作,减少不必要的等待,有工具进行发布部署,减少误操作的可能性
DevOps的目标
DevOps 必须以支持业务敏捷目标
- 精准,实时的响应客户需求
- 更好的体验和更高的效率
- 交付内容上关注完整的业务链条,交付过程上关注从业务,开发,运维在内的全链路流程实现端到端的快速响应,交付,稳定的运行
什么是持续集成
频繁的将代码集成到主干,就是让产品可以快速迭代,同时还能保持高质量。它的核心措施是,代码集成到主干之前,必须通过自动化测试。只要有一个测试用例失败,就不能集成
什么是持续交付
频繁地将软件的新版本,交付给质量团队或者用户,以供评审。如果评审通过,代码就进入生产阶段,它强调的是不管怎么更新,软件随时随地都是可以交互的
什么是持续部署
指的是代码通过评审以后,自动部署到生产环境,代码在任何时刻都是可部署的,可以进入生产阶段
Devops 工具实践
明确目标:指导最终实践的成果,DevOps 是一个比较宽泛的概念,不同的团队,不同的公司,不同的预算,实践出来的结果差异非常大,制定符合团队的DevOps 目标,解决团队实际的痛点,有利于实践。
资源:DevOps 工具有很多的云服务厂商,有预算,可以直接根据团队的需求,购买整套的基础设施,也可以利用开源的工具组装搭建,比如,Jenkins ,docker ,git ,镜像仓库等
团队文化:实践DevOps 是一次团队文化,组织架构的变革,比如引入敏捷项目管理,会根据Scrum 来调整团队的组织架构,开发可能要学习一些部署的基础知识,运维可能要学习一些开发的基础知识,Scrum中文网:https://www.scrumcn.com/agile/scrum-knowledge-library.html
实践
- 代码分支
- 明确开发,测试,线上等分支,明确分支的职责,设置对应的权限,制定符合团队的分支管理流程
- 明确代码合并的机制,制定合并的规则,例如
- 单元测试不通过,不能进行合并
- 代码Code Review 后才能合并
- 代码环境变量
- 明确环境所对应的代码环境变量
- 后端
- 开发环境:dev ,测试环境:test
- 前端
- 开发环境:dev ,测试环境:test
- 后端
- 明确代码依赖组件的环境
- Redis ,数据库 ,消息队列, 日志等
- 统一的命名方式,根据团队情况,看是否做每个组件环境的隔离
- 最好统一技术栈和统一依赖的版本
- 前端依赖包私有化:proget 等
- 明确环境所对应的代码环境变量
- 资源
- 明确有哪些可用的资源,比如,服务器,硬盘
- 根据预算资源和目标,寻找云服务的厂商,直接采购完整的DevOps平台
- 工具
- 使用开源的工具进行搭建
- 根据目标和目前实际部署情况,选择合适的工具,团队讨论,制定部署的方式和流程
- 基于docker部署:镜像仓库,docker,docker-compose 等
- 基于文件的方式部署
- 结合可用的资源,明确部署流程中,服务器资源的作用,以及承担的职责,画出部署图
- 根据目标和目前实际部署情况,选择合适的工具,团队讨论,制定部署的方式和流程
- 使用云服务进行搭建
- 阿里云云效 DevOps 平台
- 华为云 DevCloud 平台
- 使用开源的工具进行搭建
持续集成
- 自动化构建项目流程
- 从源码仓库签出最新的代码
- 选择源代码管理工具,要支持webhooks , 比如:GIT
- 选择合适的CI任务触发机制,比如,提交代码就进行CI,或者手动点击CI任务进行CI
- 静态分析,检查最新的代码是否存在潜在的 bug 并符合项目的编码规范
- 项目代码中选择合适的编码规范,比如Resharper,Sonar 等
- 集成SonarQube工具进行代码的检查,可视化的监控代码的质量
- 编译源码
- 编译源码看是否能成功编译
- 运行单元测试
- 根据团队的实际情况,为代码编写单元测试,制定单元测试标准
- 不要盲目追求覆盖率,而是思考业务上的价值(重要性与风险)
- 自动化运行单元测试,运行失败进行反馈,也可以利用可视化的工具,监控单元测试情况
- 单元测试运行失败,开发人员应该及时的进行修复,保证CI的正常运行
- 运行集成测试
- 自动运行集成测试
- 打包
- 自动化打包
- 从源码仓库签出最新的代码
持续部署
- 根据部署可用的资源,明确部署的方式,讨论出部署的方案
- 基于容器部署
- 基于文件部署
- 明确部署的目标,制定部署的完整流程,完善配套的方案
- 高可用
- 灰度发布
- 回滚方案
DevOps 度量指标
DevOps实践的成熟度差异很大,团队需要根据目标来制定符合团队期望的DevOps度量指标,根据团队使用的情况,不断的优化Devops,解决实际中的痛点
- 单元测试的错误率,测试覆盖率 ,CI修复时间
- 部署的频率,部署的失败率,部署时间
- 代码扫描漏洞出,BUG
参考文章
https://www.cnblogs.com/yibutian/p/9561749.html
https://mp.weixin.qq.com/s/4x4iNHO1aHzJr0SihzD5Rg
DevOps基础的认识与工具实践的更多相关文章
- [转载]DevOps在传统企业的落地实践及案例分享
内容来源:2017年6月10日,优维科技高级解决方案架构师黄星玲在“DevOps&SRE 超越传统运维之道”进行<DevOps在传统企业的落地实践及案例分享>演讲分享.IT 大咖说 ...
- 企业DevOps研发模式下CI/CD实践详解指南
阅读全文大概需要 10分钟. 1. 前言 借着公司今年新组建的中台研发部东风,我作为其中的主要负责人,在研发中心主导推行DevOps研发管理模式转变及质量管理创新建设,本篇文章摘取自今年9月底,笔者在 ...
- HUST高级软件工程--测试管理工具实践--Day4
测试管理工具实践--Day4 今天完成任务情况: 小靳 今天,主要在前两天的基础上继续学习挖掘jira相关内容: 学会了如何创建项目,并且创建了issue 学会了创建一般账号,并且可以将任务分发给一般 ...
- HUST高级软件工程--测试管理工具实践--Day3
测试管理工具实践--Day3 今天完成任务情况: 小靳 今天,大家参加考试,时间比较紧促.庆幸,自己的队伍比较给力,大家都没有拖后腿,深夜还在为自己的任务拼搏,很是激励人心 我今天的工作就是 学会了注 ...
- 第2课:操作系统网络配置【DevOps基础培训】
第2课:操作系统网络配置 --DevOps基础培训 1. DNS配置 1.1 什么是DNS? 域名系统(英文:Domain Name System,缩写:DNS)是互联网的一项服务.它作为将域名和IP ...
- 第1课:Linux操作系统基础【DevOps基础培训】
第1课:Linux操作系统基础 --DevOps基础培训 1. 云主机.公网IP 1.1 公网ip和私网ip 只有公网ip是能够连接互联网的,私网IP 一般只用作局域网 我们能够上网靠的是isp组织分 ...
- FW: Chef集中管理工具实践之 (1) 环境部署
本文转载:http://heylinux.com/archives/2208.html Chef集中管理工具实践之 (1) 环境部署 目录结构Chef集中管理工具实践之 (0) 什么是ChefChef ...
- 我的前端之旅--SeaJs基础和spm编译工具运用[图文]
标签:seajs nodejs npm spm js 1. 概述 本文章来源于本人在项目的实际应用中写下的记录.因初期在安装和使用Seajs和SPM的时候,有点不知所措的经历.为此,我 ...
- c语言学习基础:[1]开发工具介绍
标签:c语言 1 2 3 4 分步阅读 学习编程语言的童鞋们一开始接触到的最多的估计就是C语言了,其次才是什么java.c++等,可以说学习c语言是我们走向编程世界的一座桥梁,学好它,对于我们学习和研 ...
随机推荐
- python安装、卸载包的方法
anaconda包管理器 conda命令[1] 环境管理 conda info -e # 查看当前已安装的环境 conda create -n py27 python=2.7 # 添加2.7版本的Py ...
- excel替换函数substitute
1.substitute(需要执行替换操作的单元格区域,旧文本,新文本,第N个旧内容) 例:substitute(A1,"a","b",2) A1=aab ...
- C、C++、python、Java、php、C#六种编程语言大PK 哪个好学习?
作为程序员吃饭的工具,编程语言之间也形成了某种鄙视链,各大论坛里弥漫着剑拔弩张的气氛,众口难调.也难怪有很多初学者会有疑惑,为什么会有这么多编程语言,我到底应该学什么语言? 其实各种语言都各有千秋.接 ...
- 易车网实战+【保姆级】:Feapder爬虫框架入门教程
今天辰哥带大家来看看一个爬虫框架:Feapder,看完本文之后,别再说你不会Feapder了.本文辰哥将带你了解什么是Feapder?.如何去创建一个Feapder入门项目(实战:采集易车网轿车数据) ...
- 27、路由 route
优先于网卡中的配置,但是重启或重启网卡失效,最好加入到开机自启动服务中/etc/rc.local文件中: 27.1.添加网络路由: 目的网络.目的网络掩码,网关.网卡: 网络寻址以路由表中的路由优先: ...
- oracle :如何测试数据库安装是否成功
要测试数据安装是否成功,可按顺序执行以下两个步骤: 测试步骤 1: 请执行操作系统级的命令: tnsping orcl (如果出现[TNS-03505:无法解析名称]的提示错误: 那就改为tnspi ...
- Docker单机网络下
前言 Docker系列文章: 此篇是Docker系列的第七篇,大家一定要按照我做的Demo都手敲一遍,印象会更加深刻的,加油! 为什么要学习Docker Docker基本概念 Docker镜像基本原理 ...
- Leetcode No.35 Search Insert Position(c++实现)
1. 题目 1.1 英文题目 Given a sorted array of distinct integers and a target value, return the index if the ...
- Java | Random 和 Math 的概述及使用
Random Random类是java.util的包里面提供的我们常用的API,方便我们操作的,还有非常多像Random一样的类. Random的作用 生成一个随机数字,可以指定范围,也可以真的随机. ...
- python import 导入两个模块同时有同一名称的方法如何调用 ?
from moudule import *(这种方法不推荐) 一般不推荐使用"from 模块 import"这种语法导入指定模块内的所有成员,因为它存在潜在的风险. 比如同时导入 ...