Go语言高级编程
  • Go语言高级编程(Advanced Go Programming)
  • 第1章 语言基础
    • 1.1 Go语言创世纪
    • 1.2 Hello, World 的革命
    • 1.3 数组、字符串和切片
    • 1.4 函数、方法和接口
    • 1.5 面向并发的内存模型
    • 1.6 常见的并发模式
    • 1.7 错误和异常
    • 1.8 补充说明
  • 第2章 CGO编程
    • 2.1 快速入门
    • 2.2 CGO基础
    • 2.3 类型转换
    • 2.4 函数调用
    • 2.5 内部机制
    • 2.6 实战: 封装qsort
    • 2.7 CGO内存模型
    • 2.8 C++类包装
    • 2.9 静态库和动态库
    • 2.10 编译和链接参数
    • 2.11 补充说明
  • 第3章 汇编语言
    • 3.1 快速入门
    • 3.2 计算机结构
    • 3.3 常量和全局变量
    • 3.4 函数
    • 3.5 控制流
    • 3.6 再论函数
    • 3.7 汇编语言的威力
    • 3.8 例子:Goroutine ID
    • 3.9 Delve调试器
    • 3.10 补充说明
  • 第4章 RPC和Protobuf
    • 4.1 RPC入门
    • 4.2 Protobuf
    • 4.3 玩转RPC
    • 4.4 gRPC入门
    • 4.5 gRPC进阶
    • 4.6 gRPC和Protobuf扩展
    • 4.7 pbgo: 基于Protobuf的框架
    • 4.8 grpcurl工具
    • 4.9 补充说明
  • 第5章 Go和Web
    • 5.1 Web开发简介
    • 5.2 请求路由
    • 5.3 中间件
    • 5.4 请求校验
    • 5.5 和数据库打交道
    • 5.6 服务流量限制
    • 5.7 大型Web项目分层
    • 5.8 接口和表驱动开发
    • 5.9 灰度发布和A/B测试
    • 5.10 补充说明
  • 第6章 分布式系统
    • 6.1 分布式 id 生成器
    • 6.2 分布式锁
    • 6.3 延时任务系统
    • 6.4 分布式搜索引擎
    • 6.5 负载均衡
    • 6.6 分布式配置管理
    • 6.7 分布式爬虫
    • 6.8 补充说明
  • 附录
    • 附录A: Go语言常见坑
    • 附录B: 有趣的代码片段
    • 附录C: 作者简介
Powered by GitBook
On this page

Was this helpful?

第4章 RPC和Protobuf

学习编程,重要的是什么?多练、多看、多实践!跨语言学习,掌握基础语法和语言的特性之后,实战,效率来的最快!——khlipeng

RPC是远程过程调用的缩写(Remote Procedure Call),通俗地说就是调用远处的一个函数。远处到底有多远呢?可能是同一个文件内的不同函数,也可能是同一个机器的另一个进程的函数,还可能是远在火星好奇号上面的某个秘密方法。因为RPC涉及的函数可能非常之远,远到它们之间说着完全不同的语言,语言就成了两边的沟通障碍。而Protobuf因为支持多种不同的语言(甚至不支持的语言也可以扩展支持),其本身特性也非常方便描述服务的接口(也就是方法列表),因此非常适合作为RPC世界的接口交流语言。本章将讨论RPC的基本用法,如何针对不同场景设计自己的RPC服务,以及围绕Protobuf构造的更为庞大的RPC生态。

Previous3.10 补充说明Next4.1 RPC入门

Last updated 5 years ago

Was this helpful?