企业级 Jenkins 数据备份大法
Posted 前沿技墅
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了企业级 Jenkins 数据备份大法相关的知识,希望对你有一定的参考价值。
本文作者
景韵,Certified Jenkins Engineer,DevOps 时代联合发起人,高效运维社区核心成员,Certified DevOps Master,GOPS 全球运维大会优秀讲师。先后就职于用友、乐视,从事持续交付、DevOps 落地改进工作。曾主导用友集团DevOps 整体改进与持续交付平台建设;负责乐视EUI 持续集成方案改进。
雷涛, 百度工程效率部工具产品架构师,Certified Jenkins Engineer,Certified Scrum Master。先后就职于新浪、摩托罗拉、诺基亚、西门子、爱立信、乐视等国内外知名企业,专注于企业级软件工程效率提升、DevOps 解决方案、持续交付和软件配置管理等领域。
李华强,新乐视 SCM 组资深 DevOps架构师,Certified Jenkins Engineer,Jenkins Area Meetup 讲师。曾就职于飞维美地、爱立信、北电网络等多家外企,长期负责公司配置管理、持续集成等工作。
如何驱动持续交付与DevOps转型与落地?如何真正打破部门墙?如何实现端到端的服务交付?答案都是:用Jenkins!
相信大部分IT业者都应该听说过或者使用过Jenkins,研发工程师使用 Jenkins 执行编译打包,测试工程师使用 Jenkins 执行自动化测试,运维工程师使用Jenkins执行批量操作和自动化部署,Jenkins可谓是居家必备的神器。
Jenkins的前身Hudson诞生于2004年,由一名Sun公司的年轻工程师 Kohsuke Kawaguchi(KK)研发,一开始主要用于满足工程师本人的自动化需求,后来不断有开源爱好者贡献代码。2010年Oracle收购Sun后不久,Hudson和Sun公司其他著名开源软件Java、mysql等一样面临抉择。2011年初,社区投票决定基于Hudson创建新开源项目——Jenkins。 在社区努力下,Jenkins发展远超Hudson, 逐渐成为最流行的开源工具之一,可以说是开源赋予了Jenkins全新的生命力。
Jenkins从解决工程师的切身需求出发,跟随社区一起成长,逐步从自动化工具升级为持续集成引擎、持续交付核心工具、DevOps核心工具。KK目前对Jenkins的定位是:Jenkins is the Hub of CD/DevOps Ecosystem,即Jenkins是持续交付/DevOps生态的核心。
Jenkins Core 提供了一个平台,借助Jenkins开源社区的力量,以插件的方式实现了一个持续交付与DevOps的生态系统。尤其是2.0后,Jenkins提供了对Pipeline的原生支持,而Pipeline又是持续交付的核心实践。Pipeline可帮助团队打通从代码提交到发布上线的端到端的交付过程,整合多角色(研发、测试、运维、安全等)职能、实践与工具集合,再配合BlueOcean的Pipeline可视化查看和编辑功能,能够让持续交付流水线设计变得更加容易实现。结合Jenkinsfile的使用,将流水线的编排以文件的方式采用版本控制系统管理起来,能够轻松实现Pipeline as Code。
第十八计 Jenkins文件数据备份和恢复验证要常做,备份Archive要谨慎
Jenkins 应用是基于文件系统的,所有的配置和数据都存储在文件系统上。因此Jenkins Home目录的数据备份和恢复方案是Jenkins运维保障必须要有的。
首先,要理解Jenkins Home 下文件结构的含义,这样才能有效甄别出需要备份的有效数据。
其次,要选择适合的备份方案,可以使用一种或者多种结合的方式,确保有效数据得到备份。常用的备份方案主要有三种:
基于Jenkins Backup 插件进行备份:这种方案使用插件提供的备份功能,对Jenkins Home下特定数据可以归档备份,而且还提供恢复功能。所有操作可以通过Jenkins 管理界面完成,归档数据保存在Jenkins Master服务器上,插件名称为Backup Plugin。
基于Rsync工具将 Jenkins 数据同步到远程服务器进行备份:为了避免Jenkins Master单点故障,可以将数据备份到远程备份机器。可以使用rsync工具将Jenkins Home同步到远程服务器,利用rsync工具的 “--exclude-from=FILE”功能定制一个exclude文件,过滤掉无须备份的数据,比如一般而言,build目录下的内容不建议备份。
基于版本控制系统的增量备份方案:这种方法基于的是版本控制系统的备份方法,通过版本控制系统将需要备份的文件增量备份到版本仓库中。在使用Git工具时,还可以通过.gitignore文件过滤掉无须备份的文件。
把Jenkins配置文件备份到版本控制仓库,有两大好处:
增量备份,能够避免归档备份等冗余备份对CPU、Disk的浪费
理论上可以恢复到所有历史版本,具体取决于备份频率。
使用Gitlab作为备份仓库的基本步骤如下:
创建Gitlab repo,将它用作Jenkins Home远程备份repo。
设置Gitlab repo权限,确保Jenkins 账户具有push权限。
将Jenkins Home 初始化为本地repo。
添加 .gitignore 文件。
将Jenkins Home 本地仓库内容push到远程repo中,创建Master分支。
创建Jenkins Job或者Crontab ,实现定时周期性备份。
采用Git工具时的备份脚本示例如下图所示。
————
本文节选自集当今中国企业级 DevOps 实践大成的新书《DevOps三十六计》。本书由40位 DevOps 专家联袂打造,用115个案例分享技巧与规范,献1349条计策凝聚经验与智慧。点击阅读原文可直达秘笈,饱览一线DevOps专家真知灼见,观摩国内前沿实践精华,吸取先行者血泪经验,抢占企业未来竞争制胜点。
内容简介:新型的DevOps 涵盖了从需求提出到软件发布的整个软件生命周期,是产品设计、项目管理、开发、测试和运维提升的必由之路,国内大型互联网企业已做了很多探索,并将相关技能规范化、文档化、工具化、自动化甚至智能化。遗憾的是,这些宝贵经验往往仅在团队或公司内部分享,很多中小公司还在重复走着大公司走过的弯路。为了促进先进经验在整个行业内分享和传播,DevOps 时代社区和高效运维社区邀请40 位业界大咖,从精益、敏捷、开发、测试、运维、架构、安全等各个方面分享他们在Top 互联网公司及领先的传统企业工作多年的智慧和经验结晶。本书共有36 篇文章,1349 条计策,其中很多计策都是在经历刻骨铭心的事故后总结出来的,精选的115 个案例则是对相关计策的解读。本书旨在总结经验、交流分享,希望能帮助国内互联网及传统企业避免无谓的反复踩坑,让技术人员更好地聚焦于业务目标和业务产出。
长按二维码,关注“前沿技墅”,抢先接收新知、了解书讯、结识大咖。
任何伟大,无不起步于不经意间,你可以选择不经意错过,或不经意开始……
以上是关于企业级 Jenkins 数据备份大法的主要内容,如果未能解决你的问题,请参考以下文章