brpc最新安装上手指南

当时brpc还未开源。后于同年百度对外开源了brpc。在百度内部brpc叫baidu-rpc。后来由于进入了Apache基金会进行孵化,brpc的含义做了调整,改成了better RPC。这倒也无伤大雅,众所周知,百度和腾讯是国内鲜有的C++大厂,而brpc也算是笔者见过C++开源世界里比较优秀且实用的框架了。

好了,关于brpc的溢美之词暂且按下不表,我们言归正传,赶快上手吧!另外brpc支持Mac和Linux环境。本文是基于某云的Centos实机操作纪实!brpc的版本是0.9.7。

github

brpc的github地址如下:

https://github.com/apache/incubator-brpc

我们也可以直接在本地克隆:

git clone https://github.com/apache/incubator-brpc.git

安装编译依赖

cmake

我习惯用cmake编译一些第三方库,这里我们安装一下cmake。云主机默认安装的cmake可能是cmake 2的版本。但由于brpc其中一个依赖gflags需要cmake3,所以我们先安装一下cmake3:

yum install cmake3

第三方库

  • gflags
  • leveldb
  • protobuf (2或3均可)
  • openssl

上面是brpc编译所依赖的几个第三方库,基本上在github上都能找到。除openssl外都支持cmake编译。

  • https://github.com/gflags/gflags
  • https://github.com/google/leveldb
  • https://github.com/protocolbuffers/protobuf
  • https://github.com/openssl/openssl

其中gflags、leveldb默认cmake的编译方式会编译成静态库,导致最终编译brpc时会报错:

/usr/local/lib/libgflags.a(gflags.cc.o): relocation R_X86_64_32S against `.rodata' can not be used

所以请注意我们需要把gflags、leveldb都编译成动态库。在下载完源码后,cd到对应目录,执行如下操作:

mkdir bld
cd bld
cmake3 -DBUILD_SHARED_LIBS=ON ..
make -j 8
sudo make install

也就是给cmake加上一个-DBUILD_SHARED_LIBS=ON参数。gflags、leveldb可以安装上述流程来编译。

另外关于openssl和protobuf,参照编译文档编译即可。没有什么坑点。

唯一需要提醒的是,如果是autotool编译安装的方式(要执行./configure的),最好不要自作聪明加--prefix参数来修改默认的库安装路径。因为如果安装到自定义路径下,后续其他编译如果依赖到这个库,都需要修改编译时的库检索路径,简直自找麻烦!

编译brpc

好了,准备工作做完,终于要编译brpc了。cd到brpc的下载目录中。

mkdir bld
cd bld
cmake3 ..
make
make install

这里我make的时候没加j8参数来开启并行编译。因为我机器上实测并行编译会编译失败,串行编译无问题。当然缺点就是编译比较慢了。我建议是在云主机上开一个tmux,在tmux会话里开始make,然后你就可以忙别的去了。

漫长等待之后,最终会编译成功。

编译example

brpc编译完成,基本上你就可以使用了。但是brpc自带的例子没有编译。我们可以编译一下,启动看看。在example目录下面。

需要提醒的是example的代码用cmake编译,可能会失败(反正我是遇到了)。没关系,我们改成普通make编译的方式。

首先要先生成config.mk,回到brpc的顶级目录:

sh config_brpc.sh --headers=/usr/local/include  --libs=/usr/local/lib

headers和libs指定第三方库的头文件和库所在路径。这也就是我为什么说不要随意修改库的安装路径的原因了,库装在不同位置着实不便。尽量集中到一起,不在一起的时候,可以通过建立软连接,弄到一起。

生成config.mk之后,就可以去example目录编译了,比如我们编译echo_c++。

cd example/echo_c++
make

运行echo_c++

上面编译完成之后会有echo_server和echo_client的可执行文件。

我们启动server:

nohup ./echo_server &

echo_client 其实我一般不用。echo_client是默认的baidu_std协议。实际工作中多有使用,但作为demo测试,其实不用。因为brpc有个强大的特性是支持单端口多协议,并且号称支持协议最多的RPC框架。所以我们可以用HTTP请求的方式来请求它!

curl -d '{"message":"hello world"}' 127.0.0.1:8000/EchoService/Echo

端口号后面的路径和proto定义有关。查看echo.proto的定义:

service EchoService {
      rpc Echo(EchoRequest) returns (EchoResponse);
};

好了。后面我们就可以通过调试修改这个echo_server来学习了解brpc啦。

我知道你在看哦

原文地址:https://cloud.tencent.com/developer/article/1915052

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


学习编程是顺着互联网的发展潮流,是一件好事。新手如何学习编程?其实不难,不过在学习编程之前你得先了解你的目的是什么?这个很重要,因为目的决定你的发展方向、决定你的发展速度。
IT行业是什么工作做什么?IT行业的工作有:产品策划类、页面设计类、前端与移动、开发与测试、营销推广类、数据运营类、运营维护类、游戏相关类等,根据不同的分类下面有细分了不同的岗位。
女生学Java好就业吗?女生适合学Java编程吗?目前有不少女生学习Java开发,但要结合自身的情况,先了解自己适不适合去学习Java,不要盲目的选择不适合自己的Java培训班进行学习。只要肯下功夫钻研,多看、多想、多练
Can’t connect to local MySQL server through socket \'/var/lib/mysql/mysql.sock问题 1.进入mysql路径
oracle基本命令 一、登录操作 1.管理员登录 # 管理员登录 sqlplus / as sysdba 2.普通用户登录
一、背景 因为项目中需要通北京网络,所以需要连vpn,但是服务器有时候会断掉,所以写个shell脚本每五分钟去判断是否连接,于是就有下面的shell脚本。
BETWEEN 操作符选取介于两个值之间的数据范围内的值。这些值可以是数值、文本或者日期。
假如你已经使用过苹果开发者中心上架app,你肯定知道在苹果开发者中心的web界面,无法直接提交ipa文件,而是需要使用第三方工具,将ipa文件上传到构建版本,开...
下面的 SQL 语句指定了两个别名,一个是 name 列的别名,一个是 country 列的别名。**提示:**如果列名称包含空格,要求使用双引号或方括号:
在使用H5混合开发的app打包后,需要将ipa文件上传到appstore进行发布,就需要去苹果开发者中心进行发布。​
+----+--------------+---------------------------+-------+---------+
数组的声明并不是声明一个个单独的变量,比如 number0、number1、...、number99,而是声明一个数组变量,比如 numbers,然后使用 nu...
第一步:到appuploader官网下载辅助工具和iCloud驱动,使用前面创建的AppID登录。
如需删除表中的列,请使用下面的语法(请注意,某些数据库系统不允许这种在数据库表中删除列的方式):
前不久在制作win11pe,制作了一版,1.26GB,太大了,不满意,想再裁剪下,发现这次dism mount正常,commit或discard巨慢,以前都很快...
赛门铁克各个版本概览:https://knowledge.broadcom.com/external/article?legacyId=tech163829
实测Python 3.6.6用pip 21.3.1,再高就报错了,Python 3.10.7用pip 22.3.1是可以的
Broadcom Corporation (博通公司,股票代号AVGO)是全球领先的有线和无线通信半导体公司。其产品实现向家庭、 办公室和移动环境以及在这些环境...
发现个问题,server2016上安装了c4d这些版本,低版本的正常显示窗格,但红色圈出的高版本c4d打开后不显示窗格,
TAT:https://cloud.tencent.com/document/product/1340