原文地址:https://medium.com/@devfire/how-to-become-a-devops-engineer-in-six-months-or-less-part-3-version-76034885a7ab

原文作者:Igor Kantor

翻译君:CODING 戴维奥普斯



“Close-up of a backlit laptop keyboard” by Markus Petritz on Unsplash

快速回顾

让我们快速回顾一下前文:

简而言之,这个系列文章讲述的是现代 DevOps 的精髓——如何将一个想法尽可能快速地转化上线实现盈利。

具体来说,在第一部分的文章中,我们了解了 DevOps 文化和目标;在第二部分的文章中,我们讲述了如何使用 Terraform 为之后的代码部署奠定基础。因此在本文中,我们将会讨论如何防止这些代码在运行中失去控制(we will discuss how to keep all these pieces of code from completely going haywire all over the place. ),同时还将讨论如何使用 git 来构建和推广你自己的个人品牌。

如图所示,我们现在在 DevOps 旅程的这个位置:



DevOps Journey

为什么要进行版本控制

当我们谈论"版本控制"时我们在谈论什么?

假设你正在开发一款软件,并且在不断的根据需求修改代码,添加或移除某些功能,那么最近的一次更新通常会是一次“突破性的”更新。换言之,不管你上次更新了什么内容,都打破了之前所做的工作。

现在要怎么做?

如果你真的比较老派,那么你可能更倾向于这样命名你的第一个文件:

awesome_code.pl

接着你开始做一些修改,同时需要保留有效的内容以防可能需要回退。因此,您将文件重命名为:

awesome_code.12.25.2018.pl

这样看起来运行得不错,直到你开始在一天内进行多次更改,最终可能会得到这样的文件名:

awesome_code.GOOD.12.25.2018.pl

当然,在专业的开发环境中,你有多个团队在同一代码库上协作,这将进一步打破这个模型。

毋庸置疑,这条疯狂的火车将快速脱轨。

源代码控制

源代码控制:一种将文件保存在集中位置的方法,多个团队可以在一个公共代码库上协同工作。

这并不是个新方法,我能找到的最早提到源代码控制的内容可以追溯到 1972 年,因此将代码集中在一个地方管理的想法肯定是陈旧的。相对较新的方法是所有构建产物都必须版本化,这意味着所有与生产环境相关的内容都必须进行版本控制,能被追踪、审查并且保留历史记录。

此外,强制“所有产品必须版本化”实际上也是迫使你以“自动化优先”的思维方式处理问题。例如,当你决定在你的 Dev AWS 开发环境中通过单击解决复杂问题时,你可以暂停并思考一下,“所有这些都是能以单击实现版本化构建吗?”

答案当然是否定的。虽然可以通过 UI 的快速原型查看是否有效,但这些尝试一定不是长久之计。从长远来看,请确保你使用 Terraform 或其他基础架构作为代码工具来执行所有操作。

所以如果一切都需要版本化构建,那么我们该如何存储和管理这些内容呢?

答案是 git。

Git

git 出现前,使用像 SVN 或其他的源代码控制系统通常是笨重的、用户不友好的、非常痛苦的经历。Git 的不同之处在于它包含了分布式源代码控制的概念。换句话说,当你正在处理更改时,你不会将其他人锁定在集中式源代码存储库之外。相反,你正在处理的是代码库的完整副本,然后该副本将会被合并到主存储库中。

请记住,以上是对 git 的工作原理的过度简化,即使知道 git 的内部工作方式是有价值的,并且需要一段时间才能掌握,但就本文而言,这已经足够了。

现在请记住,Git 不像旧的 SVN,它是一个分布式源代码控制系统,多个团队可以在一个共享的代码库上安全地工作。

为什么要这么麻烦?

具体来说,我强烈主张如果不知道 git 的工作原理,你就不能成为一位专业的 DevOps(云)工程师,就这么简单。那么一个人如何学习 git 呢?

我必须说,谷歌搜索“git 教程”有一个拿不准的地方在于可能会同时出现极其全面和极其混乱的教程,但是有一些内容确实好。

我敦促大家阅读、学习和练习的一系列教程是 Atlassian 的 Git 教程

事实上这些内容都非常好,但有一部分是全世界专业软件工程师都在使用的:Git Workflows

另一个非常好的教程是 Learn Git Branching

Atlassian 教程只是阅读和学习,而 Learn Git Branching 是一个互动教程。

无论如何,如果你不明白 git 的工作原理,你就不会在这个行业中走得太远!我不能一次又一次的强调这点:对 git 功能分支如何工作缺乏了解,或者无法解释 Gitflow,这是 99% 有抱负的 DevOps 工程师候选人的失败之处。

这里有一个关键点在于你可以参加面试,不知道 Terraform 或任何最新的流行的基础设施作为代码工具,没关系——你可以在工作中学习它。

但是,不知道 git 及其工作方式是一个表明你缺乏现代软件工程最佳实践的基础知识的信号,无论是否与 DevOps 相关,这向招聘经理发出了这样的信号:你的学习曲线将会非常陡峭。我相信你不想这样。

相反,你自信地谈论 git 最佳实践的能力将告诉招聘经理,你已经具备了一种软件工程的思维方式——这正是你想要展现的形象。

总结一下:你不需要成为世界上最厉害的 git 专家才能成为令人敬畏的 DevOps 工程师,但是你需要深入学习 git 一段时间直到真正掌握,才能自信地谈论相关话题。至少,你应该精通如何:

  1. Fork 代码仓库
  2. 创建分支
  3. 合并来自上游或者后端的更改
  4. 创建 Pull 请求

接下来要怎么做

现在,一旦你看完了介绍性的 git 教程,请为自己准备一个 GitHub 帐户。

(译者注:如果你在国内,希望使用高效便捷的开发工具以及中文页面,也可以使用 CODING

一旦拥有你的 Github 帐户后,就开始向它贡献你的代码!无论你学到什么,都需要你编写代码,请确保定期将其提交到 Github。这不仅灌输了良好的源代码控制规则,还可以帮助你建立起自己的个人品牌。

注意:当你在学习如何使用 git 和 GitHub 时,请特别注意 Pull 请求(或 PR,如果你想要酷一点)。



Pull Request, by Vidar Nordli-Mathisen

个人品牌建设

说到酷——一个品牌是向更广阔的世界展示你的能力的一种方式。

目前一种更好的方法是建立一个充实的 GitHub 主页作为你的个人品牌代理形象,现在几乎所有的雇主都会有这样的要求。因此你应该努力拥有一个整洁、精心策划的 GitHub 帐户——你可以将其放在简历上并引以为豪。

在后面的部分中,我们将讨论如何使用 Hugo 框架在 GitHub 上构建一个简单但看起来酷炫的网站。现在,只需要将代码放入 GitHub 就足够了。

之后随着你的经验越来越丰富,你可能会考虑使用两个 GitHub 帐户:一个用于存储你编写的练习代码的资料,另一个用于存储你希望向其他人展示的代码。

做一个总结:

  1. 学习 git
  2. 在 Github 上贡献你所学的一切
  3. 利用第 1 点和第 2 点展示到目前为止你学到的所有东西
  4. 然后从中获益!

最后一点想法

最后,请记住这个领域的最新发展,例如 GitOps。GitOps 将我们迄今为止讨论的所有想法都提升到了新的层次——通过 git、pull 请求和部署流水线完成所有工作。

请注意,GitOps 和类似它的方法都是与业务方面的内容息息相关的。具体来说,我们使用像 git 这样的复杂工具并不是因为它们很酷,相反,我们使用 git 来实现业务敏捷性、加速创新并更快地交付功能——这些都是为了让我们的业务能获得更高的收益!

译后记

我们相信,在企业数字化转型落地过程中 ,DevOps 是企业软件开发模式革新的重要支柱。

CODING 作为国内领先的 DevOps 解决方案提供商,涵盖了软件开发从构想到交付的一切所需,支持 Git/SVN 代码托管,使研发团队在云端高效协同,实践敏捷开发与 DevOps,提升软件交付质量与速度,帮助企业轻松将创意转化为创收。

CODING 也会持续关注并分享软件研发领域最新理念与技术,与 DevOps 工程师一起成长。

DevOps 工程师成长日记系列三:版本的更多相关文章

  1. DevOps 工程师成长日记系列一:必备知识与技能组合

    原文地址:https://medium.com/@devfire/how-to-become-a-devops-engineer-in-six-months-or-less-366097df7737 ...

  2. DevOps 工程师成长日记系列二:配置

    原文地址:https://medium.com/@devfire/how-to-become-a-devops-engineer-in-six-months-or-less-part-2-config ...

  3. DevOps 工程师成长日记系列四:打包

    原文地址:https://medium.com/@devfire/how-to-become-a-devops-engineer-in-six-months-or-less-part-4-packag ...

  4. DevOps 工程师成长日记系列五:部署

    原文地址:https://medium.com/@devfire/how-to-become-a-devops-engineer-in-six-months-or-less-part-5-deploy ...

  5. DevOps工程师的成长路线图

    DevOps工程师的成长路线图 我们推崇的是 Reducing the gap between Devs and Operation teams. 来自kamranahmedse you built ...

  6. 嵌入式系统Linux内核开发工程师必须掌握的三十道题(转)

    嵌入式系统Linux内核开发工程师必须掌握的三十道题 如果你能正确回答以下问题并理解相关知识点原理,那么你就可以算得上是基本合格的Linux内核开发工程师,试试看! 1) Linux中主要有哪几种内核 ...

  7. MySQL并发复制系列三:MySQL和MariaDB实现对比

    http://blog.itpub.net/28218939/viewspace-1975856/ 并发复制(Parallel Replication) 系列三:MySQL 5.7 和MariaDB ...

  8. DevOps 工程师实际上是做什么的

    DevOps 工程师实际上是做什么的? 我们之前已经讨论过许多关于DevOps和DevOps世界的最新趋势了.但是DevOps工程师到底是做什么的? DevOps工程师以最纯粹的方式弥合了软件开发和运 ...

  9. DevOps工程师到底做些什么?

    我们之前已经听到很多谈论DevOps和DevOps世界的最新趋势的事情,但是就DevOps工程师本身,到底干些什么呢? 在最纯粹的存在形式上来说,DevOps工程师是为了加快开发和运营团队之间的交付效 ...

随机推荐

  1. 松软科技web课堂:JavaScript 事件

    HTML 事件是发生在 HTML 元素上的“事情”. 当在 HTML 页面中使用 JavaScript 时,JavaScript 能够“应对”这些事件. HTML 事件 HTML 事件可以是浏览器或用 ...

  2. Swift零基础教程2019最新版(一)搭建开发环境

    Swift简单介绍 Swift是苹果强力推荐的新型开发语言,能开发苹果下属所有软件平台(iOS,iPadOS,macOS,watchOS,tvOS)初学者如果想进入苹果的开发体系,从Swift开始学习 ...

  3. Hadoop、storm和Spark Streaming简单介绍(非原创)

    文章大纲 一.Hadoop是什么二.storm是什么三.Spark Streaming是什么四.Spark与storm比较五.参考文章   一.Hadoop是什么 1. 简介 Hadoop是一个由Ap ...

  4. JS&Jquery基础之对象和数组以及类型转换

    一.{ } 大括号,表示定义一个对象,大部分情况下要有成对的属性和值,或是函数. 如:var LangShen = {"Name":"Langshen",&qu ...

  5. myeclipse 9.0 破解方法,亲测可用

    MyEclipse 9.0的破解方法,步骤如下: 1.破解公钥,确保MyEclipse没有开启,否则失败! 用WinRAR打开Common\plugins\com.genuitec.eclipse.c ...

  6. 2019中国大学生程序设计竞赛(CCPC) - 网络选拔赛

    传送门 A.^&^ 题意: 找到最小的正数\(C\),满足\((A\ xor\ C)\&(B\ xor \ C)\)最小. 思路: 输出\(A\&B\)即可,特判答案为0的情况 ...

  7. Node.js接口避免重复启动

    众所周知,一个Node接口要是想被调用,得先在命令行中执行如下代码来启动接口 node base.js 但是一旦修改了base.js,就得重新执行这句命令 注:这里的base.js是我的node接口文 ...

  8. 201871010114-李岩松《面向对象程序设计(java)》第十四周学习总结

    项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 https://www.cnblogs.com/nwnu-daizh/p ...

  9. JVM的类加载过程以及双亲委派模型详解

    JVM的类加载过程以及双亲委派模型详解 这篇文章主要介绍了JVM的类加载过程以及双亲委派模型详解,类加载器就是根据指定全限定名称将 class 文件加载到 JVM 内存,然后再转化为 class 对象 ...

  10. layUI学习第四日:layUI布局系列一

    1.栅格布局规则 1.1 layui-row定义行,如:<div class="layui-row"></div> 1.2 layui-col-md*这样的 ...