C++ 实现 MIT6.824 环境配置

环境配置

Thrift 库

这个 Thrift 是一个轻量级的,跨语言的 rpc 库。安装这个库,我们首先需要安装它需要的依赖。

sh 复制代码
# 相关依赖工具
sudo yum install automake \
libtool \
flex \
bison \
pkgconfig \
gcc-c++ \
boost-devel \
libevent-devel \
zlib-devel \
python-devel \
ruby-devel

然后下载对应的 Thrift 的版本安装包,同时解压,安装

sh 复制代码
# 下载源代码,这里以 0.21.0 为例
wget https://github.com/apache/thrift/archive/refs/tags/v0.21.0.zip
# 然后解压
unzip v0.21.0.zip
# 然后进入文件目录
cd thrift-0.21.0
# 然后执行 sh 脚本
./bootstrap.sh
# 加载编译配置
./configure --with-cpp --with-boost --with-python --without-csharp --with-java --without-erlang --without-perl --with-php --without-php_extension --without-ruby --without-haskell  --without-go
# 编译
make -j4
# 安装
sudo make install

我在安装 Thrift 的时候,遇到找不到一个 boost 静态库(libboost_unit_test_framework.a)的问题,后来找到了解决方案,这里记录一下

sh 复制代码
# 下载 boost 库的源代码
wget https://archives.boost.io/release/1.87.0/source/boost_1_87_0.tar.gz
# 解压文件
tar xvf boost_1_87_0.tar.gz
# 进入文件目录、执行配置脚本
cd boost_1_87_0
./bootstrap.sh
./b2 --build-type=complete --layout=versioned link=static

!note\] 这里执行 `./b2` 的时候,一定要带上后面的参数,不然无法生成静态库

Glog 库

这里一个 Google 的日志库,配置这个外部依赖并不复杂

sh 复制代码
# 获取源代码
wget https://github.com/google/glog/archive/refs/tags/v0.6.0.zip
# 解压
unzip v0.6.0.zip
# 进入文件目录、创建 build 文件夹
cd glog-0.6.0 && mkdir build
# 构建cmake、编译
cmake .. && make -j4
# 安装
sudo make install

Gflags 库

这是一个用于处理命令行标志的库,一般和 Google 其他库一起使用,其提供了一种简单的方法来定义和解析程序的命令行参数,增强程序的可配置性和灵活性。

sh 复制代码
# 下载源码
wget https://github.com/gflags/gflags/archive/refs/tags/v2.2.2.zip
# 解压
unzip v2.2.2.zip
# 进入目录文件、创建 build
cd gflags-2.2.2 && mkdir build
# 加载 cmake 配置
cmake ..
# 编译、安装
make -j4 && sudo make install
相关推荐
一叶飘零_sweeeet1 天前
从手写 Redis 分布式锁到精通 Redisson:分布式系统的并发控制终极指南
redis·分布式·redisson
在未来等你1 天前
Kafka面试精讲 Day 13:故障检测与自动恢复
大数据·分布式·面试·kafka·消息队列
cui_win1 天前
基于Golang + vue3 开发的 kafka 多集群管理
分布式·kafka
iiYcyk1 天前
kafka特性和原理
分布式·kafka
在未来等你1 天前
Kafka面试精讲 Day 15:跨数据中心复制与灾备
大数据·分布式·面试·kafka·消息队列
Hello.Reader1 天前
Kafka 设计与实现动机、持久化、效率、生产者/消费者、事务、复制、日志压缩与配额
分布式·kafka
失散131 天前
分布式专题——5 大厂Redis高并发缓存架构实战与性能优化
java·redis·分布式·缓存·架构
小橘快跑1 天前
动态控制rabbitmq中的消费者监听的启动和停止
分布式·rabbitmq
在未来等你1 天前
Elasticsearch面试精讲 Day 15:索引别名与零停机更新
大数据·分布式·elasticsearch·搜索引擎·面试
无名客01 天前
redis分布式锁为什么采用Lua脚本实现。而不是事务
redis·分布式·lua·事务