请选择 进入手机版 | 继续访问电脑版

IT运维管理,ITIL,ITSS,ITSM,ISO20000-ITIL先锋论坛

 找回密码
 微信、QQ、手机号一键注册

扫描二维码登录本站

QQ登录

只需一步,快速开始

艾拓先锋
搜索
查看: 463|回复: 0

你遇到过几个DevOps的挑战?

[复制链接]
来自- 广东广州

参加活动:0

组织活动:12

发表于 2017-8-24 15:09:44 | 显示全部楼层 |阅读模式 来自- 广东广州
DevOps的主要目标很简单即:频繁、可靠地发布软件更新,并提高质量,这个目标有点“十全十美”,每个企业都会赞同这个目标,很多人回告诉你,他们已经通过遵循一些常用的框架如:CALMS开始了DevOps的道路。
& a6 R% r, i& X- V4 A2 u0 ?
+ W" h" H) W: N: \% ^( u3 ^
然而,很少人会对DevOps模式的结果表示满意,我们访问了使用生命周期的不同阶段的200多名DevOps专业人员,发现企业通常属于三大类:

/ U+ g9 Q. I( t$ H/ u
4 Q6 Z% y7 B# Q6 X4 p
1.png
最让人感兴趣的是第二和第三组,因为他们实际上已经开始实践DevOps模式,当被问及如何更好地解释这些挑战和障碍时,以下是我们的发现:

3 {; J( R) p, n! P3 g- N7 w3 C( e1 a' p( `
  • 68%的人说,在工具链中,不同的DevOps工具之间的关联性让人十分苦恼。" [/ Y5 D. L% {" u
  • 52%的人说,大部分测试仍然以手动模式进行,速度反而降低。
  • 38%的人混合了传统和现代的应用,比如Brownfield Environments,因此在部署策略和端点,工具链方面提高了复杂性。
  • 27%的人仍苦苦挣扎于“Silo'ed”团队,无法按照预期进行合作。
  • 23的人对自助服务基础设施的访问有限。

    . M+ y- {' K: ~% ?1 S' |9 ^
其他值得注意的痛点包括:DevOps相关技能,难以管理复杂多样的服务和环境,缺乏紧迫性和预算,领导层的支持。

% E% h2 t1 a  h  ~1 Y- ^
接下来详细地了解这些挑战:
5 f2 u3 K: }7 `8 M3 e- c
挑战1:DevOps的工具链缺少关联性
2 X, j/ A9 A$ d/ y
许多DevOps工具可以一些任务自动化,如CI、基础设施配置、测试、部署、配置管理、发布管理等,当企业开始采用DevOps,这些工具的帮助非常大,但它们尝尝不能很好地协同工作。
% j8 C" B4 u, L; Z! e. K
2.png
, O2 e6 u# R7 d% {( v2 @
作为经典的例子之一,我们采访了一家公司的熟悉DevOps工程师,他的团队使用Capistrano进行部署,当被问及如何发现一个新的应用版本或配置变化时,他表示,测试和运维团队打开了JIRA Tickets,包括Capistrano所需的信息,在运行这些脚本之前手动更新脚本,这一过程花了几个小时,需要小心得管理,因为所需的配置需要两次手动传输,第一次是在JIRA中,第二次是将其复制到Capistrano时。
2 _2 D+ v+ `0 O2 h8 H
虽然这是一个简单的例子,但这个问题存在于整个工具联众,在工具中执行依赖任务所需的状态和其他信息处理地非常糟糕。

3 P2 V" E3 l8 W$ ?. N5 p
较小的企业通过编写自定义脚本将这些工具链粘合在一起解决问题,这对一些应用来说是可行的,但很快就会出现严重问题,因为这些脚本不是以标准方式编写的,会很难维护、常常包含令牌、密钥和其他敏感信息,更糟糕的是,这些脚本对于每个应用都是高度定制的,并且无法重用,方便地伸缩自动化工作流。

8 f, F( {( P: L7 v$ F1 J0 A. z
而当DevOps工具链中的工具无法协作,需要通过手动或自定义脚本管理依赖项时,持续交付也就无法实现。
$ d1 r$ m2 I# w$ b/ a, g# F/ F
挑战2:缺乏测试自动化
: S4 ~3 E* G  ~! j  v
尽管所有的焦点都集中在TDD上,但多数的企业仍然在为自动化测试而努力,如果是人肉测试,那么几乎不可能为每个提交执行整个测试套件,这会成为持续交付的障碍,团队试图通过对每个提交运行一组核心测试来优化这一点,并且对整个测试套件进行周期性的运行,这意味着大多数BUG都在软件交付工作流程中被发现,并且会消耗大量的成本。

& }, ^: L* \1 ~3 Q
3.png
: c; k  D3 K2 m: ~  H) x
测试自动化是DevOps采用过程的一个重要部分,因此需要成为一个优先级。

2 h0 W) l. P9 s4 s* A, z9 `4 V$ m- p$ f1 X) d/ Q+ b
挑战 3:Brownfield Environments
+ V  x' ?3 v9 Y1 C
典型的IT组合在本质上是异构的,横跨数十年的技术、云平台供应商、实验室和数据中心、公有云和私有云,所有的这些都在同一时间节点,创建狂月这方面的工作流非常困难,因为大多数工具都与特定的体系结构和技术一起工作,导致了工具链的蔓延,因为每个团队都会使用工具链去满足需求。
, s' `5 f* z; a
Docker的兴起也鼓励了许多企业开发基于微服务的应用,这增加了DevOps自动化的复杂性,因为应用现在需要为异构的微服务提供100个部署通道,微服务还会带来动态的应用生命周期,每个微服务都是独立部署的具有独立性,因此跨团队的调度和协调需要指数级增长。
7 w! I9 H' y" [1 ~; X; B3 ~
挑战4:文化问题
* s: m  [2 f1 s  w3 T$ G. v0 a
应用在功能的驱动中发展,开发者开发应用,有测试去检验,然后由运维部署和管理,尽管所有的团队都希望进行写作,但其之间往往是有冲突的。

" R0 t6 p0 E; ]1 }1 V" w
开发者被要求尽快的开发新的应用,测试和发布管理团队被逼得尽可能彻底地确保应用没有BUG,这两个团队经常被SecOps和基础设施部门管控,确保生产不会中断,治理和遵从性也降低了速度,这导致了一种反变革的文化,因为变革会带来风险和不稳定性因素,因此需要更多的资源和预算来管
跨团队的协作。
! F+ @5 Q8 P2 ^* V' t' p
跨团队的协作往往会出现一些问题,从而减缓应用更改的流程。
! e6 X* Q( @' U0 K2 g; ^/ b* y. o
一些企业试图通过让开发人员去构建、测试、和运维应用来解决这个问题,尽管这可能在理论上行得通,但开发却因没有时间去生产陷入困境,而且大部分的时间都在运营上个月所做的事情上,无法进行创新,很多企业试图让所有的团队都参与到SDLC的各个阶段,但这种方法仍然依赖于手工协作。

# p9 D. a6 X% e2 j- N
自动化是团队间协作的最佳实践,但是正如在其他挑战中所见,自动化本身也会降低速度,并引入风险和BUG。
/ N* h8 `9 z( d
挑战5:有限的自助服务基础设施和环境访问
1 J% L5 F, d9 X7 ~# ?0 q. W
虚拟机和云计算已经改变了获取正确基础设施的过程,之前几个月时间的任务现在几分钟即可完成,如AWS这样的IaaS提供商拥有数百提灵活配置的机器,以及预装操作系统和其他工具供以选择如:Ansible、 Chef、Puppet,可以帮助代表基础设施代码,这进一步加速了机器的供应和重新配置。
1 U% u* h0 D( W$ j$ h# A/ q
然而在许多企业中,获取基础设施仍然是一个问题,特别是哪些运行自己数据中心或尚未接受云计算的企业。
  l  ]. T6 |0 C1 ~% W6 I
DevOps作为一个新兴的概念,寓意着未来的发展趋势的同时,本身也有诸多挑战,但我们不能否认,如果在以后逐步克服了这些挑战与困难,将会产生巨大的收益。

- Z, B, a& P8 J) \: a( g! o

9 J- m* `/ R7 M- I来自:SRE与运维
; E& D0 k, z# }% n- I4 |' j# _9 A5 X0 v2 d# s* _7 ~+ }  y( _' U9 P+ Z

本版积分规则

选择云运维时代的王牌讲师-长河老师,助你轻松入门ITIL Foundation培训课程

QQ|小黑屋|手机版|Archiver|艾拓先锋网 ( 粤ICP备11099876号-1|网站地图

Baidu

GMT+8, 2018-10-17 01:01 , Processed in 0.253460 second(s), 31 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表