Go编程进阶实战:开发命令行应用、HTTP应用和gRPC应用
¥
101
全新
仅1件
作者 [澳]阿米特·萨哈(Amit Saha)著 贾玉彬 刘光磊 译;上海碳泽信息科技有限公司 审校
出版社 清华大学出版社
出版时间 2022-11
版次 1
装帧 其他
货号 58978707
上书时间 2024-12-19
商品详情
品相描述:全新
图书标准信息
作者
[澳]阿米特·萨哈(Amit Saha)著 贾玉彬 刘光磊 译;上海碳泽信息科技有限公司 审校
出版社
清华大学出版社
出版时间
2022-11
版次
1
ISBN
9787302615897
定价
98.00元
装帧
其他
开本
16开
纸张
胶版纸
页数
712页
字数
485千字
【内容简介】
主要内容 ● 编写命令行应用程序 ● 编写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
点击展开
点击收起
— 没有更多了 —
以下为对购买帮助不大的评价