转载:给大型机插上翅膀,IBM Z/os 研发团队 DevOps 转型实践

2024-04-09 09:38

本文主要是介绍转载:给大型机插上翅膀,IBM Z/os 研发团队 DevOps 转型实践,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

给大型机插上翅膀,IBM Z/os 研发团队 DevOps 转型实践

2018-07-09 19:48IBM/开发/技术

摘要

企业:IBM 大型机 Z/os 研发团队

企业规模:200 名工程师

面临的问题:各个开发工具之间相对独立,没有统一工作流程,导致交付周期长、学习成本高

转型结果:建立了 DevOps 型流水线,通过 4 个月的研发,把所有 17 个开发工具集成到统一平台,将版本发布周期从 18 个月缩短到了 1 个月。

导读

但见新人笑,哪闻旧人哭,杜甫的诗句很好的诠释了现在 IT 和互联网行业对待技术的态度,区块链、AI、大数据、AR/VR 等新技术层出不穷,每个人都在追逐 The Next Thing。在这个被摩尔定律决定的行业,平均每 18 个月就能让计算能力翻倍,让技术井喷。但是过快的发展速度一定程度上也给新的技术带了不稳定性,就像 Gerald Weinberg 说的那样:

If builders built houses the way programmers built programs, the first woodpecker to come along would destroy civilization.

在这个即使 2,3 年前的技术也会被认为已经没希望的时代,仍然有很多 50,60 年前的技术活跃在前沿行业中。就像七八十年代科幻电影中的那样,笨重的主机、绿色的屏幕、靠软盘驱动,这些在那个年代帮助人类登上月球的科技被统称为 “Legacy System”。根据 Andreas Hein 的研究,这类 Legacy System 至今仍然在 NASA 被广泛使用着。

这次带来的案例就是 “Legacy System” 的缔造者,IBM 的大型机研发部门,作为地球上资历最老的研发团队之一是如何拥抱新的研发管理方式,进行 DevOps 转型的。

本次案例整理自 IBM 资深大型机工程师 Rosalind Radcliffe 在 2017 DevOps Enterprise Summit 的分享。讲述像 IBM 大型机 Z/os 研发团队这样传统的开发团队也可以向敏捷转型。

Enjoy!

设立目标

当 Radcliffe 和她的团队开始准备向 DevOps 转型的时候,发现主要问题在于现阶段的整个发布周期太长,整套 Z/os 的开发工具太多并且都相互独立,但是整体研发团队的发布周期大概在 12~18 个月左右,整套开发工具中包含了 17 个独立的开发工具。这次转型就是希望能将这些独立的开发工具整合到一条固定发布的流水线上,来实现以下目标:

  1. 为使用这些大型机和大型机开发工具的内部团队和客户带来更多的价值。
  2. 降低使用者的学习成本。
  3. 让研发团队能更快更高效的进行功能迭代和版本发布。

Radcliffe 表示如果能打造一条将这些相对独立的开发工具整合到一起的 DevOps 流水线,能更好地释放团队潜力。将发布周期降到一个月以内,不仅仅能提高研发团队的效率,同时也能为使用大型机的客户带来更多的价值。

转型过程

转型的目标是要整合所有的开发工具到一条流水线上,但是现有的17 个开发工具都太过于分散,将其全部统一起来需要花费大量时间。为了能搭建一个通用的 IDE 和环境,Radcliffe 和她的团队采取了一个大胆的举措——暂停整个研发进度。

“除了客户出的紧急情况以外,整个团队把全部的精力都放在了这条流水线的搭建上。”

因为从最开始就决定要循序渐进,所以整个团队从 IBM 大型机研发中最基本的 Z/os Explorer 和 CICS (IBM 公司的主机交易服务器、整合平台)工具开始着手,然后再按顺序加上其他开发工具。这样所有大型机相关,并以 Eclipse IDE 为基础的开发工具就可以很快地部署到这条流水线上来。

在做这段开发的过程中,值得提及的是这不仅仅是统一以 Eclipse IDE 为基础的开发工具,更关键的是为了达成这个目标而付出的后端的努力;这不仅仅是 Java 语言的开发,而是 IBM 大型机开发中所使用的传统 PLX 开发模式。这是基于汇编语言的 DevOps 流水线实践,之后将没有独立的开发工具,所有的开发工具都集成到了一个工具链中。现在整个团队只有一个 SEM,不管团队是在为内部系统还是为客户进行开发,所有的代码都在一个仓库里,每个人都能清晰的了解其他人的项目和工作进度。

Radcliffe 和她的团队总共花了 4 个月的时间完成整个转型。

转型结果

  • 为了将所有开发工具整合,17 个产品总共进行了 94 次版本迭代。
  • Bug fixes 和小型功能的发布周期缩短到了一个月内。
  • 统一了代码仓库,所有的开发工具都集中在同一环境中。
  • 同时搭建持续部署,每晚自动对部署的功能进行测试,确保高效准确的交付。

反思

Radcliffe 和她的团队花了 4 个月进行 DevOps 转型,从中她总结了 3 点意见,供其他有兴趣进行转型的企业参考。

  1. 必须给予研发团队足够的时间。研发负责人如果想采取 DevOps 的转型就必须花时间给团队做足够的讲解和训练,确保每个人都知道他们需要做什么和为什么要这么做,同时要做好前期工作效率下降的准备,尤其是对一些仍然使用传统研发方式的团队来说更是如此。就像我们的 CICS 项目团队,花了一段时间才从老式的开发工具迁移到以 Eclipse 为内核的开发工具。所以在这个过程中需要给予团队足够的时间去学习适应,毕竟罗马不是一天建成的。
  2. 保证跨部门沟通渠道的通畅。我们使用各类 Slack 的频道来进行跨部门沟通,让大家可以实时了解各个项目的进度,可以互相请教和分享关键信息。
  3. 管理层必须给予必要的支持。想象一下当整个研发团队在接下来的四个月里都不会进行新功能的交付,会给销售或市场部门带来怎样的波澜。作为管理层,必须要能认识到 DevOps 转型的必要性,相信转型能激发研发团队的潜力,为企业带来更高效的交付和更大的价值,这样才能给你的研发团队足够的支持。

结尾

这个案例向我们展示了,即使是像 IBM 的大型机研发团队这样的 “Legacy System” 项目,只要有足够的支持和决心也可以进行 DevOps 转型,为企业带来更多的价值。

Reference

1.https://www.youtube.com/watch?v=ALTmXm9eWGE&feature=youtu.be&t=13m1

---------------------------------------------------------

ZL 文章来源:http://www.sohu.com/a/240189740_205771

这篇关于转载:给大型机插上翅膀,IBM Z/os 研发团队 DevOps 转型实践的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/887807

相关文章

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

springboot集成Deepseek4j的项目实践

《springboot集成Deepseek4j的项目实践》本文主要介绍了springboot集成Deepseek4j的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录Deepseek4j快速开始Maven 依js赖基础配置基础使用示例1. 流式返回示例2. 进阶

Android App安装列表获取方法(实践方案)

《AndroidApp安装列表获取方法(实践方案)》文章介绍了Android11及以上版本获取应用列表的方案调整,包括权限配置、白名单配置和action配置三种方式,并提供了相应的Java和Kotl... 目录前言实现方案         方案概述一、 androidManifest 三种配置方式

Spring Boot中定时任务Cron表达式的终极指南最佳实践记录

《SpringBoot中定时任务Cron表达式的终极指南最佳实践记录》本文详细介绍了SpringBoot中定时任务的实现方法,特别是Cron表达式的使用技巧和高级用法,从基础语法到复杂场景,从快速启... 目录一、Cron表达式基础1.1 Cron表达式结构1.2 核心语法规则二、Spring Boot中定

Ubuntu中Nginx虚拟主机设置的项目实践

《Ubuntu中Nginx虚拟主机设置的项目实践》通过配置虚拟主机,可以在同一台服务器上运行多个独立的网站,本文主要介绍了Ubuntu中Nginx虚拟主机设置的项目实践,具有一定的参考价值,感兴趣的可... 目录简介安装 Nginx创建虚拟主机1. 创建网站目录2. 创建默认索引文件3. 配置 Nginx4

Nginx实现高并发的项目实践

《Nginx实现高并发的项目实践》本文主要介绍了Nginx实现高并发的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录使用最新稳定版本的Nginx合理配置工作进程(workers)配置工作进程连接数(worker_co

Spring Retry 实现乐观锁重试实践记录

《SpringRetry实现乐观锁重试实践记录》本文介绍了在秒杀商品SKU表中使用乐观锁和MybatisPlus配置乐观锁的方法,并分析了测试环境和生产环境的隔离级别对乐观锁的影响,通过简单验证,... 目录一、场景分析 二、简单验证 2.1、可重复读 2.2、读已提交 三、最佳实践 3.1、配置重试模板