DevOps:软件架构师行动指南
译者序前言第一部分 背 景第1章 DevOps是什么 …… 21.1 概述 …… 21.1.1 定义DevOps …… 21.1.2 DevOps实践 …… 31.1.3 持续部署的例子:IMVU …… 51.2 为什么是DevOps …… 51.2.1 发布过程 …… 51.2.2 配合不佳的原因 …… 71.2.3 运维人员能力有限 …… 71.3 DevOps视角 …… 81.3.1 自动化 …… 81.3.2 开发团队的职责 …… 91.4 DevOps与敏捷 …… 91.5 团队结构 …… 101.5.1 团队规模 …… 101.5.2 团队角色 …… 101.6 协作 …… 131.6.1 协作的形式 …… 131.6.2 团队协作 …… 141.6.3 跨团队协作 …… 141.7 障碍 …… 151.7.1 文化及组织类型 …… 151.7.2 部门类型 …… 161.7.3 筒仓思维方式(Silo Mentality) …… 17…
查看完整
查看完整
作者简介: 伦恩·拜斯(Len Bass) 澳大利亚NICTA的高级首席研究员。他曾在卡内基梅隆大学软件工程研究所工作25年,有超过50年的软件开发和研究经验。他是两本软件架构方面获奖图书的合作者(《Software Architecture in Practice, Third Edition》和《Documenting Software Architectures:Views and Beyond,Second Edition》),他还与人合作出版或发表了数篇计算机科学与软件工程领域的其他书籍和论文。
英戈·韦伯(Ingo Weber) 澳大利亚NICTA软件系统研究组的高级研究员,也是新南威尔士大学计算机科学与工程系的兼职高级讲师。他的研究领域包括云计算、DevOps、业务过程管理以及人工智能。
朱黎明(Liming Zhu) 澳大利亚NICTA一个研究小组的负责人…
查看完整
英戈·韦伯(Ingo Weber) 澳大利亚NICTA软件系统研究组的高级研究员,也是新南威尔士大学计算机科学与工程系的兼职高级讲师。他的研究领域包括云计算、DevOps、业务过程管理以及人工智能。
朱黎明(Liming Zhu) 澳大利亚NICTA一个研究小组的负责人…
查看完整
《DevOps:软件架构师行动指南》从软件架构师视角讲解了引入DevOps实践所需要拥有的技术能力,涵盖运维、部署流水线、监控、安全与审计以及质量关注。通过三个经典案例研究,讲解在不同场景下应用DevOps实践的方法,对于想应用DevOps实践的组织提供切实的指导。 全书共五部分。第一部分(第1~3章)讨论DevOps的背景,包括DevOps的目标和期望使用DevOps解决的问题、云、运维等。第二部分(第4~6章)介绍部署流水线,从功能性视角介绍部署实践的内容,涵盖微服务架构风格、构建和测试过程、工具链,以及具体的部署问题。第三部分(第7~10章)介绍横切关注点,讨论了计算监控、实时测试、安全与安全审计,以及部署流水线的性能、可靠性、可修改性等。还介绍了业务关注点,包括为引进DevOps所需要准备的业务计划的组成元素,以及如何进行论证、推出和测量业务计划。第四部分(第11~13章)描述3个案例研究:为了实现业务连续性如何维护两个数据中心,管理一个持…
查看完整
查看完整
译者序前言第一部分 背 景第1章 DevOps是什么 …… 21.1 概述 …… 21.1.1 定义DevOps …… 21.1.2 DevOps实践 …… 31.1.3 持续部署的例子:IMVU …… 51.2 为什么是DevOps …… 51.2.1 发布过程 …… 51.2.2 配合不佳的原因 …… 71.2.3 运维人员能力有限 …… 71.3 DevOps视角 …… 81.3.1 自动化 …… 81.3.2 开发团队的职责 …… 91.4 DevOps与敏捷 …… 91.5 团队结构 …… 101.5.1 团队规模 …… 101.5.2 团队角色 …… 101.6 协作 …… 131.6.1 协作的形式 …… 131.6.2 团队协作 …… 141.6.3 跨团队协作 …… 141.7 障碍 …… 151.7.1 文化及组织类型 …… 151.7.2 部门类型 …… 161.7.3 筒仓思维方式(Silo Mentality) …… 171.7.4 工具支持 …… 171.7.5 人员问题 …… 171.8 小结 …… 181.9 更多阅读材料 …… 18第2章 云即平台 …… 202.1 概述 …… 202.2 云的特性 …… 212.2.1 虚拟化 …… 222.2.2 IP和域名系统管理 …… 232.2.3 平台即服务 …… 252.2.4 分布式环境 …… 252.3 独特的云特性对DevOps的影响 …… 302.3.1 环境 …… 302.3.2 轻松创建虚拟机 …… 312.3.3 数据考量 …… 312.4 小结 …… 322.5 更多阅读材料 …… 33第3章 运维 …… 343.1 概述 …… 343.2 运维服务 …… 343.2.1 供给硬件 …… 343.2.2 供给软件 …… 353.2.3 IT功能 …… 363.2.4 服务级别协议 …… 363.2.5 容量规划 …… 363.2.6 业务连续性和安全 …… 373.2.7 服务策略 …… 383.2.8 服务设计 …… 393.2.9 服务移交 …… 393.2.10 服务运维 …… 403.2.11 服务运维概念 …… 403.3 服务运维功能 …… 413.4 持续服务改进 …… 423.5 运维和DevOps …… 433.6 小结 …… 443.7 更多阅读材料 …… 44第二部分 部署流水线第4章 整体架构 …… 484.1 DevOps实践是否需要架构调整 …… 484.2 架构结构总览 …… 494.2.1 协作模式 …… 504.2.2 资源管理 …… 514.2.3 架构元素之间的映射 …… 524.3 微服务架构的质量 …… 524.3.1 可靠性 …… 534.3.2 可修改性 …… 544.4 团队的亚马逊规则 …… 554.5 现有系统的微服务方案 …… 564.6 小结 …… 564.7 更多阅读材料 …… 57第5章 构建与测试 …… 585.1 概述 …… 585.2 在部署流水线中移动系统 …… 595.2.1 可追溯性 …… 595.2.2 环境 …… 605.3 横切关注点 …… 615.4 开发及提交前测试 …… 635.4.1 版本控制与分支 …… 635.4.2 功能开关 …… 655.4.3 配置参数 …… 665.4.4 在开发和提交前测试中的测试 …… 675.5 构建与集成测试 …… 675.5.1 构建脚本 …… 675.5.2 打包 …… 685.5.3 持续集成与构建状态 …… 695.5.4 集成测试 …… 705.6 用户验收测试/预发布/性能测试 …… 705.7 生产环境 …… 715.7.1 早期发布测试 …… 715.7.2 错误检测 …… 725.7.3 现场测试 …… 725.8 事件 …… 735.9 小结 …… 735.10 更多阅读材料 …… 74第6章 部署 …… 756.1 概述 …… 756.2 部署管理的策略 …… 766.2.1 蓝/绿部署 …… 766.2.2 滚动升级 …… 776.3 逻辑一致性 …… 786.3.1 相同服务的多个版本同时存在 …… 786.3.2 兼容数据库中保存的数据 …… 816.4 打包 …… 826.5 多环境部署 …… 846.6 部分部署 …… 866.6.1 金丝雀测试 …… 866.6.2 A/B测试 …… 876.7 回滚 …… 876.8 工具 …… 896.9 小结 …… 906.10 更多阅读材料 …… 90第三部分 横切关注点第7章 监控 …… 947.1 概述 …… 947.2 监控什么 …… 957.2.1 故障检测 …… 967.2.2 性能下降检测 …… 967.2.3 容量规划 …… 977.2.4 用户交互 …… 987.2.5 入侵检测 …… 997.3 如何监控 …… 997.3.1 基于代理的监控和无代理的监控 …… 1017.3.2 监控运维活动 …… 1027.3.3 收集和存储 …… 1027.4 什么时候变更监控配置 …… 1037.5 解释监控数据 …… 1037.5.1 日志 …… 1047.5.2 绘图和展示 …… 1057.5.3 警报和警告 …… 1057.5.4 诊断和反应 …… 1067.5.5 监控DevOps过程 …… 1067.6 挑战 …… 1077.6.1 挑战1:持续变更下的监控 …… 1077.6.2 挑战2:自下向上与自上向下和在云中的监控 …… 1087.6.3 挑战3:监控微服务架构 …… 1097.6.4 挑战4:处理大容量的分布式(日志)数据 …… 1097.7 工具 …… 1097.8 从监控数据中诊断出异常——Platformer.com的案例 …… 1107.8.1 背景 …… 1117.8.2 数据收集 …… 1127.8.3 检测异常 …… 1127.8.4 思考 …… 1137.9 小结 …… 1137.10 更多阅读材料 …… 114第8章 安全与安全审计 …… 1158.1 安全是什么 …… 1158.2 威胁 …… 1178.3 需要保护的资源 …… 1188.4 安全角色和活动 …… 1208.5 身份管理 …… 1228.5.1 认证 …… 1238.5.2 授权 …… 1258.6 访问控制 …… 1268.6.1 阻止访问 …… 1278.6.2 谁负责预防控制 …… 1298.7 检测、审计和拒绝服务 …… 1298.8 开发 …… 1308.9 审计者 …… 1308.10 应用设计考虑 …… 1318.11 部署流水线设计考虑 …… 1328.12 小结 …… 1338.13 更多阅读材料 …… 134第9章 其他非功能需求 …… 1359.1 概述 …… 1359.2 可重复性 …… 1369.2.1 在恰当的层级上定义和执行过程 …… 1369.2.2 版本控制所有事物 …… 1389.3 性能 …… 1399.3.1 测量重要的事物 …… 1399.3.2 提高资源使用率 …… 1409.4 可靠性 …… 1419.4.1 理解不同服务的可靠性特性 …… 1419.4.2 早期检测和修复错误 …… 1429.5 可恢复性 …… 1429.6 互操作性 …… 1439.6.1 注意接口的互操作性 …… 1439.6.2 理解现有的数据模型 …… 1439.7 可测试性 …… 1449.8 可修改性 …… 1459.8.1 一个工具内的修改 …… 1459.8.2 工具之间交互行为的修改 …… 1469.9 小结 …… 1469.10 更多阅读材料 …… 147第10章 业务关注点 …… 14810.1 概述 …… 14810.2 业务案例 …… 14810.2.1 问题和解决问题所带来的好处 …… 14910.2.2 成本 …… 14910.2.3 干系人影响 …… 15010.2.4 风险及其减缓 …… 15110.2.5 推出计划 …… 15310.2.6 成功标准 …… 15410.3 度量和对DevOps实践的合规性 …… 15510.3.1 测量DevOps实践的成功度 …… 15510.3.2 测量对DevOps实践的合规性 …… 15610.3.3 测量干系人的满意度 …… 15710.4 Dev和Ops之间的交互点 …… 15710.4.1 许可 …… 15710.4.2 事故处理 …… 15810.5 小结 …… 15910.6 更多阅读材料 …… 159第四部分 案 例 研 究第11章 支持多数据中心 …… 16211.1 概述 …… 16211.2 当前的情况 …… 16311.3 业务逻辑和Web层 …… 16311.3.1 应用逻辑 …… 16311.3.2 基础设施 …… 16411.3.3 增加一个应用 …… 16411.3.4 发现基础设施 …… 16511.4 数据库层 …… 16711.4.1 事务数据 …… 16711.4.2 基础设施支持 …… 16811.4.3 会话数据 …… 16811.5 其他基础设施工具 …… 16811.5.1 gem存储库服务器 …… 16911.5.2 Elasticsearch …… 16911.5.3 域名系统 …… 16911.6 数据中心切换 …… 17011.6.1 受控切换步骤 …… 17011.6.2 非受控切换 …… 17411.6.3 定义和自动化切换步骤 …… 17511.7 测试 …… 17711.7.1 数据中心切换应用程序 …… 17711.7.2 基础设施测试 …… 17711.7.3 持续交付流水线 …… 17711.8 小结 …… 17811.9 更多阅读材料 …… 179第12章 实施企业的持续部署流水线 …… 18012.1 概述 …… 18012.2 组织背景 …… 18012.3 持续部署流水线 …… 18212.3.1 持续部署流水线工具 …… 18312.3.2 使用AWS CloudFormation的环境定义 …… 18412.3.3 标准化的应用程序生命周期概览及其使用 …… 18612.3.4 标准化的应用程序生命周期阶段 …… 18812.3.5 管理复杂的应用程序和流水线状态 …… 19412.3.6 管理持久化 …… 19612.4 让安全成为持续部署流水线的基础 …… 19612.4.1 使用Amazon CloudFormation分离职责 …… 19612.4.2 身份和访问管理 …… 19712.5 高级概念 …… 19812.5.1 最小化生产环境和非生产环境之间的偏移 …… 19812.5.2 解决供应商的限制 …… 19812.5.3 厂商锁定 …… 19912.5.4 新的AWS内置服务的展望 …… 19912.6 小结 …… 19912.7 更多阅读材料 …… 200第13章 迁移到微服务 …… 20213.1 Atlassian概述 …… 20213.2 构建部署微服务的平台 …… 20313.3 BlobStore:一个微服务例子 …… 20613.3.1 架构 …… 20613.3.2 通过纯函数式架构和编程实现安全性和性能 …… 20713.3.3 解决“非功能需求” …… 21013.4 开发过程 …… 21013.4.1 开发人员和支持 …… 21113.4.2 构建和部署流水线 …… 21213.4.3 客户应用的生产环境的零停机时间路径 …… 21413.5 BlobStore演进 …… 21513.6 小结 …… 21913.7 更多阅读材料 …… 219第五部分 走 向 未 来第14章 作为过程的运维 …… 22214.1 概述 …… 22214.2 动机和概览 …… 22314.3 离线活动 …… 22414.4 在线活动 …… 22714.4.1 错误检测 …… 22714.4.2 错误恢复 …… 22914.5 错误诊断 …… 22914.6 监控 …… 23114.7 小结 …… 23114.8 更多阅读材料 …… 231第15章 DevOps的未来 …… 23215.1 概述 …… 23215.2 组织问题 …… 23315.2.1 DevOps活动中可能涉及的其他组 …… 23315.2.2 所有关系和重组 …… 23415.2.3 授权与控制 …… 23415.3 过程问题 …… 23515.3.1 厂商锁定和标准 …… 23515.3.2 计费模型 …… 23515.3.3 变更的速度 …… 23615.4 技术问题 …… 23715.4.1 持续部署流水线概念 …… 23715.4.2 在持续部署流水线中获得质量 …… 23915.4.3 实现 …… 23915.5 错误报告和修复 …… 24015.6 结束语 …… 24015.7 更多阅读材料 …… 240参考文献 …… 241
^ 收 起
^ 收 起
作者简介: 伦恩·拜斯(Len Bass) 澳大利亚NICTA的高级首席研究员。他曾在卡内基梅隆大学软件工程研究所工作25年,有超过50年的软件开发和研究经验。他是两本软件架构方面获奖图书的合作者(《Software Architecture in Practice, Third Edition》和《Documenting Software Architectures:Views and Beyond,Second Edition》),他还与人合作出版或发表了数篇计算机科学与软件工程领域的其他书籍和论文。
英戈·韦伯(Ingo Weber) 澳大利亚NICTA软件系统研究组的高级研究员,也是新南威尔士大学计算机科学与工程系的兼职高级讲师。他的研究领域包括云计算、DevOps、业务过程管理以及人工智能。
朱黎明(Liming Zhu) 澳大利亚NICTA一个研究小组的负责人和首席研究员。他拥有新南威尔士大学和悉尼大学的联合职位。曾就职于数个在软件领域具有领先地位的技术公司。
译者简介: 胥峰 资深运维专家,有10年运维经验,在业界颇具威望和影响力。2011年加入盛大游戏,工作至今,曾参与盛大游戏多款大型端游和手游的运维,主导 运维自动化平台的功能设计和实施。通过公众号“运维技术实践”发布 “网络分析技术实践”系列主题技术文章,引发万人阅读转发。拥有工信部认证高级信息系统项目管理师资格。
任发科目前担任融数数据研发总监,曾任职唯品会、会唐网、亚*逊、ThoughtWorks,有十余年软件开发、架构和管理经验。曾参与多个电商相关系统的研发工作,近年主要从事DevOps工具链的设计与实现,大数据平台的组建,以及高效研发团队的组建与管理。
^ 收 起
英戈·韦伯(Ingo Weber) 澳大利亚NICTA软件系统研究组的高级研究员,也是新南威尔士大学计算机科学与工程系的兼职高级讲师。他的研究领域包括云计算、DevOps、业务过程管理以及人工智能。
朱黎明(Liming Zhu) 澳大利亚NICTA一个研究小组的负责人和首席研究员。他拥有新南威尔士大学和悉尼大学的联合职位。曾就职于数个在软件领域具有领先地位的技术公司。
译者简介: 胥峰 资深运维专家,有10年运维经验,在业界颇具威望和影响力。2011年加入盛大游戏,工作至今,曾参与盛大游戏多款大型端游和手游的运维,主导 运维自动化平台的功能设计和实施。通过公众号“运维技术实践”发布 “网络分析技术实践”系列主题技术文章,引发万人阅读转发。拥有工信部认证高级信息系统项目管理师资格。
任发科目前担任融数数据研发总监,曾任职唯品会、会唐网、亚*逊、ThoughtWorks,有十余年软件开发、架构和管理经验。曾参与多个电商相关系统的研发工作,近年主要从事DevOps工具链的设计与实现,大数据平台的组建,以及高效研发团队的组建与管理。
^ 收 起
《DevOps:软件架构师行动指南》从软件架构师视角讲解了引入DevOps实践所需要拥有的技术能力,涵盖运维、部署流水线、监控、安全与审计以及质量关注。通过三个经典案例研究,讲解在不同场景下应用DevOps实践的方法,对于想应用DevOps实践的组织提供切实的指导。 全书共五部分。第一部分(第1~3章)讨论DevOps的背景,包括DevOps的目标和期望使用DevOps解决的问题、云、运维等。第二部分(第4~6章)介绍部署流水线,从功能性视角介绍部署实践的内容,涵盖微服务架构风格、构建和测试过程、工具链,以及具体的部署问题。第三部分(第7~10章)介绍横切关注点,讨论了计算监控、实时测试、安全与安全审计,以及部署流水线的性能、可靠性、可修改性等。还介绍了业务关注点,包括为引进DevOps所需要准备的业务计划的组成元素,以及如何进行论证、推出和测量业务计划。第四部分(第11~13章)描述3个案例研究:为了实现业务连续性如何维护两个数据中心,管理一个持续部署流水线,一个组织如何迁移到微服务架构上。第五部分(第14~15章)设想evOps的未来,介绍了目前的研究以及如何基于把运维视作一系列过程来进行,并给出了3~5年内DevOps将如何发展的预测。
^ 收 起
^ 收 起
比价列表价格走势