腾讯开源项目phxpaxos的编译步骤
#paxos的一般编译流程在项目文档《中文详细编译手册》里面已经有介绍,这里重点介绍一下编译samples目录下的代码;
#我的环境是ubuntu;
#设置paxos根目录
phx_dir=~/code/tencent/phxpaxos/
#编译leveldb
cd $phx_dir/third_party/leveldb
make
mkdir lib
cd lib
ln -s ../libleveldb.a libleveldb.a
#编译protobuf
cd $phx_dir/third_party/protobuf
./autogen.sh
./configure CXXFLAGS=-fPIC --prefix=`pwd`
make && make install
#编译glog
cd $phx_dir/third_party/glog
./configure CXXFLAGS=-fPIC -prefix=`pwd`
make && make install
#有时候我们在phxpaxos代码里面改了东西,但是sample工程不能生效,
#所以我们在编译 libphxpaxos.a 和 libphxpaxos_plugin.a 的时候先删掉之前的静态库
#然后在编译 sample 代码的时候先执行一下 make clean
#编译phxpaxos静态库
cd $phx_dir
find ./ -name "libphxpaxos.a" | xargs rm
find ./ -name "libphxpaxos_plugin.a" | xargs rm
./autoinstall.sh
make debug=y && make install
ll lib/
#编译PhxPaxos Plugin静态库
cd $phx_dir/plugin
make && make install
ll ../lib
#编译gtest和gmock
cd $phx_dir/third_party
rm -rf googlemock
git clone --recursive https://github.com/google/googletest.git
cd googletest
cmake -DCMAKE_INSTALL_PREFIX=`pwd` .
make && make install
cd $phx_dir/third_party/
mkdir gmock
mv googletest/{include,lib} ./gmock
cd gmock
mv lib64 lib
#grpc依赖于openssl,请下载最新的openssl并编译安装
openssl编译步骤略
grpc依赖于openssl,如果有 libssl.a 链接错误,请下载最新的openssl并编译安装
附错误提示:
[LD] Linking third_party/grpc/libs/opt/libgrpc.so.7.0.0-dev
/usr/bin/ld: /usr/local/lib/libssl.a(t1_meth.o): relocation R_X86_64_32 against .rodata can not be used when making a shared object; recompile with -fPIC
/usr/local/lib/libssl.a: error adding symbols: Bad value
#编译grpc
cd $phx_dir/third_party/
git clone --recursive https://github.com/grpc/grpc.git
make
mkdir bin
cp -rf bins/* bin/
mkdir lib
cp -rf libs/* lib/
cp -rf libs/opt/* lib/
#把grpc的路径加到环境变量
export PATH=$phx_dir/third_party/grpc/bins/opt/:$phx_dir/third_party/grpc/bins/opt/protobuf:$PATH
which grpc_cpp_plugin
which protoc
#编译例子
cd $phx_dir/sample
make
#修改代码之后的快速重编
killall phxecho
phx_dir=~/code/tencent/phxpaxos/
cd $phx_dir
find ./ -name "libphxpaxos.a" | xargs rm
find ./ -name "libphxpaxos_plugin.a" | xargs rm
./autoinstall.sh
if [ $? -ne 0 ]; then echo "[error]"; sleep 365d; fi
make debug=y && make install
if [ $? -ne 0 ]; then echo "[error]"; sleep 365d; fi
ll lib/
if [ $? -ne 0 ]; then echo "[error]"; sleep 365d; fi
cd $phx_dir/plugin
make && make install
if [ $? -ne 0 ]; then echo "[error]"; sleep 365d; fi
ll ../lib
if [ $? -ne 0 ]; then echo "[error]"; sleep 365d; fi
phx_dir=~/code/tencent/phxpaxos/
cd $phx_dir/sample/phxecho
make clean
if [ $? -ne 0 ]; then echo "[error]"; sleep 365d; fi
make
if [ $? -ne 0 ]; then echo "[error]"; sleep 365d; fi
#运行例子
phx_echo_dir=~/code/tencent/phxpaxos/sample/phxecho/
cd $phx_echo_dir
mkdir -p log1/log
mkdir -p log2/log
mkdir -p log3/log
server_1=127.0.0.1:38001
server_2=127.0.0.1:38002
server_3=127.0.0.1:38003
cd $phx_echo_dir/log1 && rm -r log* && mkdir log
$phx_echo_dir/phxecho $server_1 $server_1,$server_2,$server_3
cd $phx_echo_dir/log2 && rm -r log* && mkdir log
$phx_echo_dir/phxecho $server_2 $server_1,$server_2,$server_3
cd $phx_echo_dir/log3 && rm -r log* && mkdir log
$phx_echo_dir/phxecho $server_3 $server_1,$server_2,$server_3
#可以在代码里面加点日志打印
//lijing-tets
PLImp("lijing-test, Instance :: OnTimeout, %d ", 222);
腾讯开源项目phxpaxos的编译步骤的更多相关文章
- Android二维码识别 开源项目ZXing的编译
		
Android二维码识别 开源项目ZXing的编译 Android端的条形码/二维码识别功能 因为手机端的输入不是很方便,所以条形码/二维码的扫描是一种很有效的解决手段. 比较流行的手机应用中,常用的 ...
 - 利用开源项目jadx反编译Android应用
		
原文转自:http://bbs.itheima.com/thread-200475-1-1.html 利用开源项目jadx反编译Android应用 利用Github开源项目jadx可以直接对 .dex ...
 - 流媒体开发之开源项目live555---live555 server 编译 包括更改帧率大小
		
由于要测试8148解码器的性能,需要搭建不同帧率25fps - >30fps,宏块大小defualt 100 000 -> 200 000不同大小的h264码流,所以就需要编译改动的liv ...
 - Windows下编译vpx获得各个项目VS2010解决方案的步骤
		
最近研究了一下几种常见的视频编码器:x264,x265,vpx.本文简单记录一下它们的编译方法. x264,x265,vpx这三个开源的视频编码器可以说是当今“最火”的视频编码器.x264现在占据着H ...
 - 开源项目导入eclipse的一般步骤
		
开源项目导入eclipse的一般步骤 周银辉 下载到开源项目后,我们还是希望导入到eclipse中还看,这样要方便点,一般的步骤是这样的 打开源代码目录, 如果看到里面有.calsspath .pro ...
 - 开源项目导入eclipse的一般步骤[转]
		
下载到开源项目后,我们还是希望导入到eclipse中还看,这样要方便点,一般的步骤是这样的 打开源代码目录, 如果看到里面有.calsspath .project文件,那么说明这个项目本来就是ec ...
 - 使用maven编译dubbo,导入eclipse(其他maven开源项目编译类似)
		
dubbo github下载地址:https://github.com/alibaba/dubbo 相关文档:http://dubbo.io/ 使用maven编译dubbo,导入eclipse(其他m ...
 - maven编译开源项目报enforce错解决
		
刚下载一个开源项目源码,用maven编译发现报错: [ERROR] Failed to execute goal org.apache.maven.plugins:maven-enforcer-plu ...
 - 腾讯开源的 Paxos库 PhxPaxos 代码解读---Accept阶段(一)
		
腾讯开源的 Paxos库 PhxPaxos 代码解读---Accept阶段(一) 在看Accept阶段代码之前, 我们再回想一下 Basic Paxos算法; 1. Basic Paxos 算法是为 ...
 
随机推荐
- 在IDEA中设置命令行参数
 - Lightgbm 随笔
			
lightGBM LightGBM 是一个梯度 boosting 框架,使用基于学习算法的决策树.它可以说是分布式的,高效的,有以下优势: 更快的训练效率 低内存使用 更高的准确率 支持并行化学习 可 ...
 - django APPEND_SLASH
			
#设置项是否开启URL访问地址后面不为/跳转至带有/的路径APPEND_SLASH=True
 - 触摸事件,手势识别(UITouch,UIGestureRecognizer)
			
触摸发生时,UIWindow会有一个队列来存放所有的触摸事件,然后再把这些事件发送给对应的hit-test view,hit-test view会通过touch的四个函数来接收这些事件. 四个函数分别 ...
 - python学习Day14  带参装饰器、可迭代对象、迭代器对象、for 迭代器工作原理、枚举对象、生成器
			
复习 函数的嵌套定义:在函数内部定义另一个函数 闭包:被嵌套的函数 -- 1.外层通过形参给内层函数传参 -- 2.返回内部函数对象----> 延迟执行, 开放封闭原则: 功能可以拓展,但源代 ...
 - Day06 - Ruby三种存取限制:Public,Protected,Private
			
前情提要: 在第五天的最后,我们提到了一句话“相同的class的实体也无法使用别人的singleton method”. 在今天,我们把焦点放在Ruby的method,继续了解存取限制:) Ruby经 ...
 - MATLA总结三
			
1.将分数表示转换为小数表示: vpa( ******(表达式或者变量), n(小数点后几位)) 2.将一个式子中的变量带入具体的值: subs( y, x, [2,3,4] ) 3.用工具箱确定阶 ...
 - ajax原生实现
			
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/ ...
 - Mysql的隔离级别
			
一.首先什么是事务? 事务是应用程序中一系列严密的操作,所有操作必须成功完成,否则在每个操作中所作的所有更改都会被撤消.也就是事务具有原子性,一个事务中的一系列的操作要么全部成功,要么一个都不做. 事 ...
 - JAVA企业级服务器应用之Tomcat
			
Tomcat简介 Tomcat是Apache软件基金会(Apache Software Foundation)的Jakarta项目中的一个核心项目,由Apache,Sun和其他一些公司及个人共同开发而 ...