原文地址:https://medium.com/edureka/devops-interview-questions-e91a4e6ecbf3
原文作者:Saurabh Kulshrestha
翻译君:CODING 戴维奥普斯

你是一位 DevOps 工程师还是想进入 DevOps 领域的新手?如果是,那么你已经把握住了未来趋势。在本文中,我列出了几十个在雇佣 DevOps 工程师时,面试官可能会问到的问题以供参考。

理解 DevOps 的关键点在于它不仅仅是一种技术集合,而是一种思维方式、一种文化。DevOps 需要一种文化转变——将运维与开发相结合,并需要一个相关联的技术工具链来促进协作变革。由于 DevOps 理念仍处于非常初级的阶段,因此 DevOps 的应用以及适应和协作所需的带宽因团队而异。但是,你可以开发 DevOps 技能组合,提升自我,成为任何类型的团队都需要的理想候选人。

成为一名 DevOps 工程师有哪些要求?

在寻找能胜任 DevOps 工程师的人选时,团队会有一套清晰的技能需求。其中最重要的是:

  • 熟悉基础架构自动化工具,如 Chef,Puppet,Ansible,SaltStack 或 Windows PowerShell DSC。
  • 熟练掌握 Ruby,Python,PHP 或 Java 等语言。
  • 帮助你跨团队和角色进行沟通和协作的人际关系技巧。

为了组织下面的问题,我把自己放在了你的位置上,本文中的大多数答案都是以你的角度来写的——即一个有潜力的 DevOps 专家。

一般的 DevOps 相关面试问题

这类基础问题是与任何特定 DevOps 阶段无关的问题,旨在测试你对 DevOps 的理解程度,而不是关注特定的工具或阶段。

Q1.DevOps 和敏捷的根本区别

下表中列出了两者之间的差异。

Q2.DevOps 需要什么

我认为这个答案应该从解释市场总体趋势开始。现在许多公司都在通过尝试向客户快速发布小的功能点,以取代发布大的功能组。这样做有许多优点,比如能快速收到客户反馈、提高软件质量等,从而大幅提升客户满意度。为实现这一目标,公司必须:

  1. 增加部署频率
  2. 降低新版本的故障率
  3. 缩短交付时间
  4. 新版本崩溃时更快的平均恢复时间

DevOps 满足所有这些需求,并有助于实现无缝的软件交付。你可以举出像 Etsy、Google 和亚马逊这样的公司的例子,这些公司已经采用 DevOps 达到了甚至五年前都无法想象的性能水平。他们每天都在进行数十、数百甚至数千次代码部署,同时提供世界级的稳定性、可靠性和安全性。

如果我必须测试你对 DevOps 的了解程度,那么你应该知道敏捷(Agile)和 DevOps 之间的区别。下一个问题就是针对这一点的。

Q3.DevOps 与敏捷/SDLC 有何不同?

我建议你按照以下说明进行操作:
敏捷是一套关于如何实现生产即开发软件的价值观和原则。举个例子:如果你有一些想法,并且希望将这些想法转化为可用的软件,那么你可以使用敏捷价值观和原则作为实现此目的的方法。但是,该软件可能只适用于开发人员的笔记本电脑或测试环境,你希望以一种安全简单的方式,快速、轻松、可复用地将该软件移植到生产基础架构中。要做到这一点,你需要 DevOps 工具和技术。

总而言之,敏捷软件开发方法侧重于软件的开发,DevOps 则负责以最安全可靠的方式开发和部署软件。

现在请记住,你在之前的回答中包含了 DevOps 工具,因此请准备好回答一些与此相关的问题。

Q4.哪些是最顶尖的 DevOps 工具?你使用过哪些工具?

下面介绍了一些最受欢迎的 DevOps 工具:

  • Git:版本控制系统工具
  • Jenkins:持续集成工具
  • Selenium:持续测试工具
  • Puppet、Chef、Ansible:配置管理和部署工具
  • Nagios:持续监控工具
  • Docker:容器化工具

如果有需要你也可以提及其他工具,但请确保在你的回答中包含上述工具。

接下来的回答有两种可能:

  1. 如果你掌握上述所有工具,那么你可以说自己已经使用过所有这些工具来开发高质量的软件,并能轻松、频繁和可靠地部署这些软件。
  2. 如果你只对上述某些工具有经验,那么请提及这些工具,并说自己对这些工具有专业性,同时对其余工具进行一些概述。

Q5.所有这些工具如何协同工作?

下面给出了一个通用的逻辑流程,在这个流程中所有内容都将自动进行无缝交付。但是此流程也会因不同组织的不同需求而导致一些差异。

  1. 开发人员开发代码,源代码由 Git 等版本控制系统工具管理。
  2. 开发人员将此代码提交到 Git,并且对代码所做的任何更改都将提交到此代码仓库。
  3. Jenkins 通过 Git 插件从仓库中提取此代码,并使用 Ant 或 Maven 等工具构建它。
  4. 配置管理工具(如 Puppet)部署和提供测试环境,然后 Jenkins 在使用 Selenium 等工具进行测试的测试环境上发布此代码。
  5. 代码测试结束后,Jenkins 就会将其发送到生产服务器上进行部署(甚至生产服务器也由 Puppet 等工具进行配置和维护)。
  6. 部署后,Nagios 等工具会进行持续监控。
  7. Docker 容器提供测试环境来测试构建功能。

Q6.DevOps 有哪些优势?

对于这个答案,你可以利用你过去的经验,解释 DevOps 是如何帮助你完成之前的工作。如果没有任何此类经验,那么你可以提及以下优势。

技术优势:
持续的软件交付
修复不太复杂的问题
更快地解决问题

商业优势:
更快速地提供新功能
更稳定的操作环境
更多可用于提升价值的时间(而不是修复/维护)

Q7.DevOps 帮助我们实现的最重要的事情是什么?

据我所知,DevOps 帮助我们实现的最重要的事是尽可能快地将更改投入生产,同时最大限度地保证软件质量和合规性。这是 DevOps 的主要目标。

你也可以提及 DevOps 的许多其他积极影响,例如团队之间更清晰的沟通和更好的工作关系——即运维团队和开发团队共同合作,通过提供高质量的软件提升客户满意度。

Q8.用一个工业/现实生活中的使用案例来解释 DevOps

有许多行业正在应用 DevOps,所以你可以举出任意案例,也可以参考下面的例子:
Etsy 是一个 P2P 电商网站,专注于手工或古董物品,以及独特的工厂制造的物品。Etsy 在缓慢且痛苦的网站更新中挣扎,这些更新经常导致网站崩溃,影响了数百万通过在线市场销售商品的 Etsy 用户的使用,并且很有可能将商品推向竞争对手。

在新技术管理团队的帮助下,Etsy 从每周进行两次四小时全站点部署的瀑布模型,转变为更敏捷的模式。如今它拥有完全自动化的部署管道,据报道,其持续交付实践每天可以进行 50 多次更少中断的部署。

Q9.解释与分享在之前的工作中,你在软件开发和技术运维方面的理解和专业知识

这个回答主要是分享你过去的工作经验,并试着解释你在以前工作中的灵活性。可以参考以下示例:
DevOps 工程师几乎总在业务关键在线环境中全天候工作。我能够适应随叫随到的工作,并且承担生产系统的维护责任;我成功自动化了支持持续软件部署的流程;我有使用公有/私有云、Chef 或 Puppet 等工具、使用 Python 和 PHP 等工具编写脚本和实现自动化方面的经验,并且具有敏捷相关的背景。

Q10.DevOps 的反模式有哪些?

一般来说通常你的研发组织中遵循了某种模式,但如果其他人普遍采用的模式对你的组织不起作用,并且你继续盲目地遵循它,那么你实际上是在采用反模式。一些关于 DevOps 的错误认知包括:

  • DevOps 是一个过程
  • 敏捷就是 DevOps?
  • 我们需要一个单独的 DevOps 小组
  • DevOps 将解决我们所有的问题
  • DevOps 意味着由开发人员来管理生产
  • DevOps 是开发驱动的发布管理
  • DevOps 不是开发驱动的
  • DevOps 不是 IT 业务驱动的
  • 我们不能应用 DevOps - 我们比较特别
  • 我们不能应用 DevOps - 我们找错人了

点击使用 CODING,体验 DevOps 全工具链敏捷研发

2019 DevOps 必备面试题——DevOps 理念篇的更多相关文章

  1. 2019 DevOps 必备面试题——持续集成篇

    原文地址:https://medium.com/edureka/devops-interview-questions-e91a4e6ecbf3 原文作者:Saurabh Kulshrestha 翻译君 ...

  2. 2019 DevOps 必备面试题——代码版本控制篇

    原文地址:https://medium.com/edureka/devops-interview-questions-e91a4e6ecbf3 原文作者:Saurabh Kulshrestha 翻译君 ...

  3. 2019 DevOps 必备面试题——配置管理篇

    原文地址:https://medium.com/edureka/devops-interview-questions-e91a4e6ecbf3 原文作者:Saurabh Kulshrestha 翻译君 ...

  4. 2019 DevOps 必备面试题——容器化和虚拟化

    原文地址:https://medium.com/edureka/devops-interview-questions-e91a4e6ecbf3 原文作者:Saurabh Kulshrestha 翻译君 ...

  5. Redis必备面试题《基础篇》

    Date:2019-11-12 读前思考: 面试官会问什么样的问题? 所问的问题背后真实的套路是什么? 喜欢问Redis哪些问题? 如何顺畅回答面试问的问题?吊打面试官. 1.什么是Redis? Re ...

  6. 年度十佳 DevOps 博客文章(后篇)

    如果说 15 年你还没有将 DevOps 真正应用起来,16 年再不实践也未免太落伍了.在上篇文章中我们了解到 15 年十佳 DevOps 博客文章的第 6-10 名,有没有哪一篇抓住了您的眼球,让您 ...

  7. 好程序员分享Web前端面试题汇总JS篇之跨域问题

    为什么80%的码农都做不了架构师?>>>   好程序员分享Web前端面试题汇总JS篇之跨域问题,接着上一篇文章我们继续来探讨web前端面试必备面试题. 跨域解决方案 1. 通过jso ...

  8. Azure DevOps (十三) 通过Azure Devops部署一个Go的Web应用

    前几篇文章中,我们分别实现通过azure来部署.NET和Springboot的应用,今天我们来研究一下如何部署一套Go的Web应用上去. 文章配套视频专栏: https://space.bilibil ...

  9. web前端面试试题总结---html篇

    HTML Doctype作用?标准模式与兼容模式各有什么区别? (1).<!DOCTYPE>声明位于位于HTML文档中的第一行,处于 <html> 标签之前.告知浏览器的解析器 ...

随机推荐

  1. ASCII、Unicode、GBK和UTF-8字符编码的区别联系

    转自http://dengo.org/archives/901 很久很久以前,有一群人,他们决定用8个可以开合的晶体管来组合成不同的状态,以表示世界上的万物.他们看到8个开关状态是好的,于是他们把这称 ...

  2. display:block、display:inline与displayinline:block的概念和区别

    总体概念 block和inline这两个概念是简略的说法,完整确切的说应该是 block-level elements (块级元素) 和 inline elements (内联元素).block元素通 ...

  3. 64位centos下安装python的PIL模块

    http://blog.csdn.net/xiaojun1288/article/details/8673529

  4. PLSQL_性能优化系列01_Oracle Index索引

    2014-06-01 Created By BaoXinjian

  5. [Android应用]《花界》V1.0 正式版隆重发布!

    http://www.cnblogs.com/qianxudetianxia/archive/2012/04/05/2433669.html 1. 软件说明(1). 花界是一款看花软件:“看花,议花, ...

  6. CSS样式属性

    一.背景与前景 1.背景: 2.前景字体: (二)边界和边框 border(表格边框.样式等).margin(表外间距).padding(内容与单元格间距). margin(外边距)对自身不会有变化, ...

  7. 在java程序当中怎么获取一个文件的路径

    在java程序当中怎么获取一个文件的路径? * 当这个文件在类路径下的时候(在src/bin目录下的时候): String absolutePath = Thread.currentThread(). ...

  8. Alpha冲刺之事后诸葛亮

    组长博客 作业博客 项目Postmortem 设想和目标 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 我们的软件针对的是福大学子来到食堂会犹豫不决无法决定吃什么 ...

  9. 设计模式学习——工厂模式(Factory Pattern)

    1.有一个工厂,专门生产不同品牌的汽车.当有人需要从此工厂提货的时候,只需要告诉他,要什么品牌的,就可以了,并不关心这些车是怎么生产出来的. 2.以上方式,如果增加品牌的时候,也要修改工厂,有点麻烦. ...

  10. mysqlDOS命令

    MySQL : 1.安装mysql服务:mysqld install 2.删除mysql服务:sc delete mysql 3.启动mysql服务:net start mysql 4.初始化设置密码 ...