searchusermenu
  • 发布文章
  • 消息中心
点赞
收藏
评论
分享
原创

初识DevOps

2022-12-28 08:16:20
77
0

基本概念和延伸的思考

DevOps,是Development(开发)和Operations(运维)组成的复合词,一般译为“开发运维一体化”。

(图片来自网络)

看到这个概念,首先会产生几个问题:

开发是什么,哪些环节是开发?

运维是什么,哪些环节是运维?

开发人员写好代码在本地调试,环境出问题了自己来调整,这是开发工作还是运维工作?

系统故障后,运维人员发现是配置文件内容出错了就改成了正确的信息,这是运维还是开发工作?

这些问题不正是说明本身开发和运维本来就是一体的吗,为何还要进行开发运维一体化?

 

每个切身参与到开发和运维的员工,日常工作一定经常遇到各种界限不清晰的问题。面对这类问题,应对策略和解决方法,大致分为如下两个方向:

  • 从管理角度,制定工作环节和流程的规章制度,规范人员行为,确保开发和运维环节的衔接。
  • 从技术研发角度,研究开发过程的管理工具,减少人工的环节,从而减少问题出现的机会。

敏捷管理

管理角度上,从瀑布式开发到敏捷开发,人们一直在面对的是软件不断发生变更的需求场景,从而被动衍生出来一套应对频繁变化,快速迭代的管理模式。

 

传统的瀑布开发流程是:

  • 需求人员收集客户需求;
  • 进行需求分析,输出需求规格说明书;
  • 召集开发部门宣讲需求,开发人员开始编写代码;
  • 写好代码以后,进行后续的代码构建、测试环境部署;
  • 经过测试部门测试,通过后交给实施部门;
  • 实施部门进行生产环境部署。

在瀑布模式和敏捷开发共同出现的语境中,人们经常认为瀑布模式是一种过时的技术,缺点很多的技术。而通过上述的流程可以看出,瀑布模式清晰的定义出了各个环节的职责范围,保障软件开发工作无偏差、高质量的完成。

而敏捷开发出现不是为了颠覆瀑布模式,而是弥补瀑布模式周期较长不够灵活这一缺点。

(图片来自网络)

敏捷开发平没有抛弃瀑布开发的工作环节,而是在经常发生变更的场景下,进行灵活的工作调整,来实现在变化中迭代的效果。

丰富的工具

技术角度上,开发过程的各个环节,都已经诞生出多种适用于各种不同场景的工具。有开源、有商用,供各类不同的用户选择。

(图片来自网络)

一些常见的技术:

版本控制&协作开发:GitHub、GitLab、BitBucket、SubVersion、Coding、Bazaar
自动化构建和测试:Apache Ant、Maven 、Selenium、PyUnit、QUnit、JMeter、Gradle、PHPUnit
持续集成&交付:Jenkins、Capistrano、BuildBot、Fabric、Tinderbox、Travis CI、flow.ci Continuum、LuntBuild、CruiseControl、Integrity、Gump、Go
容器平台:Docker、Rocket、Ubuntu(LXC)、第三方厂商如(AWS/天翼云)
配置管理:Chef、Puppet、CFengine、Bash、Rudder、Powershell、RunDeck、Saltstack、Ansible
微服务平台:OpenShift、Cloud Foundry、Kubernetes、Mesosphere
服务开通:Puppet、Docker Swarm、Vagrant、Powershell、OpenStack Heat
日志管理:Logstash、CollectD、StatsD
监控,警告&分析:Prometheus、Nagios、Ganglia、Sensu、zabbix、ICINGA、Graphite、Kibana

 

可以看到工具不仅仅局限在开发环节,构建、测试、部署、运维工具也均发展出了优秀的软件和技术。

 

优秀的开发管理模式和成熟的技术的相融合,形成了今天我们看到的DevOps模式。

实践DevOps的原则

那么现在技术已经具备了,优秀的开发管理模式也具备了。如何结合两者,形成一个借助工具来快速、自动化的完成整个开发生命周期的模式呢?

答案就是DevOps。

 

但需要注意的是,DevOps并非一套通用方法来做技术和流程的结合。而是技术和流程结合这一实践过程中,不断调整、探索,最终达到一个适合自己的模式。

 

每个开发者或者企业都有个性的工作和管理模式。没有一个标准的方案能够适用于每个企业,企业在践行DevOps时应该充分考虑这样一些原则:


1、基础设施即代码(Infrastructure as Code)

DeveOps的基础是将重复的事情使用自动化脚本或软件来实现,例如Docker(容器化)、Jenkins(持续集成)、Puppet(基础架构构建)、Vagrant(虚拟化平台)等。

 

2、持续交付(Continuous Delivery)

持续交付是在生产环境发布可靠的软件并交付给用户使用。而持续部署则不一定交付给用户使用。涉及到2个时间,TTR(Time to Repair)修复时间,TTM(Time To Marketing)产品上线时间。要做到高效交付可靠的软件,需要尽可能的减少这2个时间。部署可以有多种方式,比如蓝绿部署、金丝雀部署等。

 

3、协同工作(Culture of Collaboration)

开发者和运维人员必须定期进行密切的合作。开发应该把运维角色理解成软件的另一个用户群体。协作有几个的建议:1、自动化(减少不必要的协作);2、小范围(每次修改的内容不宜过多,减少发布的风险);3、统一信息集散地(如wiki,让双方能够共享信息);4、标准化协作工具(比如jenkins)。

高效便捷的DevOps体验----天翼云EasyCoding敏捷开发平台

阐述了这些概念之后,有没有快速实践DevOps的方法呢?

市面上目前已经出现大量成熟的DevOps平台供用户挑选了,很多平台都能够进行试用,让用户尝试DevOps,体验DevOps带来的进步。

 

天翼云EasyCoding敏捷开发平台就是这样一款产品,以产品价值在线化,交付价值自动化为设计理念,提供敏捷开发SaaS服务,助力大中型企业高价值、高质量、高效率发布产品,开启高效研发之旅。

 

天翼云EasyCoding平台具有这些优势:

  • 灵活的编排能力

可灵活编排的工作项界面、流程和规则,支持各种复杂的业务,可编排的流水线。

  • 灵活的扩展能力

支持应用、单据、属性、事件多级扩展机制,实现无代码或低代码的扩展

  • 完善的开放生态

可基于丰富的前端组件和后端API、易用的公共服务定制开发衍生应用

  • 快速稳定的响应

基于搜索引擎的读写分离,保障高并发、大数据量场景下稳定的性能

  • 前瞻性的管理思想

交易流程在线,业务活动在线,端到端全程可视跟踪业务活动

  • 稳定安全的研发环境

基于天翼云的接入安全、数据安全管理,多副本容灾架构设计

0条评论
0 / 1000
AlucardZ
3文章数
0粉丝数
AlucardZ
3 文章 | 0 粉丝
AlucardZ
3文章数
0粉丝数
AlucardZ
3 文章 | 0 粉丝
原创

初识DevOps

2022-12-28 08:16:20
77
0

基本概念和延伸的思考

DevOps,是Development(开发)和Operations(运维)组成的复合词,一般译为“开发运维一体化”。

(图片来自网络)

看到这个概念,首先会产生几个问题:

开发是什么,哪些环节是开发?

运维是什么,哪些环节是运维?

开发人员写好代码在本地调试,环境出问题了自己来调整,这是开发工作还是运维工作?

系统故障后,运维人员发现是配置文件内容出错了就改成了正确的信息,这是运维还是开发工作?

这些问题不正是说明本身开发和运维本来就是一体的吗,为何还要进行开发运维一体化?

 

每个切身参与到开发和运维的员工,日常工作一定经常遇到各种界限不清晰的问题。面对这类问题,应对策略和解决方法,大致分为如下两个方向:

  • 从管理角度,制定工作环节和流程的规章制度,规范人员行为,确保开发和运维环节的衔接。
  • 从技术研发角度,研究开发过程的管理工具,减少人工的环节,从而减少问题出现的机会。

敏捷管理

管理角度上,从瀑布式开发到敏捷开发,人们一直在面对的是软件不断发生变更的需求场景,从而被动衍生出来一套应对频繁变化,快速迭代的管理模式。

 

传统的瀑布开发流程是:

  • 需求人员收集客户需求;
  • 进行需求分析,输出需求规格说明书;
  • 召集开发部门宣讲需求,开发人员开始编写代码;
  • 写好代码以后,进行后续的代码构建、测试环境部署;
  • 经过测试部门测试,通过后交给实施部门;
  • 实施部门进行生产环境部署。

在瀑布模式和敏捷开发共同出现的语境中,人们经常认为瀑布模式是一种过时的技术,缺点很多的技术。而通过上述的流程可以看出,瀑布模式清晰的定义出了各个环节的职责范围,保障软件开发工作无偏差、高质量的完成。

而敏捷开发出现不是为了颠覆瀑布模式,而是弥补瀑布模式周期较长不够灵活这一缺点。

(图片来自网络)

敏捷开发平没有抛弃瀑布开发的工作环节,而是在经常发生变更的场景下,进行灵活的工作调整,来实现在变化中迭代的效果。

丰富的工具

技术角度上,开发过程的各个环节,都已经诞生出多种适用于各种不同场景的工具。有开源、有商用,供各类不同的用户选择。

(图片来自网络)

一些常见的技术:

版本控制&协作开发:GitHub、GitLab、BitBucket、SubVersion、Coding、Bazaar
自动化构建和测试:Apache Ant、Maven 、Selenium、PyUnit、QUnit、JMeter、Gradle、PHPUnit
持续集成&交付:Jenkins、Capistrano、BuildBot、Fabric、Tinderbox、Travis CI、flow.ci Continuum、LuntBuild、CruiseControl、Integrity、Gump、Go
容器平台:Docker、Rocket、Ubuntu(LXC)、第三方厂商如(AWS/天翼云)
配置管理:Chef、Puppet、CFengine、Bash、Rudder、Powershell、RunDeck、Saltstack、Ansible
微服务平台:OpenShift、Cloud Foundry、Kubernetes、Mesosphere
服务开通:Puppet、Docker Swarm、Vagrant、Powershell、OpenStack Heat
日志管理:Logstash、CollectD、StatsD
监控,警告&分析:Prometheus、Nagios、Ganglia、Sensu、zabbix、ICINGA、Graphite、Kibana

 

可以看到工具不仅仅局限在开发环节,构建、测试、部署、运维工具也均发展出了优秀的软件和技术。

 

优秀的开发管理模式和成熟的技术的相融合,形成了今天我们看到的DevOps模式。

实践DevOps的原则

那么现在技术已经具备了,优秀的开发管理模式也具备了。如何结合两者,形成一个借助工具来快速、自动化的完成整个开发生命周期的模式呢?

答案就是DevOps。

 

但需要注意的是,DevOps并非一套通用方法来做技术和流程的结合。而是技术和流程结合这一实践过程中,不断调整、探索,最终达到一个适合自己的模式。

 

每个开发者或者企业都有个性的工作和管理模式。没有一个标准的方案能够适用于每个企业,企业在践行DevOps时应该充分考虑这样一些原则:


1、基础设施即代码(Infrastructure as Code)

DeveOps的基础是将重复的事情使用自动化脚本或软件来实现,例如Docker(容器化)、Jenkins(持续集成)、Puppet(基础架构构建)、Vagrant(虚拟化平台)等。

 

2、持续交付(Continuous Delivery)

持续交付是在生产环境发布可靠的软件并交付给用户使用。而持续部署则不一定交付给用户使用。涉及到2个时间,TTR(Time to Repair)修复时间,TTM(Time To Marketing)产品上线时间。要做到高效交付可靠的软件,需要尽可能的减少这2个时间。部署可以有多种方式,比如蓝绿部署、金丝雀部署等。

 

3、协同工作(Culture of Collaboration)

开发者和运维人员必须定期进行密切的合作。开发应该把运维角色理解成软件的另一个用户群体。协作有几个的建议:1、自动化(减少不必要的协作);2、小范围(每次修改的内容不宜过多,减少发布的风险);3、统一信息集散地(如wiki,让双方能够共享信息);4、标准化协作工具(比如jenkins)。

高效便捷的DevOps体验----天翼云EasyCoding敏捷开发平台

阐述了这些概念之后,有没有快速实践DevOps的方法呢?

市面上目前已经出现大量成熟的DevOps平台供用户挑选了,很多平台都能够进行试用,让用户尝试DevOps,体验DevOps带来的进步。

 

天翼云EasyCoding敏捷开发平台就是这样一款产品,以产品价值在线化,交付价值自动化为设计理念,提供敏捷开发SaaS服务,助力大中型企业高价值、高质量、高效率发布产品,开启高效研发之旅。

 

天翼云EasyCoding平台具有这些优势:

  • 灵活的编排能力

可灵活编排的工作项界面、流程和规则,支持各种复杂的业务,可编排的流水线。

  • 灵活的扩展能力

支持应用、单据、属性、事件多级扩展机制,实现无代码或低代码的扩展

  • 完善的开放生态

可基于丰富的前端组件和后端API、易用的公共服务定制开发衍生应用

  • 快速稳定的响应

基于搜索引擎的读写分离,保障高并发、大数据量场景下稳定的性能

  • 前瞻性的管理思想

交易流程在线,业务活动在线,端到端全程可视跟踪业务活动

  • 稳定安全的研发环境

基于天翼云的接入安全、数据安全管理,多副本容灾架构设计

文章来自个人专栏
devops
2 文章 | 1 订阅
0条评论
0 / 1000
请输入你的评论
0
0