Hadoop/HBase 編譯安裝 snappy 壓縮工具(採坑)

準備所需組件

  1. Hadoop 2.7.3:
    https://github.com/apache/had...
  2. Snappy 1.1.3: https://github.com/google/sna...
  3. protobuf-2.5.0: https://github.com/google/pro...

安裝依賴包

ant,gcc,gcc-c++,make,autoconf,automake,cmake,gzip,libssl-devel,openssl-devel,libtool,Java7+,maven 3+

大部分可直接 yum install 安裝便可c++

安裝 snappy

  1. 解壓 unzip snappy-1.1.3.zip
  2. 進入目錄 cd snappy-1.1.3
  3. 編譯安裝 ./configure, make && make install;編譯成功後,在 /usr/local/lib/ 下會有以下
# ls /usr/local/lib/
libsnappy.a libsnappy.la libsnappy.so libsnappy.so.1 libsnappy.so.1.3.0

安裝 protobuf

  1. 解壓:unzip protobuf-2.5.0.zip
  2. 進入目錄:cd protobuf-2.5.0/
  3. 編譯安裝:./configure, make && make install
  4. 配置環境變量:export PATH=/usr/local/protoc/bin:$PATH
  5. 當即生效:source /etc/profile
  6. 查看版本: protoc –version
[root@SparkWorker3 data]# protoc --version
libprotoc 2.5.0

編譯 hadoop 源碼

  1. 安裝 jdk,maven,安裝依賴庫:git

    yum -y install svn ncurses-devel gcc*
    yum -y install lzo-devel zlib-devel autoconf automake libtool cmake openssl-devel
  2. 解壓 unzip hadoop-release-2.7.3-RC2.zip
  3. 進入目錄 cd hadoop-release-2.7.3-RC2/
  4. 設置 maven 內存,export MAVEN_OPTS="-Xms256m -Xmx512m"
  5. 編譯 mvn package -DskipTests -Pdist,native -Dtar -Dsnappy.lib=/usr/local/lib -Dbundle.snappy
  6. 時間會很長,通常報錯都是缺乏依賴
  7. 結果以下
# ls hadoop-release-2.7.3-RC2/hadoop-dist/target/hadoop-2.7.3/lib/native
libhadoop.a         libhadooputils.a  libsnappy.a     libsnappy.so.1.3.0
libhadooppipes.a    libhdfs.a         libsnappy.la
libhadoop.so        libhdfs.so        libsnappy.so
libhadoop.so.1.0.0  libhdfs.so.0.0.0  libsnappy.so.1

hadoop 和hbase 添加 snappy

  1. 拷貝庫文件到 hadoopgithub

    # cp -r /data/hadoop-compile/hadoop-release-2.7.3-RC2/hadoop-dist/target/hadoop-2.7.3/lib/native/* $HADOOP_HOME/lib/native/
  2. 在 hbase 中建立目錄apache

    # mkdir -p $HBASE_HOME/lib/native/Linux-amd64-64
  3. 拷貝庫文件到 Hbasebash

    # cp -r /data/hadoop-compile/hadoop-release-2.7.3-RC2/hadoop-dist/target/hadoop-2.7.3/lib/native/* $HBASE_HOME/lib/native/Linux-amd64-64/
  4. $HADOOP_/HOME/etc/hadoop/hadoop-env.sh 添加以下環境變量:app

    export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/hadoop/hadoop-2.7.3/lib/native/:/usr/local/lib/
  5. $HBASE_HOME/conf/hbase-env.sh 添加以下環境變量:maven

    export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/hadoop/hadoop-2.7.3/lib/native/:/usr/local/lib/
    export HBASE_LIBRARY_PATH=$HBASE_LIBRARY_PATH:$HBASE_HOME/lib/native/Linux-amd64-64/:/usr/local/lib/

修改配置文件

  1. 添加 $HADOOP_HOOME/etc/hadoop/core-site.xmlsvn

    <property>  
          <name>io.compression.codecs</name>  
          <value>org.apache.hadoop.io.compress.GzipCodec,  
            org.apache.hadoop.io.compress.DefaultCodec,  
            org.apache.hadoop.io.compress.BZip2Codec,  
            org.apache.hadoop.io.compress.SnappyCodec  
          </value>  
       </property>
  2. 添加 $HADOOP_HOOME/etc/hadoop/mapred-site.xmloop

    <property>    
        <name>mapred.output.compress</name>    
        <value>true</value>    
    </property>    
    <property>    
        <name>mapred.output.compression.codec</name>    
        <value>org.apache.hadoop.io.compress.SnappyCodec</value>    
    </property>    
    <property>    
        <name>mapred.compress.map.output</name>    
        <value>true</value>    
    </property>    
    <property>    
        <name>mapred.map.output.compression.codec</name>    
        <value>org.apache.hadoop.io.compress.SnappyCodec</value>    
    </property>
  3. 添加 $HBASE_HOME/conf/hbase-site.xml測試

    <property>  
             <name>hbase.regionserver.codecs</name>  
             <value>snappy</value>  
     </property>

重啓 hadoop、hbase,並測試

hadoop測試: $HADOOP_HOME/bin/hadoop checknative -a

# $HADOOP_HOME/bin/hadoop checknative -a
17/09/21 10:31:50 INFO zlib.ZlibFactory: Successfully loaded & initialized native-zlib library
Native library checking:
hadoop:  true /usr/local/hadoop/hadoop-2.7.3/lib/native/libhadoop.so
zlib:    true /lib64/libz.so.1
snappy:  true /usr/local/hadoop/hadoop-2.7.3/lib/native/libsnappy.so.1
lz4:     true revision:99
bzip2:   false 
openssl: true /lib64/libcrypto.so
17/09/21 10:31:50 INFO util.ExitUtil: Exiting with status 1

hbase 建立表:

create 'snappytest', { NAME => 'info', COMPRESSION => 'snappy'}
相關文章
相關標籤/搜索