前些天gRPC 發(fā)布1.0 版本,代表著gRPC 已經(jīng)正式進入穩(wěn)定階段。 

今天我們就來學(xué)習(xí)gRPC C# 。而且目前也已經(jīng)支持.NET Core 可以實現(xiàn)完美跨平臺。

傳統(tǒng)的.NET 可以通過Mono 來實現(xiàn)跨平臺調(diào)用。

GitHub: https://github.com/grpc/grpc

gRPC 簡單介紹:

gRPC是一個高性能、通用的開源RPC框架,其由Google主要面向移動應(yīng)用開發(fā)并基于HTTP/2協(xié)議標(biāo)準(zhǔn)而設(shè)計,基于ProtoBuf(Protocol Buffers)序列化協(xié)議開發(fā),且支持眾多開發(fā)語言。gRPC提供了一種簡單的方法來精確地定義服務(wù)和為iOS、Android和后臺支持服務(wù)自動生成可靠性很強的客戶端功能庫??蛻舳顺浞掷酶呒壛骱玩溄庸δ?,從而有助于節(jié)省帶寬、降低的TCP鏈接次數(shù)、節(jié)省CPU使用、和電池壽命。

gRPC支持多種語言,并能夠基于語言自動生成客戶端和服務(wù)端功能庫。目前,在GitHub上已提供了C版本grpc、Java版本grpc-java 和 Go版本grpc-go,其它語言的版本正在積極開發(fā)中,其中 grpc支持C、C++、Node.js、Python、Ruby、Objective-C、PHP和C#等語言,grpc-java已經(jīng)支持Android開發(fā)。

gRPC已經(jīng)應(yīng)用在Google的云服務(wù)和對外提供的API中,其主要應(yīng)用場景如下:

低延遲、高擴展性、分布式的系統(tǒng)
同云服務(wù)器進行通信的移動應(yīng)用客戶端
設(shè)計語言獨立、高效、精確的新協(xié)議
便于各方面擴展的分層設(shè)計,如認(rèn)證、負(fù)載均衡、日志記錄、監(jiān)控等

參考文檔:

http://www.infoq.com/cn/news/2015/03/grpc-google-http2-protobuf

本篇文章主要講解傳統(tǒng).NET 應(yīng)用如何支持gRPC。

下面就正式開始。

延伸閱讀

學(xué)習(xí)是年輕人改變自己的最好方式-Java培訓(xùn),做最負(fù)責(zé)任的教育,學(xué)習(xí)改變命運,軟件學(xué)習(xí),再就業(yè),大學(xué)生如何就業(yè),幫大學(xué)生找到好工作,lphotoshop培訓(xùn),電腦培訓(xùn),電腦維修培訓(xùn),移動軟件開發(fā)培訓(xùn),網(wǎng)站設(shè)計培訓(xùn),網(wǎng)站建設(shè)培訓(xùn)學(xué)習(xí)是年輕人改變自己的最好方式