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语言是我们走向编程世界的一座桥梁,学好它,对于我们学习和研 ...
随机推荐
- 对标 Spring Boot & Cloud ,轻量框架 Solon 1.5.8 发布
Solon 是一个轻量的Java基础开发框架.强调,克制 + 简洁 + 开放的原则:力求,更小.更快.更自由的体验.支持:RPC.REST API.MVC.Job.Micro service.WebS ...
- SpringBoot系列(十五)整合缓存,项目会用得到的技术
一.缓存有什么用? 缓存应该是我们每一个系统都应该考虑使用的,这样可以加速系统的访问,提升系统的性能.比如我们经常需要访问的高频数据,将此类数据放在缓存中,可以大幅度提升系统的响应速度.原因就是一般 ...
- 07 修改JumpServer网页信息
1.7.修改JumpServer网页信息 注意:在修改相关配置文件之前要先进行备份,防止文件修改错误无法恢复. 1.Luna图标: /opt/luna/static/imgs/logo.png 2.j ...
- 利用ONT测序检测真核生物全基因组甲基化状态
摘要 甲基化在真核生物基因组序列中广泛存在,其中5mC最为普遍,在真核生物基因组中也有发现6mA.捕获基因组中的甲基化状态的常用技术是全基因组甲基化测序(WGBS)和简化甲基化测序(RRBS),而随着 ...
- XML:使用cxf调用WebService接口时报错:编码GBK的不可映射字符(设置UTF-8字符集)
调用代码如下 JaxWsDynamicClientFactory dcf = JaxWsDynamicClientFactory.newInstance(); Client client = dcf. ...
- jar打包
1.jar文件? 学过java的同学应该都听过吧!所以第一站是:打包发布 2.如何把 java 程序编译成 .exe 文件? 通常回答只有两种: 1)一种是制作一个可执行的 JAR 文件包,然后就可以 ...
- 『心善渊』Selenium3.0基础 — 29、使用HTMLTestRunner生成unittest的HTML报告
目录 1.HTMLTestRunner介绍 2.HTMLTestRunner的使用 3.测试报告示例 4.封装成模块 1.HTMLTestRunner介绍 HTMLTestRunner是一个基于uni ...
- C++ 标准模板库(STL)——算法(Algorithms)的用法及理解
C++ STL中的算法(Algorithms)作用于容器.它们提供了执行各种操作的方式,包括对容器内容执行初始化.排序.搜索和转换等操作.按照对容器内容的操作可将STL 中的算法大致分为四类: (1) ...
- 从0到1认识XHTML
XHTML概念 XHTML是一种可扩展超文本标记语言,与HTML(超文本标记语言)类似,不过在语法上更加严格.XHTML是以XML(是一种必须正确标记且格式良好的标记语言)应用方式定义的HTML,与h ...
- python爬取北京政府信件信息01
python爬取,找到目标地址,开始研究网页代码格式,于是就开始根据之前学的知识进行爬取,出师不利啊,一开始爬取就出现了个问题,这是之前是没有遇到过的,明明地址没问题,就是显示网页不存在,于是就在百度 ...