Go编程进阶实战:开发命令行应用、HTTP应用和gRPC应用
全新正版现货
¥
49
5.0折
¥
98
全新
仅1件
作者 [澳]阿米特·萨哈(Amit Saha)著 贾玉彬 刘光磊 译 上海碳泽信息科技有限公司 审校
出版社 清华大学出版社
ISBN 9787302615897
出版时间 2022-11
装帧 平装
开本 16开
纸张 胶版纸
定价 98元
货号 29489359
上书时间 2024-07-11
商品详情
品相描述:全新
正版全新
商品描述
【编辑推荐 】: 谷歌在2009年发布了Go编程语言,并于2012年发布了1.0版。Go语言具有强大的兼容性,一直用于编写可扩展的重量程序(命令行应用程序、关键基础设施工具乃至大规模分布式系统)。凭借简单性、丰富的标准库和蓬勃发展的第三方软件包生态系统,Go语言成为软件开发人员的通用语言。 《Go编程进阶实战:开发命令行应用、HTTP应用和gRPC应用》将指导你使用 Go编程语言来构建健壮的、生产别的应用程序。你将学到足够多的知识来构建命令行工具以及通过HTTP和gRPC通信的应用程序。 【内容简介 】: 主要内容 ● 编写命令行应用程序 ● 编写HTTP服务和客户端 ● 使用gRPC编写RPC应用程序 ● 为网络客户端和服务器编写中间件 ● 在云对象存储和SQL数据库中存储数据 ● 使用惯用的技术测试应用程序 ● 为应用程序增加可观察性 ● 管理应用程序的配置数据 【作者简介 】: Amit Saha是位于澳大利亚悉尼市的Atlassian公司的高DevOps工程师。Amit曾撰写Doing Math with Python: Use Programming to Explore Algebra, Statistics, Calculus, and More!和Write Your First Program等书籍。Amit已在软件行业工作10年,曾加盟Sun Microsystems、RedHat和多家初创公司。Amit在技术杂志、会议论文集和研究期刊上发表过大量文章。 【目录 】: 第1章 编写命令行应用程序 1 1.1 我们的个应用程序 1 1.2 编写单元测试 8 1.3 使用flag包 14 1.4 改进用户界面 22 1.4.1 删除重复的错误消息 22 1.4.2 自定义用例消息 23 1.4.3 通过位置参数接收姓名 24 1.5 更新单元测试 27 1.6 小结 32 第2章 高命令行应用程序 33 2.1 实现子命令 33 2.1.1 子命令驱动的应用程序架构 37 2.1.2 测试main包 43 2.1.3 测试cmd包 45 2.2 使应用程序更健壮 47 2.2.1 带有超时的用户输入 48 2.2.2 处理用户信号 51 2.3 小结 55 第3章 编写HTTP客户端 57 3.1 下载数据 57 3.2 反序列化接收到的数据 61 3.3 发送数据 65 3.4 使用二进制数据 71 3.5 小结 78 第4章 高HTTP客户端 79 4.1 使用自定义HTTP客户端 79 4.1.1 从过载的服务器下载 79 4.1.2 测试超时行为 83 4.1.3 配置重定向行为 86 4.2 定制请求 89 4.3 实现客户端中间件 90 4.3.1 了解RoundTripper接口 90 4.3.2 日志中间件 91 4.3.3 给所有请求添加一个标头 94 4.4 连接池 97 4.5 小结 101 第5章 构建HTTP服务器 103 5.1 我们的个HTTP服务器 103 5.2 设置请求处理程序 106 处理程序 106 5.3 测试服务器 109 5.4 Request(请求)结构 112 5.4.1 方法 112 5.4.2 URL 112 5.4.3 Proto、ProtoMajor和ProtoMinor 113 5.4.4 标头 113 5.4.5 主机 113 5.4.6 正文 113 5.4.7 Form、PostForm 113 5.4.8 MultipartForm 114 5.5 将元数据附加到请求 115 5.6 处理流请求 118 5.7 将流数据作为响应 123 5.8 小结 128 第6章 高HTTP服务器应用程序 129 6.1 处理程序的类型 129 6.2 跨处理程序共享数据 130 6.3 编写服务器中间件 135 6.3.1 自定义HTTP处理程序技术 135 6.3.2 HandlerFunc技术 136 6.3.3 链接中间件 138 6.4 为复杂的服务器应用程序编写测试 142 6.4.1 组织代码 143 6.4.2 测试处理程序 148 6.4.3 测试中间件 151 6.4.4 测试服务器启动 153 6.5 小结 155 第7章 生产HTTP服务器 157 7.1 终止请求处理 157 7.1.1 终止请求处理的策略 160 7.1.2 处理客户端断开连接 165 7.2 服务器范围的超时 168 7.2.1 为所有处理程序实现超时 169 7.2.2 实现服务器超时 169 7.3 实施优雅的关机 174 7.4 使用TLS保护通信 178 7.4.1 配置TLS和HTTP/2 179 7.4.2 测试TLS服务器 183 7.5 小结 186 第8章 使用gRPC构建RPC应用程序 187 8.1 gRPC和协议缓冲区 187 8.2 编写个服务 190 8.2.1 编写服务器 192 8.2.2 编写一个客户端 196 8.2.3 测试服务器 201 8.2.4 测试客户端 204 8.3 protobuf消息的详细介绍 207 8.3.1 序列化和反序列化 207 8.3.2 向前和向后兼容 212 8.4 多个服务 214 8.5 错误处理 219 8.6 小结 221 第9章 高gRPC应用 223 9.1 流通信 223 9.1.1 服务器端流传输 223 9.1.2 客户端流传输 231 9.1.3 双向流 233 9.2 接收和发送任意字节 241 9.3 使用拦截器实现中间件 250 9.3.1 客户端拦截器 251 9.3.2 服务器端拦截器 257 9.3.3 包装流 262 9.3.4 链接拦截器 264 9.4 小结 265 第10章 生产gRPC应用 267 10.1 使用TLS保护通信 267 10.2 服务器健壮性 270 10.2.1 实施健康检查 270 10.2.2 处理运行时错误 277 10.2.3 终止请求处理 280 10.3 客户端健壮性 289 10.3.1 提高连接配置 289 10.3.2 处理瞬态故障 291 10.3.3 为方法调用设置超时 296 10.4 连接管理 297 10.5 小结 299 第11章 使用数据存储 301 11.1 使用对象存储 302 11.1.1 与包服务器集成 303 11.1.2 测试包上传 312 11.1.3 访问底层驱动类型 315 11.2 使用关系数据库 316 11.2.1 与包服务器集成 318 11.2.2 测试数据存储 328 11.2.3 数据类型转换 332 11.2.4 使用数据库事务 335 11.3 小结 337 —— 以下部分通过扫描封底二维码获取 —— 附录A 使应用程序可观察 339 附录B 部署应用程序 356 附录C 配置Go开发环境 362
— 没有更多了 —
以下为对购买帮助不大的评价