• Kubernetes in Action中文版
  • Kubernetes in Action中文版
  • Kubernetes in Action中文版
  • Kubernetes in Action中文版
  • Kubernetes in Action中文版
  • Kubernetes in Action中文版
21年品牌 40万+商家 超1.5亿件商品

Kubernetes in Action中文版

正版保障 假一赔十 电子发票

95.76 6.5折 148 全新

库存12件

四川成都
认证卖家担保交易快速发货售后保障

作者(美)马尔科·卢克沙(Marko Luksa)

出版社电子工业出版社

ISBN9787121349959

出版时间2019-01

装帧平装

开本16开

定价148元

货号1201809309

上书时间2024-11-09

瀚东书店

已实名 已认证 进店 收藏店铺

   商品详情   

品相描述:全新
商品描述
前言

 

推 荐 序

 

2013 年,Docker 问世,由于其简练易用的使用范式,极大降低了容器技术的使用门槛,引爆了容器技术,一场轰轰烈烈的由容器带来的新计算革命开始了。

 

2014 年,预见到了容器带来的革命性变化,七牛内部成立了一个新项目——QCOS,全称为 Qiniu Cloud Operating System(也可以理解为 Qiniu Cluster OperatingSystem),目标是实现一个数据中心操作系统,让开发人员使用数据中心如同使用一台机器一样容易。在当时,Kubernetes 项目也刚刚开始,还在规格设计阶段。我们通读了 Kubernetes 的设计,决定自己干。这是一个非常疯狂的想法。促使我们决定自己干的原因有两点 :一是我们存储也自己干,而且干成了,所以计算自己干,也不无成功的可能 ;二是 Kubernetes 刚开始,一切如果跟随 Kubernetes,那么我们做起事情来肯定束手束脚,没办法按照商业公司的推进速度来推进。

 

但是做着做着我们就发现,计算不像存储,计算问题是一个非常开放性的问题。而以容器为核心的计算系统,其复杂性也不同于以虚拟机(VM)为代表的计算系统,因为虚拟机(VM)是以虚拟一台机器为边界的,其问题域同样比较闭合。但是容器计算就是要打破机器的边界,让计算力在数据中心内自由调度。这个问题域涉及面非常广,除了常规的计算力调度、负载均衡、部署升级、服务发现、日志与监控,这些东西都要以全新的方式来解决。

 

实际上给数据中心做一个操作系统并不是什么新想法。20 世纪 80 年代中期,贝尔实验室就开启了一个名为 Plan9 的操作系统项目,目的就是做一个数据中心操作系统。参与这个操作系统的名单都大名鼎鼎 :Rob Pike、Ken Thompson,等等。你没看错,就是今天创建了 Go 语言的那帮人。他们在 Plan9 项目解散后被 Google抢了过去,换了一个思路继续做数据中心操作系统 —— 从面向数据中心的语言开始:Go 语言就这样诞生了。而随着 Go 语言的流行,Docker、Kubernetes 接连诞生,继续续写着数据中心操作系统的梦想。

 

Kubernetes 诞生之初,虽然嘴里衔着 Google Borg 系统的金钥匙,但是同期竞争的项目还是比较多的,除了七牛自己内部发起的 QCOS 外,比较知名的还有 Docker Swam 和 Mesos。但是到了 2016 年,这场竞争越来越趋于 Kubernetes 一统天下。七牛内部 QCOS 项目也放弃了自研,将方向转向了 Kubernetes 阵营。

 

QCOS 项目对七牛有着特殊的意义,它是七牛业务多元化的开始。在此之前,七牛秉承专注做好一件事情,着眼于对象存储一个点,从单点切入,把单点做到极致的思路,获得了极佳的口碑,大量的移动互联网应用都选择了七牛作为它们的图片和视频托管的云服务提供商。选择做 QCOS,实际上是我们在打第二个根据地时,选择了一条极其艰难的道路。

 

今天我们 QCOS 团队(内部已更名为 KIRK 团队)发起了 Kubernetes in Action一书的翻译,他们邀请我给译本作序,我脑子里不由自主想起了这段历史。选择基于 Kubernetes,是我们从商业上来说的务实选择,但是它并不代表放弃自主研发,只是把梦想暂时封存在心里。中国古话说,师夷长技以制夷,别人的好东西我们是要学习的,学好了我们才能完成从模仿到超越的过程。

 

Kubernetes 的背后,是一场新计算革命,是真正的云计算 2.0,我们期待更多有想法的开发者能够学习 Kubernetes,能够加入这场计算革命。也欢迎大家加入七牛。

 

是为序。

 

许式伟 七牛云 CEO

 

 

 

译 者 序

 

早在 2011 年创业初期,七牛就决定使用 GoLang 作为主要开发语言,那时距离 GoLang 1.0 的正式发布还有将近一年的时间。当时我们就断定,在分布式时代,GoLang 这种语言必定会大放异彩。今天,七牛的绝大多数线上服务都是用 GoLang实现的,Golang 帮助我们以*的效率实现应用,快速响应客户需求。现在,我们也很幸运地看到当前*热门的开源项目如 Docker、Kubernetes 等,也都是基于GoLang 来实现的。

 

就像早期拥抱 GoLang 一样,七牛也是 Docker 和 Kubernetes 技术的坚定拥抱者和践行者。早在 2014 年,我们就基于 Docker 自研了一套容器集群管理系统,用于图片、音视频转码应用实例的资源调度,这套系统在线上运行了好几年,现在正逐渐被 Kubernetes 替代。

 

Docker 和 Kubernetes 的出现,让我们发现了构建数据中心操作系统(DCOS)的可能性。Docker 的轻量级、Kubernetes 的灵活性和开放性,能让我们以 API 调用的方式来交付计算力(包括 CPU、内存、网络、磁盘等),能让业务应用摆脱传统资源交付方式和既往运维手段的束缚,更快捷地得到部署、升级和管理,业务迭代速度大大加快,资源利用率大幅提高。

 

早在几年前,我们在七牛就成立了专门的容器云团队,致力于打造更健壮、更易用的容器集群调度管理系统。现在,我们在七牛内部全面推广和应用 Kubernetes,不仅把无状态服务运行在 Kubernetes 中,也把有状态服务比如数据库运行在Kubernetes 中,正如使用 GoLang 提高了我们的开发效率一样,使用 Kubernetes 大大提高了我们的部署和运维效率。

 

在七牛,我们坚定地认为,Kubernetes 会成为下一个 Linux,但是管理的不再是单台机器,而是以 DCOS 的方式来管理整个数据中心。熟练地掌握和使用Kubernetes,将成为每个前后端工程师的技能,Kubernetes 将成为发布前后端服务的标准途径。

 

这本书的翻译,我们集中了七牛容器云团队,以及其他七牛内部热心志愿者的力量,针对翻译的每个术语我们认真推敲,尽*可能达到“信”“达”“雅”的程度。鉴于水平有限,难免有纰漏,请读者谅解。

 

希望这本书能带领你进入 Kubernetes 的世界。

 

参与本书翻译的七牛容器团队成员有 :卢兴铭(致谢词、第 1 章)、李雪瓅(第2 章)、路涛(第 3 章)、孙讷敏(第 4 章)、刘岩(第 5 章)、孙毅飞(第 6 章)、林培裕(第 7 章)、周玉壁(第 8 章)、陈凯俊(第 9 章)、杨冠军(第 10 章)、张钦尧 (第11 章)、况永巧 (第 12 章)、易弢(第 13 章)、王浩宇(第 14 章)、王雪瑞(第 15 章)、屈啸(第 16 章)、金鑫鑫(第 17 章)、陈忠杰(第 18 章)。由袁晓沛任翻译组组长,由李雪瓅、马力、冯义勇负责审校。

 

袁晓沛 容器计算部技术总监

 

 

  

在 Red Hat 工作了几年之后,2014 年底,我被分配到一个叫 Cloud Enablement的新团队。我们的任务是将公司的中间件系列产品引入基于 Kubernetes 开发的OpenShift 容器平台。当时,Kubernetes 还在初始的 1.0 版本中,甚至还没有正式发布。

 

我们团队必须尽快了解 Kubernetes 的细节,以便能够充分利用 Kubernetes 的一切,为软件开发设定正确的方向。当遇到问题时,很难判断是我们出错了,还是仅仅是碰到了一个 Kubernetes 的 bug。

 

从那以后,Kubernetes 有了长足的发展,我对它的理解也有了很大的提升。当我*次使用它的时候,大多数人甚至从未听说过 Kubernetes。现在,几乎每个软件工程师都知道它,Kuberntes 已经成为在云上和内部数据中心运行应用程序的增长*快和使用*广泛的方式之一。

 

在使用 Kubernetes 的*个月,我写了一篇包含两部分的博客文章,介绍如何在 OpenShift/Kubernetes 中运行 JBoss WildFly 应用服务集群。当时,我从未想过一篇简单的博客文章会让曼宁出版社的人联系我,询问我是否愿意写一本关于Kubernetes 的书。当然,我不能拒绝这样的提议,尽管我确信他们也会联系其他人,甚至*终会选择其他人。

 

经过一年半的写作和研究,完成了本书,这是一次很棒的经历。写一本关于一项技术的书是比使用更好的了解它的方法。随着我对 Kubernetes 了解的深入,以及Kubernetes 本身的不断发展,我不断地回到之前写完的章节,添加更多的信息。我是一个完美主义者,所以永远不会对这本书感到*满意,但我很高兴听到 MEAP(Manning Early Access Program)的许多读者觉得它是一本很好的学习 Kubernetes 的指南。

 

我的目的是让读者了解技术本身,并教会他们如何使用工具有效地在Kubernetes 集群中开发和部署应用程序。本书的重点不在如何建立和维护一个高可用的 Kubernetes 集群,但本书的*后一部分告诉读者这样一个集群应该包含什么,这能让大家很容易地理解处理这个问题的额外资源。

 

希望你能享受阅读此书,并且让你学到如何能够充分利用 Kubernetes 系统的强大之处。

 

 

 

 

 

关于本书

 

本书旨在让你能够熟练使用 Kubernetes。它介绍了在 Kubernetes 中有效地开发和运行应用所需的几乎所有概念。

 

在深入研究 Kubernetes 之前,本书概述了 Docker 等容器技术,包括如何构建容器,以便即使以前没有使用过这些技术的读者也可以使用它们。然后,它会慢慢带你从基本概念到实现原理了解大部分的 Kubernetes 知识。

 

本书适合谁

 

本书主要关注应用开发人员,但也从操作的角度概述了应用的管理。它适合任何对在多服务器上运行和管理容器化应用感兴趣的人。

 

对于希望学习容器技术以及大规模的容器编排的人,无论是初学者还是高级软件工程师都将得到在 Kubernetes 环境中开发、容器化和运行应用所需的专业知识。

 

阅读本书不需要预先了解容器或 Kubernetes 技术。本书以渐进的方式展开主题,不会使用让非专家开发者难以理解的应用源代码。

 

读者至少应该具备编程、计算机网络和运行 Linux 基本命令的基础知识,并了解常用的计算机协议,如 HTTP 协议。

 

 

 

本书的组织方式 :路线图

 

本书分为三个部分,涵盖 18 个章节。

 

*部分简要地介绍 Docker 和 Kubernetes、如何设置 Kubernetes 集群,以及如何在集群中运行一个简单的应用。它包括两章 :

 

第 1 章解释了什么是 Kubernetes、Kubernetes 的起源,以及它如何帮助解决当今大规模应用管理的问题。

 

第 2 章是关于如何构建容器镜像并在 Kubernetes 集群中运行的实践教程。还解释了如何运行本地单节点 Kubernetes 集群,以及在云上运行适当的多节点集群。

 

第二部分介绍了在 Kubernetes 中运行应用必须理解的关键概念。本章内容如下:

 

第 3 章介绍了 Kubernetes 的基本构建模块——pod,并解释了如何通过标签组织 pod 和其他 Kubernetes 对象。

 

第 4 章将向你介绍 Kubernetes 如何通过自动重启容器来保持应用程序的健康。还展示了如何正确地运行托管的 pod,水平伸缩它们,使它们能够抵抗集群节点的故障,并在未来或定期运行它们。

 

第 5 章介绍了 pod 如何向运行在集群内外的客户端暴露它们提供的服务,还展示了运行在集群中的 pod 是如何发现和访问集群内外的服务的。

 

第 6 章解释了在同一个 pod 中运行的多个容器如何共享文件,以及如何管理持久化存储并使得 pod 可以访问。

 

第 7 章介绍了如何将配置数据和敏感信息(如凭据)传递给运行在 pod 中的应用。

 

第 8 章描述了应用如何获得正在运行的 Kubernetes 环境的信息,以及如何通过与 Kubernetes 通信来更改集群的状态。

 

第 9 章介绍了 Deployment 的概念,并解释了在 Kubernetes 环境中运行和更新应用的正确方法。

 

第 10 章介绍了一种运行需要稳定的标识和状态的有状态应用的专门方法。

 

第三部分深入研究了 Kubernetes 集群的内部,介绍了一些额外的概念,并从更高的角度回顾了在前两部分中所学到的所有内容。这是*后一组章节 :

 

第 11 章深入 Kubernetes 的底层,解释了组成 Kubernetes 集群的所有组件,以及每个组件的作用。它还解释了 pod 如何通过网络进行通信,以及服务如何跨多个 pod 形成负载平衡。

 

第 12 章解释了如何保护 Kubernetes API 服务器,以及通过扩展集群使用身份验证和授权。

 

第 13 章介绍了 pod 如何访问节点的资源,以及集群管理员如何防止 pod 访问节点的资源。

 

第 14 章深入了解限制每个应用程序允许使用的计算资源,配置应用的 QoS(Quality of Service)保证,以及监控各个应用的资源使用情况。还会介绍如何防止用户消耗太多资源。

 

第 15 章讨论了如何通过配置 Kubernetes 来自动伸缩应用运行的副本数,以及在当前集群节点数量不能接受任何新增应用时,如何对集群进行扩容。

 

第 16 章介绍了如何确保 pod 只被调度到特定的节点,或者如何防止它们被调度到其他节点。还介绍了如何确保 pod 被调度在一起,或者如何防止它们调度在一起。

 

第 17 章介绍了如何开发应用程序并部署在集群中。还介绍了如何配置开发和测试工作流来提高开发效率。

 

第 18 章介绍了如何使用自己的自定义对象扩展 Kubernetes,以及其他人是如何开发并创建企业级应用平台的。

 

随着章节的深入,不仅可以了解单个构建 Kubernetes 的模块,还可以逐步增加对使用 kubectl 命令行工具的理解。

 

 
 
 
 

商品简介

 

本书主要讲解如何在 Kubernetes 中部署分布式容器应用。本书开始部分概要介绍了 Docker 和Kubernetes 的由来和发展,然后通过在 Kubernetes 中部署一个应用程序,一点点增加功能,逐步加深我们对于Kubernetes架构的理解和操作的实践。在本书的后面部分,也可以学习一些高阶的主题,比如监控、调试及伸缩。Kubernetes是希腊文,意思是“舵手”,带领我们安全地到达未知水域。Kubernetes这样的容器编排系统,会帮助我们妥善地管理分布式应用的部署结构和线上流量,高效地组织容器和服务。Kubernetes 作为数据中心操作系统,在设计软件系统时,能够尽量降低在底层网络和硬件设施上的负担。

 

作者简介
 

目录
1Kubernetes介绍1
1.1Kubernetes系统的需求2
1.1.1从单体应用到微服务2
1.1.2为应用程序提供一个一致的环境5
1.1.3迈向持续交付:DevOps和无运维6
1.2介绍容器技术7
1.2.1什么是容器7
1.2.2Docker容器平台介绍11
1.2.3rkt——一个Docker的替代方案14
1.3Kubernetes介绍15
1.3.1初衷15
1.3.2深入浅出地了解Kubernetes15
1.3.3Kubernetes集群架构17
1.3.4在Kubernetes中运行应用18
1.3.5使用Kubernetes的好处20
1.4本章小结22
2开始使用Kubernetes和Docker23
2.1创建、运行及共享容器镜像23
2.1.1安装Docker并运行HelloWorld容器24
2.1.2创建一个简单的Node.js应用26
2.1.3为镜像创建Dockerfile27
2.1.4构建容器镜像27
2.1.5运行容器镜像30
2.1.6探索运行容器的内部31
2.1.7停止和删除容器32
2.1.8向镜像仓库推送镜像33
2.2配置Kubernetes集群34
2.2.1用Minikube运行一个本地单节点Kubernetes集群34
2.2.2使用GoogleKubernetesEngine托管Kubernetes集群36
2.2.3为kubectl配置别名和命令行补齐39
2.3在Kubernetes上运行第一个应用40
2.3.1部署Node.js应用40
2.3.2访问Web应用43
2.3.3系统的逻辑部分45
2.3.4水平伸缩应用46
2.3.5查看应用运行在哪个节点上49
2.3.6介绍Kubernetesdashboard50
2.4本章小结51
3pod:运行于Kubernetes中的容器53
3.1介绍pod53
3.1.1为何需要pod54
3.1.2了解pod55
3.1.3通过pod合理管理容器56
3.2以YAML或JSON描述文件创建pod58
3.2.1检查现有pod的YAML描述文件59
3.2.2为pod创建一个简单的YAML描述文件61
3.2.3使用kubectlcreate来创建pod63
3.2.4查看应用程序日志64
3.2.5向pod发送请求65
3.3使用标签组织pod66
3.3.1介绍标签66
3.3.2创建pod时指定标签67
3.3.3修改现有pod的标签68
3.4通过标签选择器列出pod子集69
3.4.1使用标签选择器列出pod69
3.4.2在标签选择器中使用多个条件71
3.5使用标签和选择器来约束pod调度71
3.5.1使用标签分类工作节点72
3.5.2将pod调度到特定节点72
3.5.3调度到一个特定节点73
3.6注解pod73
3.6.1查找对象的注解74
3.6.2添加和修改注解74
3.7使用命名空间对资源进行分组75
3.7.1了解对命名空间的需求75
3.7.2发现其他命名空间及其pod75
3.7.3创建一个命名空间76
3.7.4管理其他命名空间中的对象77
3.7.5命名空间提供的隔离78
3.8停止和移除pod78
3.8.1按名称删除pod78
3.8.2使用标签选择器删除pod79
3.8.3通过删除整个命名空间来删除pod80
3.8.4删除命名空间中的所有pod,但保留命名空间80
3.8.5删除命名空间中的(几乎)所有资源80
3.9本章小结81
4副本机制和其他控制器:部署托管的pod83
4.1保持pod健康84
4.1.1介绍存活探针84
4.1.2创建基于HTTP的存活探针85
4.1.3使用存活探针86
4.1.4配置存活探针的附加属性87
4.1.5创建有效的存活探针88
4.2了解ReplicationController89
4.2.1ReplicationController的操作90
4.2.2创建一个ReplicationController92
4.2.3使用ReplicationController94
4.2.4将pod移入或移出ReplicationController的作用域97
4.2.5修改pod模板100
4.2.6水平缩放pod101
4.2.7删除一个ReplicationController103
4.3使用ReplicaSet而不是ReplicationController104
4.3.1比较ReplicaSet和ReplicationController104
4.3.2定义ReplicaSet105
4.3.3创建和检查ReplicaSet106
4.3.4使用ReplicaSet的更富表达力的标签选择器106
4.3.5ReplicaSet小结107
4.4使用DaemonSet在每个节点上运行一个pod107
4.4.1使用DaemonSet在每个节点上运行一个pod108
4.4.2使用DaemonSet只在特定的节点上运行pod109
4.5运行执行单个任务的pod112
4.5.1介绍Job资源112
4.5.2定义Job资源113
4.5.3看Job运行一个pod114
4.5.4在Job中运行多个pod实例114
4.5.5Jobpod完成任务的时间116
4.6安排Job定期运行或在将来运行一次116
4.6.1创建一个CronJob116
4.6.2了解计划任务的运行方式118
4.7本章小结118
5服务:让客户端发现pod并与之通信121
5.1介绍服务122
5.1.1创建服务123
5.1.2服务发现129
5.2连接集群外部的服务132
5.2.1介绍服务endpoint133
5.2.2手动配置服务的endpoint133
5.2.3为外部服务创建别名135
5.3将服务暴露给外部客户端136
5.3.1使用NodePort类型的服务137
5.3.2通过负载均衡器将服务暴露出来140
5.3.3了解外部连接的特性142
5.4通过Ingress暴露服务143
5.4.1创

—  没有更多了  —

以下为对购买帮助不大的评价

此功能需要访问孔网APP才能使用
暂时不用
打开孔网APP