mirror of
https://github.com/chai2010/advanced-go-programming-book.git
synced 2025-01-09 06:50:06 +00:00
.. | ||
ch4-01-rpc-intro.md | ||
ch4-02-pb-intro.md | ||
ch4-03-netrpc-hack.md | ||
ch4-04-grpc.md | ||
ch4-05-grpc-hack.md | ||
ch4-06-grpc-ext.md | ||
ch4-07-pbgo.md | ||
ch4-08-grpcurl.md | ||
ch4-09-ext.md | ||
readme.md |
第4章 RPC和Protobuf
学习编程,重要的是什么?多练、多看、多实践!跨语言学习,掌握基础语法和语言的特性之后,实战,效率来的最快!——khlipeng
RPC是远程过程调用的缩写(Remote Procedure Call),通俗地说就是调用远处的一个函数。远处到底有多远呢?可能是同一个文件内的不同函数,也可能是同一个机器的另一个进程的函数,还可能是远在火星好奇号上面的某个秘密方法。因为RPC涉及的函数可能非常之远,远到它们之间说着完全不同的语言,语言就成了两边的沟通障碍。而Protobuf因为支持多种不同的语言(甚至不支持的语言也可以扩展支持),其本身特性也非常方便描述服务的接口(也就是方法列表),因此非常适合作为RPC世界的接口交流语言。本章将讨论RPC的基本用法,如何针对不同场景设计自己的RPC服务,以及围绕Protobuf构造的更为庞大的RPC生态。