尝试在iOS上使用gRPC

简介node

gRPC,google的远程过程调用框架,传输协议使用 HTTP2, 序列化协议使用 protobuf。
gRPC 使用 HTTP2 传输协议传输 protobuf 序列化的二进制数据,有极高的效率、极低的资源占用率。
github仓库地址:https://github.com/grpc/grpc,该仓库包含在共享C核心库src / core之上编写的多种语言(C++, Python, Ruby, Objective-C, PHP, C#)实现的gRPC库的源代码。
gRPC的一些特性:c++

  • 简单的服务定义
  • 跨语言和平台工做
  • 快速启动并扩展
  • 双向流媒体以及身份验证集成

使用GRPC几大核心步骤
1)Defining a service 定义服务(在.proto文件中这个是和后台交互的主要协议)
2)Generating grpc code 生成grpc代码
3)Writing a server 服务端编写必定的服务提供给客户端使用(相似接口)
4)Server implementation 服务的实现
5)Writing a client 编写客户端代码(集成grpc)
6)Calling an rpc 根据RPC协议(.proto文件约定的协议)进行代码(接口)调用
优势:客户端充分利用高级流和连接功能,从而有助于节省带宽、下降的TCP连接次数、节省CPU使用、和电池寿命。git

Objective-C Quick Start

系统需求github

  • 最小iOS版本为7.0,即iOS version >=7.0
  • OS X 10.11及以上,即OS X 10.11 >= 10.11

前提条件
  一、CocoaPods >= 1.0 检查Cocoapods版本:pod –version
  $ sudo gem install cocoapods
  $ pod setup
  PS:CocoaPods是iOS开发、macOS开发中的包依赖管理工具,效果如Java中的Maven,nodejs的npm。
  二、Xcode >=7.2objective-c

  

  三、Homebrew
  $ ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
  PS:Homebrew是一款自由及开放源代码的软件包管理系统,用以简化macOS系统上的软件安装过程
  四、autoconf, automake, libtool, pkg-config
  $ brew install autoconf automake libtool pkg-confignpm

安装gRPC插件以及二进制库文件windows

https://github.com/grpc/grpc下载gRPC源码,解压后进入grpc目录:
$ make
遇到错误:报错很简单,提示系统缺乏cares包ruby

https://github.com/c-ares/c-ares下载cares包后,解压放在/grpc/third_party/cares/cares目录下,从新make,又报错了~,提示缺乏OpenSSL,我勒个去,安装一个缺一个,什么时候是个头啊!grpc的third_party中只是给出了库的仓库地址,可是实际编译时须要的时third_party的所有源码文件。服务器

有效解决方法:Git源码编译(须要网络良好):
$ git clone --recursive -b v1.23.0 https://github.com/grpc/grpc.git
$ cd grpc
$ git submodule update --init
$ make
$ [sudo] make install
完成后会把gRPC的头文件安装在/usr/local/include,在程序中可直接包含使用,连接库则安装在/usr/local/lib中,供程序编译成功后连接使用。网络

 

安装protoc编译器

$ brew tap grpc/grpc
$ brew install protobuf

运行Server

对于此示例应用程序,咱们须要在本地计算机上运行的gRPC服务器。gRPC Objective-C API支持建立gRPC客户端,但不支持建立gRPC服务器。所以,咱们在同一个存储库中构建并运行C ++服务器:
$ cd examples/cpp/helloworld
$ make
$ ./greeter_server &

C++服务端进程greeter_server运行起来了~

运行Client

1)生成客户端库和依赖项
$ cd ../../objective-c/helloworld
$ pod install

2)运行客户端app
$ open HelloWorld.xcworkspace
这将使用Xcode打开应用程序项目。经过按Xcode窗口左上角的“运行”按钮,在iOS模拟器中运行应用程序。你能够检查main.m中的调用代码,并在Xcode的控制台中查看结果。代码将包含字符串“Objective-C”的HLWHelloRequest发送到本地服务器。服务器响应HLWHelloResponse,其中包含一个字符串“Hello Objective-C”,而后输出到控制台。

恭喜!您刚刚使用gRPC成功运行了iOS模拟器客户端-C++服务器应用程序。

iOS真机测试

插入iphone,Xcode识别iphone,并选择为当前设备,配置工程签名信息,构建运行便可!

因为个人Mac OS是在实体机的虚拟机中运行,而实体机使用的是有线光纤网络,和iphone手机所使用的无线网络不在同一个局域网内,因此没法网络联通。
个人笔记本(Windows7 x64)使用的是无线网络,ip地址192.168.2.15,iphone手机ip地址192.168.2.231,是在同一个无线局域网内,能够在笔记本192.168.2.15上运行该gRPC C++ HelloWorld Server程序,可是须要Windows版本的gRPC程序,编译Windows版本的gRPC并使用其HelloWorld Demo程序可参考文章《grpc1.18.0 c++ windows visual studio 2017(vs2017)版本编译(入门)》以及《grpc1.18.0 c++ windows visual studio 2017(vs2017)版本Helloworld示例与解析》。

我这里直接展现最终的结果:
1) gRPC C++ HelloWorld Server

注意:因为该服务端程序是使用VS2017 x64编译出来的,运行时须要zlib.dll以及VS2017的一些运行时库,因此须要安装VS2017才能确保运行(只安装C++开发部分组件便可)。
一点小知识:服务器端的监听地址为"0.0.0.0:50051",0.0.0.0在服务器端它表示本机上的全部IPV4地址,若是一个服务有多个IP地址(192.168.1.2和10.1.1.12),那么咱们若是设置的监听地址是0.0.0.0那么咱们不管是经过IP192.168.1.2仍是10.1.1.12都是能够访问该服务的。
2) gRPC Object-C HelloWorld Client
在Xcode中将链接的服务器地址由@"localhost.15:50051"修改成@"192.168.2.15:50051",以后选择所链接的iOS真机,运行!

测试所使用的iOS真机,借来用的:

恭喜!您刚刚使用gRPC成功运行了iOS真机客户端-C++服务器应用程序。

参考

相关文章
相关标签/搜索