1 下载protobuf
https://github.com/google/protobuf/releases/download/v2.6.1/protobuf-2.6.1.tar.gz
编译hadoop-2.7.3 要求 protobuf-2.5.0,只需要将链接改为
https://github.com/google/protobuf/releases/download/v2.5.0/protobuf-2.5.0.tar.gz
2 进入下载文件的目录
tar -zxvf protobuf-2.6.1.tar.gz
cd protobuf-2.6.1/
./configure
make
make check
sudo make install
我在执行./configure时出现如下问题
Ubuntu: configure error: C++ preprocessor "/lib/cpp" fails sanity check
解决办法
sudo apt-get install build-essential
3 检查是否安装成功
protoc --version
如果安装成功,会出现版本号 如
libprotoc 2.6.1
最后我安装完成,用上述命令检查版本号时出现如下问题
protoc: error while loading shared libraries: libprotocbuf.so.9: cannot open shared
错误原因
protobuf的默认安装路径是/usr/local/lib,而/usr/local/lib不在ubuntu体系默认的LD_LIBRARY_PATH里,所以就找不到lib
解决办法
1 在 /etc/ld.so.conf.d/目录下创建文件bprotobuf.conf文件,文件内容如下
/usr/local/lib
2 输入命令
sudo ldconfig
这时,再输入protoc --version就可以正常看到版本号了
关于/etc/ld.so.conf.d/的了解请参考下面这篇文章的说明
原文链接:https://www.f2er.com/ubuntu/355117.html