grpc详解和安装

环境: Ubuntu18.04
cmake版本: cmake version 3.17.0
grpc API
知乎介绍
本文主要介绍如何安装grpc, 后续文章将介绍
grpc实例之Python实现
grpc实例之C++实现
grpc详解和安装
注意: 下面的git链接永不过期, 大胆使用即可;

一. 问题驱动

1.1 起源

问题: 最近的项目需要用到C++, Python联合编程
具体而言, C++相当于一个车, Python(机器学习模型, 得到车观察四周环境数据后, 给出一个下一步操作行动给车), 但是因为二者不是一种语言, 所以交流上有些障碍, 虽然之前有写过最简单的socket网络实现C/S通信, 但是由于过于简单, 导致这个交流过程比较缓慢, 造成不必要的延时, 综上所述, 既要实现联合编程, 又要加速交流, 所以就要考虑到使用新的思路来做了

解决方案: 远程过程调用, 也就是C/S的高级做法
远程过程调用的具体应用工具有很多, 能跨语言的目前查到的最好的只有grpc, gRPC可以通过protobuf来定义接口,从而可以有更加严格的接口约束条件

名词解释
RPC:Remote Procedure Call,远程过程调用。简单来说就是两个进程之间的数据交互。正常服务端的接口服务是提供给用户端(在Web开发中就是浏览器)或者自身调用的,也就是本地过程调用。和本地过程调用相对的就是:假如两个服务端不在一个进程内怎么进行数据交互?使用RPC。尤其是现在微服务的大量实践,服务与服务之间的调用不可避免,RPC更显得尤为重要。
protobuf: protocol buffers 是一种语言无关、平台无关、可扩展的序列化结构数据的方法,它可用于(数据)通信协议、数据存储等
具体知识如下链接或者直接去Google或GitHub查看源码吧,
知乎介绍grpc
深入 ProtoBuf - 简介
这里致敬Google和各位学者

在这里插入图片描述

1.1 遇到的问题说明

版本问题:
首先目前grpc已经到v1.36.0(GitHub直接下载) 但是在安装过程中会出现各种问题, 因此为了规避不必要的麻烦, 这里推荐使用v1.12.0版本, 下文安装过程中会提及;

网速问题:
由于GitHub在国内访问确实有点慢, 所以本人已经将GitHub上的库复制并开源到了gitee(国内GitHub镜像), 所以下面下载的链接都是我公开的gitee, 请不要慌张, 都是为了速度;

protoc安装问题:
其实grpc安装主要的问题就出在了protoc安装上, 所以遇到问题, 多Google一下问题, 基本Google上前人都遇到过;

二. 安装

1.0 安装依赖

# 安装依赖
sudo apt-get install pkg-config
sudo apt-get install autoconf automake libtool make g++ unzip
sudo apt-get install libgflags-dev libgtest-dev
sudo apt-get install clang libc++-dev

1.1 下载grpc.zip 直接安装

因为有很多依赖包, 为了避免麻烦, 在配置好后, 已经将整个项目压缩好

# 下载
链接: https://pan.baidu.com/s/1W9rlwuI-TwvvhBvhTAFFQQ 
提取码: 8afw 复制这段内容后打开百度网盘手机App,操作更方便哦

# 安装protobuf
cd third_party/protobuf
sudo ./autogen.sh      # 生成配置脚本
sudo ./configure       # 生成Makefile文件,为下一步的编译做准备,可以加上安装路径:--prefix=path,默认安装路径为usr/local/bin/
sudo make -j4 && sudo make install # 编译安装到本地
sudo ldconfig       # 更新共享库缓存
which protoc       # 查看软件的安装位置
protoc --version   # 检查是否安装成功
# 返回 libprotoc 3.6.1

# 安装grpc
cd ../../ # 返回到grpc主目录里面
make clean  # 清理残留
make HAS_SYSTEM_PROTOBUF=false 
sudo make install # 安装到本地

# cpp测试
cd examples/cpp/helloworld/
make clean && make # 编译
./greeter_server  # 启动服务器

# 从另一个窗口打开
cd /mnt/e/01_gRPC/grpc/examples/cpp/helloworld/
./greeter_client  # 启动客户端

三. 从GitHub下载安装grpc

# 下载grpc
git clone https://gitHub.com/grpc/grpc.git # 下载
git checkout v1.12.0 # 指定版本
git submodule sync # 诊断
git submodule update --init # 立即应用生效

# 安装protobuf
cd third_party/protobuf
git tag # 查看版本
git checkout v3.6.1 # 将protoc 更新到指定版本
git submodule update --init --recursive   # 确保克隆子模块,更新第三方源码
sudo ./autogen.sh      # 生成配置脚本
sudo ./configure       # 生成Makefile文件,为下一步的编译做准备,可以加上安装路径:--prefix=path,默认安装路径为usr/local/bin/
sudo make -j4 && sudo make install # 编译安装到本地
sudo ldconfig       # 更新共享库缓存
which protoc       # 查看软件的安装位置
protoc --version   # 检查是否安装成功
# 返回 libprotoc 3.6.1

# 安装grpc安装
cd ../../ # 返回到grpc主目录里面
make clean  # 清理残留
make HAS_SYSTEM_PROTOBUF=false 
sudo make install # 安装到本地

四. 测试

cd examples/cpp/helloworld/
make # 编译
./greeter_server  # 启动服务器
# 从另一个窗口打开
cd /mnt/e/01_gRPC/grpc/examples/cpp/helloworld/
./greeter_client  # 启动客户端
  • 10
    点赞
  • 40
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 7
    评论
RPC(Remote Procedure Call)和gRPC(Google Remote Procedure Call)都是用于远程过程调用的协议。它们允许客户端应用程序像调用本地函数一样调用远程函数,从而简化了分布式系统中的通信。 RPC是一种通用的协议,可以使用不同的编码格式和传输协议来实现。RPC的编解码过程是在客户端和服务器端之间进行的,这意味着它可以使用不同的编码格式来传输数据。 gRPC是由Google开发的一种基于RPC的框架,它使用Protocol Buffers作为默认的编码格式,并且使用HTTP/2作为传输协议。gRPC提供了强类型的接口定义语言(IDL),可以用来定义RPC服务的接口和消息格式,从而使得客户端和服务器端可以生成相应的代码来进行通信。 相比于RPC,gRPC具有以下优势: 1. 高效的编码格式:Protocol Buffers是一种高效的二进制编码格式,它可以大幅减少数据传输的大小,从而提高网络带宽的利用率。 2. 高效的传输协议:HTTP/2是一种高效的传输协议,它支持多路复用和头部压缩等特性,可以减少网络延迟和带宽占用。 3. 强类型的IDL:gRPC提供了一种强类型的IDL,可以用来定义服务接口和消息格式,从而使得客户端和服务器端可以生成相应的代码来进行通信,减少了手动编写和解析请求和响应的工作量。 4. 多语言支持:gRPC支持多种编程语言,包括C++、Java、Python、Go等,可以在不同的平台上进行通信。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

落子无悔!

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值