229.md 20.7 KB
Newer Older
W
wizardforcel 已提交
1
# Google 如何针对行星级基础设施进行行星级工程设计?
W
init  
wizardforcel 已提交
2

W
wizardforcel 已提交
3
> 原文: [http://highscalability.com/blog/2016/7/18/how-does-google-do-planet-scale-engineering-for-a-planet-sca.html](http://highscalability.com/blog/2016/7/18/how-does-google-do-planet-scale-engineering-for-a-planet-sca.html)
W
init  
wizardforcel 已提交
4

W
wizardforcel 已提交
5
![](img/9c7095e31a8c5999cdcef74072ddf82a.png)
W
init  
wizardforcel 已提交
6

W
wizardforcel 已提交
7
Google 如何保持其所有服务正常运行? 他们似乎从来没有失败过。 如果您想知道我们在 [GCP NEXT 2016](https://cloudplatformonline.com/next2016-schedule.html) 上发表的演讲中的精彩幕后花絮, [Melissa Binde](https://www.linkedin.com/in/mbinde) ,Google Storage SRE 总监: [Google 如何针对行星级基础架构](https://www.youtube.com/watch?v=H4vMcD7zKM0)进行行星级工程。
W
init  
wizardforcel 已提交
8

W
wizardforcel 已提交
9
梅利莎(Melissa)的讲话很简短,但充满智慧,而且以一种胡说八道的方式表达出来,使您认为服务是否失败梅利莎(Melissa)绝对是您想要的那种人。
W
init  
wizardforcel 已提交
10

W
wizardforcel 已提交
11
哦,什么是 SRE? 它代表*站点可靠性工程*,但定义却更加难以捉摸。 就像您要求道的定义时得到的答案一样。 正如 Google 的本·斯洛斯(Ben Sloss)24x7 副总裁所明确指出的那样,这不仅仅是一个过程,更是一个过程,他将 SRE 定义为:
W
init  
wizardforcel 已提交
12

W
wizardforcel 已提交
13
> 当软件工程师承担了过去称为操作的任务时会发生什么。
W
init  
wizardforcel 已提交
14

W
wizardforcel 已提交
15
让它在您的头部反弹一会儿。
W
init  
wizardforcel 已提交
16

W
wizardforcel 已提交
17
最重要的是,有一件事很清楚:SRE 是生产的保管人。 SRE 是 google.com 和 GCP 的客户体验的管理者。
W
init  
wizardforcel 已提交
18

W
wizardforcel 已提交
19
对我来说,一些演讲重点:
W
init  
wizardforcel 已提交
20

W
wizardforcel 已提交
21 22 23 24
*   **点检正常运行时间的破坏性激励与功能**相比。 SRE 试图解决想要推送功能的开发人员与想要通过不推送功能来维持正常运行时间的系统管理员之间的天然矛盾。
*   **错误预算**。 这是预期会失败的想法。 这不是一件坏事。 用户无法确定服务的运行时间是 100%还是 99.99%,因此您可能会出错。 这减少了开发人员和运营人员之间的紧张关系。 只要维护错误预算,您就可以推出新功能,而运营方也不会受到指责。
*   **目标是立即恢复服务。 故障排除将在稍后进行。** 这意味着在还原服务后,您需要大量日志记录和工具来进行调试。 由于某种原因,这使[较早的文章](http://highscalability.com/blog/2014/2/3/how-google-backs-up-the-internet-along-with-exabytes-of-othe.html)上的内容闪烁了起来,同样基于 Google SRE 的讲话:*备份无用。 这是您关心的*还原。
*   **没有无聊的分页哲学**。 当页面进入时,应该是一个有趣的新问题。 您不希望无聊的 SRE 处理重复性问题。 这就是机器人的目的。
W
init  
wizardforcel 已提交
25

W
wizardforcel 已提交
26
演讲中其他有趣的话题是:SRE 的组织结构如何? 如何聘用开发人员来专注于生产并使他们满意? 我们如何保持团队在 Google 内部的价值? 我们如何帮助我们的团队更好地沟通并解决与数据而非断言或权力夺取的分歧?
W
init  
wizardforcel 已提交
27

W
wizardforcel 已提交
28
让我们继续吧。 以下是 Google 如何针对行星级基础设施进行行星级工程...
W
init  
wizardforcel 已提交
29

W
wizardforcel 已提交
30
## 保持平衡:点检正常运行时间的破坏性动机与功能
W
init  
wizardforcel 已提交
31

W
wizardforcel 已提交
32
*   系统管理员会在站点正常运行时获得 Cookie 的正常运行时间。 当网站停滞不前时,我们会吸引访问者,访问者会给我们钱。
W
init  
wizardforcel 已提交
33

W
wizardforcel 已提交
34
*   开发人员会获得功能的 Cookie。 发布一个新功能,访问者来了,他们给了我们钱。
W
init  
wizardforcel 已提交
35

W
wizardforcel 已提交
36
*   生产冻结,也就是新功能的冻结,通常映射为增加正常运行时间。
W
init  
wizardforcel 已提交
37

W
wizardforcel 已提交
38
*   开发人员和系统管理员之间存在天生的紧张关系。 开发人员会获得发布功能的 Cookie。 系统管理员会获取 Cookie 以确保正常运行时间。
W
init  
wizardforcel 已提交
39

W
wizardforcel 已提交
40
*   因此,系统管理员因阻止新功能发布而获得奖励。 如果开发人员能够解决系统管理员的问题,他们将获得奖励。
W
init  
wizardforcel 已提交
41

W
wizardforcel 已提交
42
*   开发人员进行他们所谓的 Beta 测试是为了尽快发布功能。
W
init  
wizardforcel 已提交
43

W
wizardforcel 已提交
44
*   系统管理员执行他们所谓的启动评论,以减慢新功能。
W
init  
wizardforcel 已提交
45

W
wizardforcel 已提交
46
*   您的团队将所有的时间都花在彼此抗争上,因此您会增加停机次数,风险,混乱和无政府状态。
W
init  
wizardforcel 已提交
47

W
wizardforcel 已提交
48
*   您想要的是消除异想天开的命令。 请按规则处理,以便团队可以有目标并共同努力。
W
init  
wizardforcel 已提交
49

W
wizardforcel 已提交
50
*   就像 devops 一样,有一种方法可以使开发人员和操作人员一起工作。 问题是,devops 无论走到哪里都有不同的含义。 相反,SRE(站点可靠性工程)定义明确。
W
init  
wizardforcel 已提交
51

W
wizardforcel 已提交
52
*   **SRE:** **当您要求软件工程师设计和运行操作时会发生什么?**-Ben Sloss 24x7 VP,Google
W
init  
wizardforcel 已提交
53

W
wizardforcel 已提交
54
    *   软件工程师-事实证明,当知道软件的人也运行服务时,服务可以更好地运行。 他们对什么使它打勾有深刻的理解。
W
init  
wizardforcel 已提交
55

W
wizardforcel 已提交
56
    *   设计和运行-实际上是设计您的生产环境,而不是让它成为意外的事故。
W
init  
wizardforcel 已提交
57

W
wizardforcel 已提交
58
*   假设有 1000 个 SRE 在 Google 的基础架构上工作:网络,计算,存储等。有多少个 SRE 负责云计算?
W
init  
wizardforcel 已提交
59

W
wizardforcel 已提交
60
    *   所有。
W
init  
wizardforcel 已提交
61

W
wizardforcel 已提交
62
    *   **google.com 的运行源与 GCP(Google 的云平台)的运行**之间没有界限。 不需要让云团队和内部团队进行沟通的开销。 他们创造了一种环境,可以帮助所有人协同工作。
W
init  
wizardforcel 已提交
63

W
wizardforcel 已提交
64
## 技能:SRE 是一个印章团队和圣职
W
init  
wizardforcel 已提交
65

W
wizardforcel 已提交
66
*   本节的标题是我的描述。 具有技能的 SRE 必须是精英。 在工作方面,他们仅致力于这种几乎准神秘的事物,称为生产。
W
init  
wizardforcel 已提交
67

W
wizardforcel 已提交
68
*   SRE 必须比开发人员更熟练,才能完成相同的工作:
W
init  
wizardforcel 已提交
69

W
wizardforcel 已提交
70
    *   他们需要更大的技能范围。
W
init  
wizardforcel 已提交
71

W
wizardforcel 已提交
72
    *   所有 SRE 必须通过完整的软件开发人员面试才能被录用。
W
init  
wizardforcel 已提交
73

W
wizardforcel 已提交
74
    *   所有 SRE 必须通过一次非抽象的大型系统设计采访。
W
init  
wizardforcel 已提交
75

W
wizardforcel 已提交
76
*   SRE 必须具有相同的软件技能,这是不同的应用领域。
W
init  
wizardforcel 已提交
77

W
wizardforcel 已提交
78
    *   开发人员专心于产品经理并制作功能。
W
init  
wizardforcel 已提交
79

W
wizardforcel 已提交
80
    *   SRE 依赖于生产,以使生产达到最佳状态。
W
init  
wizardforcel 已提交
81

W
wizardforcel 已提交
82
*   **将面向开发和面向生产的观点结合在一起时,最终的设计会更强大**
W
init  
wizardforcel 已提交
83

W
wizardforcel 已提交
84
*   入职流程示例给出了 SRE 带来的问题的示例,该过程在将团队的项目置于 SRE 的责任之下时发生。 在评估团队的软件时,他们发现:
W
init  
wizardforcel 已提交
85

W
wizardforcel 已提交
86
    *   当达到规模时,它将在生产中失败。
W
init  
wizardforcel 已提交
87

W
wizardforcel 已提交
88
    *   开发人员已隐式假定某种呼叫不会失败。
W
init  
wizardforcel 已提交
89

W
wizardforcel 已提交
90
    *   他们假设请求的分配是统一的。
W
init  
wizardforcel 已提交
91

W
wizardforcel 已提交
92
    *   他们以为不会受到用户的关注。
W
init  
wizardforcel 已提交
93

W
wizardforcel 已提交
94
    *   他们假定所有请求的大小均处于平均水平。
W
init  
wizardforcel 已提交
95

W
wizardforcel 已提交
96
    *   他们的两条尾巴都失败了(没有给出解释)。
W
init  
wizardforcel 已提交
97

W
wizardforcel 已提交
98
## 组织:为开发人员提供不让运营工作积聚的理由
W
init  
wizardforcel 已提交
99

W
wizardforcel 已提交
100
*   该系统必须设计为不增加运营工作,因为如果开发人员不从事工作,他们将不会那么在意。
W
init  
wizardforcel 已提交
101

W
wizardforcel 已提交
102
*   **SRE** 的开发预算。 如果您的系统的运营开销很大,那么您获得的开发人员就不会那么多,那么您就无法推广那么多的功能。
W
init  
wizardforcel 已提交
103

W
wizardforcel 已提交
104
*   SRE 具有完全不同的命令链。 他们有自己的副总裁,与开发副总裁分开。 这赋予了他们权力和权力。 当生产意味着他们需要拒绝时,它允许他们说不。 一堆不是的传呼猴子。
W
init  
wizardforcel 已提交
105

W
wizardforcel 已提交
106
*   当开发人员说他们可以捐赠人数时,SRE 不必接受。 SRE 可以说服务不够重要,请自己继续提供支持。
W
init  
wizardforcel 已提交
107

W
wizardforcel 已提交
108
*   SRE 是一种稀缺资源。 并非 Google 的每个团队都有 SRE。 云确实可以,但是不是每个其他团队,甚至不是云中的每个小服务,都只是重要的。
W
init  
wizardforcel 已提交
109

W
wizardforcel 已提交
110
## 环境:如何使开发人员在生产团队中保持快乐?
W
init  
wizardforcel 已提交
111

W
wizardforcel 已提交
112
*   **至少有 50%的工作需要为项目工作**。 不待命。 不是门票。 不开会。 实际上是在做项目工作。
W
init  
wizardforcel 已提交
113

W
wizardforcel 已提交
114
*   如果项目工作量过多,则开发人员会给 SRE 分配更多的人员,或者将额外的工作流交给开发人员团队。
W
init  
wizardforcel 已提交
115

W
wizardforcel 已提交
116
*   什么是项目工作?
W
init  
wizardforcel 已提交
117

W
wizardforcel 已提交
118
    *   通过切换基础数据库技术来改善服务的延迟。
W
init  
wizardforcel 已提交
119

W
wizardforcel 已提交
120
    *   编写自动化以加速部署。
W
init  
wizardforcel 已提交
121

W
wizardforcel 已提交
122
    *   跨服务的项目。 Google 作为一项内部服务,可以由其他服务(通常由软件 bot)在内部进行查询,如果可以安全地将计算机停机,可以安全地将机架停机或者将数据中心安全地停机,则可以返回 Google ?
W
init  
wizardforcel 已提交
123

W
wizardforcel 已提交
124
*   SRE 是一支志愿军。 没有草稿。
W
init  
wizardforcel 已提交
125

W
wizardforcel 已提交
126
    *   您可以随时转入另一个 SRE 团队。
W
init  
wizardforcel 已提交
127

W
wizardforcel 已提交
128
    *   您可以随时转移到 dev 中。
W
init  
wizardforcel 已提交
129

W
wizardforcel 已提交
130
    *   Mission Control 是一个程序,开发人员可以在其中试用 SRE 并查看他们是否喜欢它。
W
init  
wizardforcel 已提交
131

W
wizardforcel 已提交
132
*   团队很流畅。 人们来自团队,分享经验,分享观点。
W
init  
wizardforcel 已提交
133

W
wizardforcel 已提交
134
## 预算:您可以支出任意预算的错误预算
W
init  
wizardforcel 已提交
135

W
wizardforcel 已提交
136
*   如果您有 3 个 9 的可用性,目标不是将其提高到 4 个 9,则您有 0.1%的错误预算,请继续努力。
W
init  
wizardforcel 已提交
137

W
wizardforcel 已提交
138
*   **如果您想更快地推出功能并使 GCP 变得更好,那就去做吧。 直到用尽错误预算。**
W
init  
wizardforcel 已提交
139

W
wizardforcel 已提交
140
*   如果您希望进行较差的测试,使软件定期出现故障并且必须不断回滚,则也可以选择该选项,但是错误预算很快就会用完,并且您将无法启动 。
W
init  
wizardforcel 已提交
141

W
wizardforcel 已提交
142
*   错误预算按季度循环。
W
init  
wizardforcel 已提交
143

W
wizardforcel 已提交
144
*   有一个逃生阀:三枚银色子弹。
W
init  
wizardforcel 已提交
145

W
wizardforcel 已提交
146
    *   一个开发人员可以说我真的需要推动,请给我一个银弹。
W
init  
wizardforcel 已提交
147

W
wizardforcel 已提交
148
    *   SRE 会说“ OK”,但您必须说服 VP 您实际需要推动。
W
init  
wizardforcel 已提交
149

W
wizardforcel 已提交
150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348
    *   这个仪式听起来很愚蠢,但功能非常强大。 它将控制权交给开发人员。 他们有 3 个灵丹妙药,由他们的副总裁来决定是否合适。

*   错误预算基于每个服务。 因此,如果多个开发团队使用相同的服务,则它们共享相同的预算。

    *   SRE 不在交战的开发团队中间。 他们必须弄清楚如何花费错误预算。

*   机外。 如果所有其他方法都失败了,并且开发人员和 SRE 确实不同意,则 SRE 可以派遣开发团队。

    *   像和睦的离婚。

    *   这是至关重要的逃生阀门,因此团队在很长一段时间内都不会出现令人讨厌的分歧。

    *   很少见,但确实发生了。 一个示例场景是,如果团队不想在其 ACID 类型项目中使用 Spanner,如果开发团队说他们想建立自己的团队,那么 SRE 团队可以说他们不想为团队提供支持。 去建立自己的数据库,因为这对生产不利。

*   SRE 是 google.com 和 GCP 的生产托管人,SRE 是客户体验的托管人。

## SRE 支持在频谱上

*   聊天和咨询。 与开发人员聊天。 进行白板会议。

*   协同设计。 与开发人员一起创建设计。

*   完全所有权。 完全拥有的服务。 所有容量,所有供应,所有页面。

*   页面是保持诚实的一种方式。 它们不是 SRE 的目的。

    *   负责制作的人应该拿走页面,因为这样可以使他们的皮肤保持游戏的外观。

    *   它还有助于使 SRE 的技能,专长和观点保持最新。

## 是什么让事情顺利进行? 文化和过程

*   Google 会进行常规的培训和通话阴影处理。

*   Google 也有一个名为:**命运之轮**的过程-卷轴游戏。

    *   一个人是地牢大师,他们有一个受害者,团队轮流尝试猜测发生了什么。

    *   Google 运行非常复杂的系统。 除了进行培训的人之外,很少有人真正知道发生了什么以及答案是什么。

    *   对新的来电者来说很好。 让他们在受控环境中进行测试。

    *   有些团队在某些场景中会破坏生产并让新手修复它。

    *   对退伍军人也有好处。 最好重新整理您的知识,尤其是在使用非常复杂的系统时。

## 事件管理

*   场景:您正在呼叫 gmail,并且您获得票证,用户可以看到其他用户的电子邮件。 你是做什么? 关闭 gmail。

*   **Oncallers 被完全授权采取一切措施来保护用户,保护信息,保护 Google。** 如果这意味着要关闭 gmail 甚至关闭全部 google.com,那么作为 SRE,您的副总裁将为您提供支持,而您的 SVP 将为保护 Google 提供支持。

*   **目标是立即恢复服务。 故障排除将在稍后进行。**

    *   有二进制状态的记录。 有日志。

    *   醒着,开发人员在办公室,所有人都在时,请进行故障排除。 目的是使服务重新启动并运行。

## 你该怪谁?

*   当“新开发者”推送代码并破坏 google.com 达三个小时时,您应归咎于谁? a)新开发者 b)代码审查。 c)缺乏测试(或被忽略)的测试。 d)缺乏针对代码的适当的金丝雀程序。 e)缺乏快速回滚工具。

    *   除了新开发者以外的所有东西。 **如果新开发人员编写的代码会导致网站瘫痪,那不是开发人员的错。 这是开发人员和工作人员之间所有关口的错。**

    *   **绝对不允许人为错误传播到人外。** 查看允许部署损坏的代码的过程。

## 无罪的岗位形态

*   避免责备文化至关重要。

*   研究表明,大多数事件是人为错误引起的。

*   **最好通过了解实际发生的事件来解决事件。** 不知道发生了什么的最好方法? 通过寻找责任人来揭开每一个事件。

*   人们真的很擅长隐藏,并确保没有线索,并确保您实际上不知道发生了什么。 试图找到责任,只会使您的工作更加困难。

*   在 Google 谁搞砸了谁写的事后验尸。 这样可以避免命名和遮挡。 使他们有能力纠正错误。 促成失败的每个人都应尽可能诚实地参与进来,并写下您如何陷入困境。

*   已在全体会议上给予拆除该站点的奖金,因为他们立即拥有该站点,因此他们拥有了该站点。 他们上了 IRC,并将其回滚。 他们说出来并如此迅速地照顾好他们,便获得了奖金。

*   无赖并不意味着没有名称和细节。 这意味着我们不会因为事情出错的原因而选择别人。 不应发生诸如断电之类的事情,应予以解雇。

*   深度防御

    *   由于策略是纵深防御,因此事后评估模板将操作分为预防,检测和缓解措施。

    *   **我们希望防止中断,我们希望更快地检测到它们,并希望减轻影响。**

    *   如果类似的情况再次发生,它将不会传播到很远,持续太久或影响那么多客户。

## 分页的无聊哲学

*   团队喜欢看什么样的页面? 新的和有趣的。

*   您知道如何解决的页面很无聊。 您应该创建一个机器人来解决该问题。

*   Google 发明了许多机器人。 他们不喜欢无聊。

*   如果您可以写下修复它的步骤,那么您可能可以编写自动化来修复它。

*   不要做机器人可以为您做的事情。

*   构建机器人的结果是,理想情况下,每个页面都是真正的新页面,因此不会感到无聊。 甚至经验丰富的工程师也可能在每次寻呼机关闭时都看到一些新内容。

*   **这是哲学的根本变化。 如果一切正常,重复的事件很少,则意味着您在调试系统时不会像以前那样沉迷于此。**

## 需要更强大的调试工具

*   **如果所有问题都是新问题,则意味着您需要更强大的调试工具来查找问题。**

*   文本日志不是调试工具。 如果您不知道要查找的内容,则在日志文件中查找模式的标准调试无法扩展。 使用 GCP 大小的平台,您需要浏览多少个外观才能找到失败的外观?

*   Google 严重依赖各种可视化工具来解决不熟悉的问题并尽快恢复服务。

*   绘图工具:石墨,InfluxDB + Grafana,OpenTSDB。

    *   这些和其他提到的工具不是 Google 使用的工具,因此不建议使用,但它们是有用工具的开放源代码示例。

    *   很高兴看到正在发生的一切。 Google 拥有数十亿亿个流程,因此您需要汇总视图才能理解事物。

    *   **Google 在其二进制文件中放置了很多工具。** 在新情况下,您并不总是知道您要寻找的东西。

*   创建一个框架,使开发人员可以轻松地插入监视框架。

*   大量存储空间专门用于存储监视数据。

    *   **这个想法是您不想在中断期间进行故障排除。 中断仅与恢复服务有关。**

    *   故障排除是您稍后醒来时要执行的操作。 开发人员通常具有很深的系统知识,因此经常参与故障排除过程。

    *   历史数据必须可用,以便故障恢复后可以进行故障排除。 恢复不会导致中断监视数据丢失。

    *   这种方法可以使停机时间尽可能短,同时可以在以后解决问题。

*   事件绘图-对于关联事件非常有用。

    *   充分利用人类的模式匹配能力,很难编写机器人来做到这一点。

    *   给出了一个图表示例,其中每行是一个数据中心,列是时间,单元格中的颜色是事件类型。

    *   这可以帮助您找到不是单个事件的模式,例如导致级联故障的软件推出,或者一起重复出现的错误簇,或者如果您看到延迟尖峰之后立即出现错误尖峰 重复一遍。 这些都将有助于确定问题的根本原因。

*   可视化过程跟踪-有时您需要深入到过程级别以识别性能问题。

    *   开源选项不多:Performance Co-Pilot + vector。

    *   Google 有一个非常复杂的框架,可将示例查询拉入存储并提供完整的跟踪记录。

    *   视觉工具的优点是很难理解时间戳。 可视化工具使您可以更轻松地折叠,展开和比较事件。

*   网络流量和容量

    *   开源选项:仙人掌,天文台和 Nagios

    *   事实证明,很多存储缓慢的问题实际上是网络问题。

    *   如果您正在查看存储系统,但无法弄清为什么它对网络的访问速度很慢。

    *   您需要一个工具来快速查看网络状态。 哪些链接超载? 您看到多少个包错误? 链接断开了吗?

*   日志文件-当所有其他失败时

    *   开源:ElasticSearch + Logstash(+ Kibana)

    *   您不想浏览日志文件。 您需要一个具有更多 SQL 之类的查询的系统,以便您可以挖掘日志。

    *   日志应易于使用且易于理解。

## Stackdriver 错误报告

*   如果您想看一下 SRE 所拥有的那种工具的例子,那么请看 [Google Stackdriver 错误报告](https://cloud.google.com/error-reporting/)

    *   这是他们能够用于服务的内部工具。

    *   通过分析堆栈跟踪将分组错误并进行重复数据删除

    *   系统了解所使用的通用框架并相应地对错误进行分组。

*   该计划将做更多。 Google 内部拥有一套广泛的工具,他们希望向云客户提供这些工具。

## 相关文章 [

*   [在 HackerNews](https://news.ycombinator.com/item?id=12116121) 上/ [在 Reddit](https://www.reddit.com/r/programming/comments/4tg31p/how_does_google_do_planetscale_engineering_for_a/)
*   图书:[网站可靠性工程:Google 如何运行生产系统](https://www.amazon.com/Site-Reliability-Engineering-Production-Systems-ebook/dp/B01DCPXKZ6)。 它是由从事实际 SRE 工作的实际 Google SRE 编写的,是作者 500 年综合经验的结果。
*   [大规模计算,或者说 Google 如何扭曲我的大脑](http://matt-welsh.blogspot.com/2010/10/computing-at-scale-or-how-google-has.html)
*   [网站可靠性工程师-使 Google 保持 24/7 全天候运行](http://transcriptvids.com/v2/yXI7r0_J29M.html)
*   [服务水平和错误预算](https://www.usenix.org/conference/srecon16/program/presentation/jones)
*   [SREcon](https://www.usenix.org/conference/srecon16) 。 会议视频[可用](https://www.usenix.org/conference/srecon16/program)。 看起来内容很多。
*   [小组:谁/什么是 SRE?](https://www.usenix.org/conference/srecon16/program/presentation/definition-of-sre-panel)
*   [策略:规划停电的 Google 样式](http://highscalability.com/blog/2010/3/5/strategy-planning-for-a-power-outage-google-style.html)
*   [Google 如何备份互联网以及 EB 级其他数据](http://highscalability.com/blog/2014/2/3/how-google-backs-up-the-internet-along-with-exabytes-of-othe.html)
*   [什么是“网站可靠性工程”?](https://landing.google.com/sre/interview/ben-treynor.html)
*   [成为 Google 的网站可靠性工程师(SRE)感觉如何?](https://www.quora.com/What-is-it-like-to-be-a-Site-Reliability-Engineer-SRE-at-Google)
*   [我的警惕](https://docs.google.com/document/d/199PqyG3UsyXlwieHaqbGiWVa8eMWi8zzAn0YfcApr8Q/preview#)的哲学,作者:Rob Ewaschuk,Google SRE
*   [这是 Google 确保(几乎)永不衰败的方式](http://www.wired.com/2016/04/google-ensures-services-almost-never-go/)

FWIW,Stack Driver 并不是他们能够用于服务的内部工具; 这是 Google 购买的 SaaS 创业公司。

https://techcrunch.com/2014/05/07/google-acquires-cloud-monitoring-service-stackdriver/