grpc不是只支持go语言。grpc是通信协议基于HTTP/2,支持多语言的RPC框架;目前提供C、Java和Go语言版本,分别是grpc、grpc-java、grpc-go;其中C版本支持C、C++、Node.js、Python、Ruby、Objective-C、PHP和C#支持。
本教程操作环境:windows7系统、GO 1.18版本、Dell G3电脑。
gRPC 是通信协议基于 HTTP/2,支持多语言的 RPC 框架,面向移动和 HTTP/2 设计。gRPC 基于 HTTP/2 标准设计,带来诸如双向流、流控、头部压缩、单 TCP 连接上的多复用请求等特。这些特性使得其在移动设备上表现更好,更省电和节省空间占用。
RPC:Remote Procedure Call 的缩写,译为远程过程调用(也可译为远程方法调用或远程调用),它是计算机通信协议。该协议可以实现调用远程服务就像调用本地服务一样简单,无需关心跨网络,跨平台,跨语言等问题。
gRPC 消息序列化方式通常使用 Protobuf,它是二进制格式,体积小,网络传输快,占用带宽流量少,调用性能更高。
gRPC 的特点
立即学习“go语言免费学习笔记(深入)”;
IDL
gRPC 使用 ProtoBuf 来定义服务,ProtoBuf 是由 Google 开发的一种数据序列化协议(类似于 XML、JSON)。ProtoBuf 能够将数据进行序列化,并广泛应用在数据存储、通信协议等方面。
多语言支持
gRPC 支持多种语言,并能够基于语言自动生成客户端和服务端功能库。目前已提供了 C 版本 grpc、Java 版本 grpc-java 和 Go 版本 grpc-go,其中,grpc 支持 C、C++、Node.js、Python、Ruby、Objective-C、PHP 和 C# 等语言,grpc-java 已经支持 Android 开发。
HTTP2
gRPC基于HTTP2标准设计,带来了更多强大功能,如双向流、头部压缩、多复用请求等。这些功能带来重大益处,如节省带宽、降低TCP链接次数、节省CPU使用和延长电池寿命等。同时,gRPC还能够提高了云端服务和Web应用的性能。gRPC既能够在客户端应用,也能够在服务器端应用,从而以透明的方式实现客户端和服务器端的通信和简化通信系统的构建。
为什么我们要用grpc
生态好:背靠Google。还有比如nginx也对grpc提供了支持,参考链接
跨语言:跨语言,且自动生成sdk
性能高:比如protobuf性能高过json, 比如http2.0性能高过http1.1
强类型:编译器就给你解决了很大一部分问题
流式处理(基于http2.0):支持客户端流式,服务端流式,双向流式
1)什么是protobuf?
2)他比json快多少?
3)为什么protobuf比json快?
protobuf的二进制数据流和json数据流如下图
1)多路复用
示意图
2)头部压缩
3)二进制分帧
4)服务器主动推送资源
更多编程相关知识,请访问:编程入门!!
以上就是grpc只支持go语言吗的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号