Linux C++ 安装和使用grpc和jsoncpp库

简介

本文主要教会大家如何在Linux环境搭建C++ 所需的grpc和jsoncpp库,并教会大家如何编写cmake,并配置使用这些库。

解决vim乱码

为了解决Linux环境下打开vim中文乱码的问题
用vim打开用户目录下的vim配置文件

  1. vim ~/.vimrc

配置如下

  1. set termencoding=utf-8
  2. set encoding=utf8
  3. set fileencodings=utf8,ucs-bom,gbk,cp936,gb2312,gb18030

配置和使用jsoncpp

如果你是ubuntu系统,可以通过如下命令直接安装

  1. 可以通过指令apt install libjsoncpp-dev 安装

但是如果是其他Linux系统最好是手动安装源码包,我的操作都是在ubuntu为基础镜像生成的docker中进行的,如果大家使用的是宿主机,可以直接安装。
推荐源码安装,去github下载

https://github.com/open-source-parsers/jsoncpp/releases

可以选择用wget 命令
我在电脑下好后传到云服务器上
然后在云服务器上copy到docker里, 如果你是在宿主机进行的,可以略去这一步。

  1. docker cp /home/ubuntu/download/jsoncpp-1.9.5.tar.gz cppubuntu:/test

进入容器

  1. docker exec -it cppubuntu /bin/bash

接下来解压压缩包,无论docker还是宿主机内,都需执行如下命令

  1. tar zxvf ./jsoncpp-1.9.5.tar.gz

进入到源码目录

  1. cd ./json

创建目录

  1. mkdir build

进入目录

  1. cd build

执行cmake生成makefile

  1. cmake ../

执行make

  1. make

执行安装

  1. make install

更新库

  1. ldconfig

写一个jsoncpp的测试cpp

  1. #include<json/json.h>
  2. #include<iostream>
  3. using namespace std;
  4. int main(int argc, char** argv)
  5. {
  6. Json::Value root;
  7. Json::FastWriter fast;
  8. root["ModuleType"]= Json::Value("你好");
  9. root["ModuleCode"]= Json::Value("22");
  10. root["ModuleDesc"]= Json::Value("33");
  11. root["DateTime"]= Json::Value("44");
  12. root["LogType"]= Json::Value("55");
  13. cout<<fast.write(root)<<endl;
  14. return 0;
  15. }

执行 编译

  1. g++ jsontest.cpp -o jsontest -ljsoncpp

或者写个cmake

  1. cmake_minimum_required(VERSION 3.12)
  2. project(jsontest)
  3. # 设置 C++ 标准
  4. set(CMAKE_CXX_STANDARD 17)
  5. # 添加可执行文件和源文件
  6. file(GLOB SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/*.cpp)
  7. set(JSONCPP_INC_DIR /usr/local/include)
  8. add_executable(jsontest ${SOURCES})
  9. # 包含头文件路径(包括其他目录)
  10. target_include_directories(jsontest
  11. PRIVATE
  12. ${JSONCPP_INC_DIR}
  13. )
  14. # 链接 Boost 库
  15. target_link_libraries(jsontest PRIVATE jsoncpp)

运行 ./jsontest
输出

  1. {"DateTime":"44","LogType":"55","ModuleCode":"22","ModuleDesc":"33","ModuleType":"\u4f60\u597d"}

grpc配置和使用

克隆grpc指定分支

  1. git clone -b v1.34.0 https://gitee.com/mirrors/grpc-framework.git grpc

进入目录并更新子模块

  1. cd grpc
  2. git submodule update --init

编译并生成grpc库

  1. cd grpc
  2. mkdir build
  3. cd build
  4. // 指定安装路径 /usr/local
  5. cmake -DCMAKE_INSTALL_PREFIX=/usr/local ..
  6. make -j2
  7. sudo make install

测试安装成功与否

编译源代码中的helloworld文件夹下的文件,步骤如下:

  1. #进入grpc文件夹下
  2. cd examples/cpp/helloworld
  3. mkdir build
  4. cd build
  5. # 编译
  6. cmake ..
  7. make -j8

编译完成后,分别执行greeter_server和greeter_client即可测试。

项目应用grpc

我们的项目中也用到了grpc, 需要编写一个CMakeLists.txt 配置grpc。
大家可以克隆我的boost项目代码

https://gitee.com/secondtonone1/boostasio-learn

进入day19-Grpc-Server目录,我们编写如下的CMakeLists.txt

  1. cmake_minimum_required(VERSION 3.1)
  2. project(GrpcServer LANGUAGES CXX)
  3. set(CMAKE_INCLUDE_CURRENT_DIR ON)
  4. set(CMAKE_CXX_STANDARD 17)
  5. set(CMAKE_CXX_STANDARD_REQUIRED ON)
  6. #假设已经安装好grpc了
  7. find_package(Threads REQUIRED)
  8. set(protobuf_MODULE_COMPATIBLE TRUE)
  9. find_package(Protobuf CONFIG REQUIRED)
  10. message(STATUS "Using protobuf ${Protobuf_VERSION}")
  11. set(_PROTOBUF_LIBPROTOBUF protobuf::libprotobuf)
  12. set(_REFLECTION gRPC::grpc++_reflection)
  13. # Find gRPC installation
  14. # Looks for gRPCConfig.cmake file installed by gRPC's cmake installation.
  15. find_package(gRPC CONFIG REQUIRED)
  16. message(STATUS "Using gRPC ${gRPC_VERSION}")
  17. set(_GRPC_GRPCPP gRPC::grpc++)
  18. # 添加可执行文件和源文件
  19. file(GLOB SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/*.cpp)
  20. file(GLOB PBSOURCES ${CMAKE_CURRENT_SOURCE_DIR}/*.cc)
  21. add_executable(GrpcServer ${SOURCES}
  22. ${PBSOURCES})
  23. target_link_libraries(GrpcServer
  24. ${_REFLECTION}
  25. ${_GRPC_GRPCPP}
  26. ${_PROTOBUF_LIBPROTOBUF})

我们新建一个build文件夹

  1. mkdir build

进入build文件夹里,执行cmake .., 再执行make即可。
直接执行GrpcServer就可以看到我们的程序跑起来了。

总结

本文介绍了如何使用Linux环境下配置和使用grpc和cppjson库,我将docker打包为镜像提交到了网盘上,大家感兴趣可以下载看看

链接
提取码:5wng

热门评论

热门文章

  1. vscode搭建windows C++开发环境

    喜欢(596) 浏览(98579)
  2. 使用hexo搭建个人博客

    喜欢(533) 浏览(13985)
  3. Linux环境搭建和编码

    喜欢(594) 浏览(15635)
  4. MarkDown在线编辑器

    喜欢(514) 浏览(15904)
  5. 聊天项目(28) 分布式服务通知好友申请

    喜欢(507) 浏览(7201)

最新评论

  1. 利用指针和容器实现文本查询 越今朝:应该添加一个过滤功能以解决部分单词无法被查询的问题: eg: "I am a teacher."中的teacher无法被查询,因为在示例代码中teacher.被解释为一个单词从而忽略了teacher本身。
  2. 无锁并发队列 TenThousandOne:_head  和 _tail  替换为原子变量。那里pop的逻辑,val = _data[h] 可以移到循环外面吗
  3. 解决博客回复区被脚本注入的问题 secondtonone1:走到现在我忽然明白一个道理,无论工作也好生活也罢,最重要的是开心,即使一份安稳的工作不能给我带来事业上的积累也要合理的舍弃,所以我还是想去做喜欢的方向。
  4. 处理网络粘包问题 zyouth: //消息的长度小于头部规定的长度,说明数据未收全,则先将部分消息放到接收节点里 if (bytes_transferred < data_len) { memcpy(_recv_msg_node->_data + _recv_msg_node->_cur_len, _data + copy_len, bytes_transferred); _recv_msg_node->_cur_len += bytes_transferred; ::memset(_data, 0, MAX_LENGTH); _socket.async_read_some(boost::asio::buffer(_data, MAX_LENGTH), std::bind(&CSession::HandleRead, this, std::placeholders::_1, std::placeholders::_2, shared_self)); //头部处理完成 _b_head_parse = true; return; } 把_b_head_parse = true;放在_socket.async_read_some前面是不是更好
  5. C++ 线程池原理和实现 mzx2023:两种方法解决,一种是改排序算法,就是当线程耗尽的时候,使用普通递归,另一种是当在线程池commit的时候,判断线程是否耗尽,耗尽的话就直接当前线程执行task

个人公众号

个人微信