一、DevOps的理解

DevOps的概念理解

DevOps 的概念在软件开发行业中逐渐流行起来。越来越多的团队希望实现产品的敏捷开发,DevOps 使一切成为可能。有了 DevOps ,团队可以定期发布代码、自动化部署、并将持续集成 / 持续交付作为发布过程的一部分。
一句话概括就是提高生产力,快速交付!

二、引入DevOps的背景

2.1 福禄技术栈介绍

  • 后端开发框架:基于C#的.netCore和Java的SpringCloud,少部分项目采用python和go开发

  • 前端开发框架:vue、react

  • 服务部署:前端站点基于ECS的nginx部署 ,后端服务统一部署在kubernetes上

  • 代码仓库:gitlab

  • 项目环境:目前有6套,开发、测试、压测、集成、PRE和生产

2.2 后端服务的CICD现状

福禄后端CICD流程

CICD 流程说明

每一次的代码push,根据创建的分支,根据在gitlab的CICD文件gitlab.yml定义构建步骤,触发runner,从单元测试、通过dockerfile进行编译和生成镜像版本、将新镜像部署到K8S生成pod,然后触发接口自动化测试任务的执行

好像缺了点什么?

  • 初次部署应用到kubernetes怎么做的?

  • 服务的configmap在哪里维护的?

  • 每个服务的gitlab.yml文件都不一样,如何维护的?

  • 应用的域名解析怎么做?

目前有6套环境进行管理,其中开发、测试、集成、压测都是测试人员维护,预发布和生产运维人员维护;这也就要求每一个测试人员都必须对整个cicd流程和配置绝对掌握;所以当新人入职,需要掌握整个流程才能进入项目测试中,这是一个学习成本;

预发布和生产的kubernetes只有运维能够操作,当有新的服务需要上线上述环境,或者configmap有变动,或者有时候排查问题需要查看容器日志,我们只能通过运维的工单系统描述作业操作,中间文字描述可能存在理解差异,沟通成本和时间成本很大;

有的新应用我们去设置cicd的相关文件,比如dockerfile,我们发现应用的代码目录结构各种各样,这样往往就没法套用一个模板快速配置完成

2.3 前端站点的CICD现状

前端CICD流程说明

开发人员push代码到gitlab,测试人员通过jenkins拉取最新的代码到jenkins本地,然后通过jenkins与服务器之间的传输管道,将要部署的文件更新到目标服务器,并触发UI自动化的job

完整的过程来看,也缺点内容

  • 一个新的站点部署,nginx需要做一些配置初始化工作,比如域名、路径的配置
  • 前端的配置文件是如何管理的

跟后端应用一样,前端的PRE和生产环境也是运维处理,所以当一个新的应用上线我们也需要发工单,描述具体操作,然后运维执行工单;配置文件一般不会变更,所以我们在jenkins推送更新文件到目标服务器的时候,将配置文件做了过滤处理。后续需要变更通过工单执行

2.3 痛点你看到了吗

2.3.1 安全管控缺位
  • 代码安全:CICD的起点在gitlab里面,所以大家都有gitlab的账号,代码安全管控缺位
  • 线上安全:线上项目部署也是通过gitlab的cicd直接触发,审批流程缺失
2.3.2 管理成本
  • 维护账号多:gitlab账号、jenkins账号、kubernetes账号(本地和阿里云),每一个人员都需要上述账号,运维管理麻烦,大家每个平台维护自己的账号也麻烦
  • 工单沟通:工单编写、沟通过程花费时间较多
  • 代码规范:项目组多,微服务也多,代码框架各自发挥,无论是流程维护还是问题排查都增加了难度

三、研发管理平台(RDMS)应运而生

3.1 如何理解这个平台

工具链到平台的转变

当前的cicd是对工具链进行了打通,但需要大家登录各个工具平台操作,我们希望对工具集进行功能整合,打造一个系统平台,并且将CICD的技术细节进行屏蔽,开发人员能够专心进行业务需求的开发,测试人员能够专注到需求测试任务中,而运维人员能够解放繁重的工单内容,投入到服务高可用的建设上!

3.2 业务功能设计

福禄研发管理平台功能结构图

3.2.1 功能说明
  • 项目管理:项目的创建和维护,默认提供了.netcore的api和控制台,java的api和前端站点的应用初始化代码框架,开发人员开发新的应用直接根据应用类型选择对应的模板就可以在git默认创建代码仓库和初始化框架代码,并自动生成应用的http和https的域名
  • 构建记录:获取gitlab的pipeline,展示所有分支的构建记录信息,可以一键跳转到git仓库
  • 部署管理:部署构建的镜像到指定的环境,提供实时部署和定时部署功能
  • 容器管理:提供容器的查看功能,可以看到容器的存活状态和容器实时日志
  • 配置字段权限申请:针对PRE和生产环境查看配置,需要先走钉钉审批申请流程
  • 配置信息:进行配置的维护,包括新增、编辑、删除,PRE和生产环境操作需要钉钉流程审批
  • 操作日志:针对应用的操作日志记录
  • 用户设置:在使用rdms前,需要先将用户git仓库的token设置在rdms上,这样用户在rdms操作与gitlab相关的业务才能正常使用
3.2.2 RDMS几个核心页面的展示

首页-创建应用

构建记录

部署管理

容器管理

3.3 技术架构

对接系统的说明

  • 通行证:RDMS的目标用户是研发中心人员,这些人员在通行证中都有默认的账户信息,与通行证打通,可以直接登录使用
  • GitlabAPI:目前RDMS的CI还是采用的gitlab的ci支撑,包括新应用在rdms的创建到git仓库的代码初始化等,都需要调用gitlab的api接口
  • 钉钉flow:安全管控的原因,PRE和生产的任何操作都会触发钉钉审批流,所属项目的项目经理审批通过后才会获取到数据或者执行操作指令
  • 福禄开放平台:提供了网关相关的功能和菜单、角色等维护功能,公司所有后端服务都需要入驻开放平台
  • 蜂巢:公司的调度作业平台,rdms的定时部署功能依赖该服务的支撑
  • 运维工单系统:rdms的CD流程没有直接与kubernets进行交互,而是通过运维的工单系统包装了运维底层的shell脚本层,然后提供给rdms相关的api接口,也是基于安全控制的考虑
  • shell脚本层:shell脚本层会调用kubernetes的api进行kubernetes的相关操作(部署、配置更新、容器重启、日志查看等);调用阿里云的dns解析接口,对应用的域名自动解析;调用oss的接口,进行前端站点文件目录的维护

3.4 后端应用的devops实现详解

举个栗子进行介绍

根据模板,创建一个应用

根据名称默认生成域名

初始化代码仓库,默认生成develop分支

在rdms第一次部署到对应环境(开发、测试、生产等)时,会默认读取appsettings.Development.json的文件,并写入kubernets的configmap

构建完成,进行部署

在kubernets生成pod

通过域名访问接口文档

3.5 前端站点的devops实现详解

同样的,举个栗子介绍

首页-创建前端站点

根据名称生成域名

初始化代码仓库,默认生成develop分支

配置文件,默认生成几套环境的配置文件,站点的配置维护就是维护这几个文件

部署应用

kubernetes的nginx容器内可以看到部署的文件,实际就是挂载的oss到该pod上

四、展望

目前RDMS投产一个月左右,我们希望能将devops理念在这个系统上进行持续的优化和实践,包括研发中心小伙伴也很踊跃参与共建,提出了很多好的方向和建议

  • 完善devops链条功能:通过字面来看有dev、ops两部分,我们后期需要加入test的比重,比如在CI部分,引入静态代码扫描、单测覆盖率;在CD部分集成我们的自动化测、性能测试
  • 工具平台:RDMS的初衷是整合,针对研发中心经常使用的工具或者有相关工具化的需求,我们可以整合到rdms或者在RDMS上进行开发
福禄ICH·质量保证部 福小龙

我们是如何实现DevOps的相关推荐

  1. 容器云原生DevOps学习笔记——第三期:从零搭建CI/CD系统标准化交付流程

    暑期实习期间,所在的技术中台-效能研发团队规划设计并结合公司开源协同实现符合DevOps理念的研发工具平台,实现研发过程自动化.标准化: 实习期间对DevOps的理解一直懵懵懂懂,最近观看了阿里专家带 ...

  2. 容器云原生DevOps学习笔记——第二期:如何快速高质量的应用容器化迁移

    暑期实习期间,所在的技术中台-效能研发团队规划设计并结合公司开源协同实现符合DevOps理念的研发工具平台,实现研发过程自动化.标准化: 实习期间对DevOps的理解一直懵懵懂懂,最近观看了阿里专家带 ...

  3. [DevOps] 认识一下

    大家都在说DevOps(Develop Operation),大概知道就是开发和运维沟通交流,一条线,然后使产品能够顺利的.短时间内上线.维稳什么的. 今天特意看了下 DockOne里面的一篇文章,再 ...

  4. 一键部署dns服务_OpenShift : 通往云原生、DevOps、微服务和Serverless的大门

    新书速递 查尔斯·狄更斯的<双城记>中有句耳熟能详的名言:"这是一个最好的时代,也是一个最坏的时代."作为技术从业者,在这个数字化浪潮和技术变革接连发生的时代,我对这句 ...

  5. git review devops过程

    自己搭建的devops环境是gitlab/gerrit/jenkins 1. 首先自己checkout一个自己的代码分支,一般不要在master上做直接修改 2. 修改后git add file,   ...

  6. #QCon# Devops

    今天参加了QCon2011 杭州.听了百度项目管理部的乔梁关于"Devops"的分享.比如如下: continuous integration -- Dev , QA agile ...

  7. 最佳DevOps工具获奖者:CloudBees Jenkins平台

    最新一期<IT新架构>宣布了第三届影响力奖的最终结果.这些获奖的产品和技术由我们读者.行业专家和编辑人员参与投票评选,并且预计将对2016年的IT运营产生显著影响.首先向所有的获胜者表示祝 ...

  8. 我眼中的DevOps(转)

    过去一年以来,一批来自欧美的.不墨守陈规的系统管理员和开发人员一直在谈论一个新概念:DevOps.DevOps 就是开发(Development)和运维(Operations)这两个领域的合并.(如果 ...

  9. DevOps:怎么实现源代码注释和系统文档的自动化更新?

    [编者按]计算机软件传统定义为:软件是计算机系统中与硬件相依存的另一部分,软件包括程序.数据及其相关文档的完整集合.然而在时下的开发中,文档的合规性往往被忽视的干干净净.本文由 Todd Waits ...

  10. [译]一个系统管理员眼中的DevOps

    前言 原文发表在Patrick Debois大神的官网上,传送门>> 通篇围绕运维工作进行阐述,始终是在强调运维人员和开发人员需要通力协作,这大概也是DevOps理念的核心价值所在吧!大概 ...

最新文章

  1. 所有java程序都有线程_若所有的用户线程都终止了,Java程序就会结束。( )_学小易找答案...
  2. Flask == scoped_session
  3. noip模拟赛 abcd
  4. 自动性能统计信息(三)(Automatic Performance Statistics)
  5. 我们并没有觉得MapReduce速度慢,直到Spark出现
  6. LeetCode 1025. 除数博弈(动态规划)
  7. 【NOI2022】PV「什么是信息学精神?」
  8. React Native图片缓存解决方案
  9. python中唯一的映射类型是什么_Python基础类型之字典(dict)
  10. html自定义表格插件,简单实用的jQuery响应式表格插件
  11. NPC问题及其解决方法
  12. h264js解码直播解码显示
  13. oracle进行列合并,oracle列合并的实现方法
  14. 四、RocketMQ的控制台安装
  15. js实现进入页面后自动跳转到锚点
  16. 破解加密文档以及宏口令
  17. Android之多个View同时动画
  18. 第四类互联网交互模式──威客模式
  19. 精品绿色便携软件下载站
  20. 襄阳职业技术学院计算机专业宿舍,襄阳职业技术学院宿舍条件怎么样—宿舍图片内景...

热门文章

  1. 雅迪在瑞士和拉丁美洲开设旗舰店;起亚发布全新Logo和品牌口号;戴姆勒与印孚瑟斯达成战略合作 | 美通企业周刊...
  2. win7显示方向旋转快捷键禁用及图形属性打开方法
  3. 面对面翻译小程序是微信团队针对面对面沟通的场景开发的流式语音翻译小程序,通过微信同声传译插件提供了语音识别,文本翻译等功能。
  4. 微信小程序中的用户ID(openid和unionid)
  5. 用复利模型创造自己的睡后收入
  6. SSM整合之Mybatis笔记( MyBatis获取参数值的两种方式(重要))(P020—P025)
  7. 如何构建大数据层级体系,看这一文章就够了
  8. php语音提示_微信收付款怎么设置语音播报
  9. 那个爆火的“梦中修炼”AI,你也能用Keras搭一个了
  10. 手把手教截图识别文字