【Hadoop】Hadoop Snappy 安裝

[TOC]

一、hadoop checknative

首先檢查下 hadoop 是否已經(jīng)集成 snappy:

hadoop checknative -a

Native library checking:
hadoop:  true /home/bigdata/hadoop/lib/native/libhadoop.so.1.0.0
zlib:    true /lib/x86_64-linux-gnu/libz.so.1
snappy:  false 
zstd  :  false 
lz4:     true revision:10301
bzip2:   true /lib/x86_64-linux-gnu/libbz2.so.1
openssl: false Cannot load libcrypto.so (libcrypto.so: cannot open shared object file: No such file or directory)!

二叶眉、所需組件

  1. Snappy 1.1.3: https://pan.baidu.com/s/1aT-voN7TM6kUeZIVIa5p_w&shfl=sharepset 提取碼:ly76
  2. protobuf-2.5.0: https://pan.baidu.com/s/1pJlZubT

三、安裝依賴包

sudo apt-get install gcc g++ libtool cmake maven zlib1g.dev autoconf automake gzip unzip

# 后續(xù)編譯出錯:CMAKE Could NOT find PkgConfig (missing: PKG_CONFIG_EXECUTABLE)季研,添加如下依賴
sudo apt-get install --reinstall pkg-config cmake-data

# 編譯繼續(xù)出錯:CMake not able to find OpenSSL library富腊,添加如下依賴
sudo apt-get install libssl-dev

四腺占、安裝 Snappy

解壓下載的 sanppy 安裝包

tar -xvf snappy-1.1.3.tar.gz
cd snappy-1.1.3
./configure
make
sudo make install

默認(rèn)目錄是 /usr/local/lib琉朽,查看snappy是否安裝成功

ll /usr/local/lib | grep snappy

出現(xiàn)下面5個文件毒租,安裝成功

libsnappy.a
libsnappy.la*
libsnappy.so -> libsnappy.so.1.3.0*
libsnappy.so.1 -> libsnappy.so.1.3.0*
libsnappy.so.1.3.0*

五、安裝 protobuf

tar -xvf protobuf-2.5.0.tar.gz
cd protobuf-2.5.0
./configure --prefix=/home/bigdata/protobuf
make && make install

編譯成功后加入環(huán)境變量并生效:

export PATH= /home/bigdata/protobuf/bin:$PATH

最后箱叁,protoc --version命令墅垮,如顯示libprotoc 2.5.0 則安裝成功。

六耕漱、hadoop-src-2.9.2 編譯源碼

Hadoop2.x 以后版本在 hadoop-common 模塊已經(jīng)內(nèi)置 snappy 編解碼算色,所以編譯安裝 hadoop-snappy 是多余的(Hadoop1.x 需要),只要安裝 snappy 本地庫和重新編譯 hadoop native 庫螟够。

由于下載hadoop-2.9.2.tar.gz中不包含源碼文件灾梦,所以需要使用 hadoop-src-2.9.2包來編譯源碼;

官網(wǎng)下載后解壓:

tar -xvf hadoop-2.9.2-src.tar.gz 

編譯過程中妓笙,會出現(xiàn)java堆棧溢出情況斥废,因此執(zhí)行下述命令擴(kuò)大內(nèi)存:

export MAVEN_OPTS="-Xms256m -Xmx512m"

然后編譯:

mvn package -DskipTests -Pdist,native -Dtar -Dsnappy.lib=/usr/local/lib -Dbundle.snappy

時間會很長,如果安裝了第三步中的依賴给郊,應(yīng)該沒有問題,如果還有報錯捧灰,一般也是缺少相應(yīng)依賴淆九,相應(yīng)安裝解決即可。

編譯成功后可以看到:

ll /home/bigdata/hadoop-2.9.2-src/hadoop-dist/target/hadoop-2.9.2/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 添加 snappy

拷貝庫文件到 hadoop炭庙,同步到集群:

cp -r /home/bigdata/hadoop-2.9.2-src/hadoop-dist/target/hadoop-2.9.2/lib/native/* $HADOOP_HOME/lib/native/

scp -r  $HADOOP_HOME/lib/native/* bigdata@intellif-bigdata-node1:/$HADOOP_HOME/lib/native/
scp -r  $HADOOP_HOME/lib/native/* bigdata@intellif-bigdata-node2:/$HADOOP_HOME/lib/native/
scp -r  $HADOOP_HOME/lib/native/* bigdata@intellif-bigdata-node3:/$HADOOP_HOME/lib/native/

$HADOOP_/HOME/etc/hadoop/hadoop-env.sh 添加如下環(huán)境變量:

export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$HADOOP_HOME/lib/native
export HADOOP_OPTS="-Djava.library.path=$HADOOP_HOME/lib:$HADOOP_COMMON_LIB_NATIVE_DIR"
export HADOOP_COMMON_LIB_NATIVE_DIR=$HADOOP_HOME/lib/native/

修改 $HADOOP_HOME/etc/hadoop/core-site.xml配置文件,在文件中加入:

<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>

修改 $HADOOP_HOME/etc/hadoop/mapred-site.xml

<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>

同步修改配置到所有集群煌寇。

重新啟動 hdfs焕蹄,再次檢查:

hadoop checknative -a

Native library checking:
hadoop:  true /home/bigdata/hadoop/lib/native/libhadoop.so
zlib:    true /lib/x86_64-linux-gnu/libz.so.1
**snappy:  true /home/bigdata/hadoop/lib/native/libsnappy.so.1**
zstd  :  false 
lz4:     true revision:10301
bzip2:   false 

八、hbase 添加 snappy

在 hbase 每個節(jié)點(diǎn)中創(chuàng)建目錄

mkdir -p $HBASE_HOME/lib/native/Linux-amd64-64

每個節(jié)點(diǎn)拷貝庫文件到 Hbase

cp -r $HADOOP_HOME/lib/native/* $HBASE_HOME/lib/native/Linux-amd64-64/

每個節(jié)點(diǎn) $HBASE_HOME/conf/hbase-env.sh 添加如下環(huán)境變量:

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

每個節(jié)點(diǎn) $HBASE_HOME/conf/hbase-site.xml 添加:

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

然后重啟 hbase阀溶。

創(chuàng)建表驗(yàn)證一下:

create 'tsnappy', { NAME => 'f', COMPRESSION => 'snappy'}
describe 'tsnappy'
put 'tsnappy', 'row1', 'f:col1', 'value'
scan 'tsnappy'
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末腻脏,一起剝皮案震驚了整個濱河市鸦泳,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌永品,老刑警劉巖做鹰,帶你破解...
    沈念sama閱讀 218,682評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異鼎姐,居然都是意外死亡钾麸,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,277評論 3 395
  • 文/潘曉璐 我一進(jìn)店門炕桨,熙熙樓的掌柜王于貴愁眉苦臉地迎上來饭尝,“玉大人,你說我怎么就攤上這事献宫≡科剑” “怎么了?”我有些...
    開封第一講書人閱讀 165,083評論 0 355
  • 文/不壞的土叔 我叫張陵遵蚜,是天一觀的道長帖池。 經(jīng)常有香客問我,道長吭净,這世上最難降的妖魔是什么睡汹? 我笑而不...
    開封第一講書人閱讀 58,763評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮寂殉,結(jié)果婚禮上囚巴,老公的妹妹穿的比我還像新娘。我一直安慰自己友扰,他們只是感情好彤叉,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,785評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著村怪,像睡著了一般秽浇。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上甚负,一...
    開封第一講書人閱讀 51,624評論 1 305
  • 那天柬焕,我揣著相機(jī)與錄音,去河邊找鬼梭域。 笑死斑举,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的病涨。 我是一名探鬼主播富玷,決...
    沈念sama閱讀 40,358評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了赎懦?” 一聲冷哼從身側(cè)響起雀鹃,我...
    開封第一講書人閱讀 39,261評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎铲敛,沒想到半個月后褐澎,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,722評論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡伐蒋,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評論 3 336
  • 正文 我和宋清朗相戀三年工三,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片先鱼。...
    茶點(diǎn)故事閱讀 40,030評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡俭正,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出焙畔,到底是詐尸還是另有隱情掸读,我是刑警寧澤,帶...
    沈念sama閱讀 35,737評論 5 346
  • 正文 年R本政府宣布宏多,位于F島的核電站儿惫,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏伸但。R本人自食惡果不足惜肾请,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,360評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望更胖。 院中可真熱鬧铛铁,春花似錦、人聲如沸却妨。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,941評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽彪标。三九已至倍权,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間捞烟,已是汗流浹背账锹。 一陣腳步聲響...
    開封第一講書人閱讀 33,057評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留坷襟,地道東北人。 一個月前我還...
    沈念sama閱讀 48,237評論 3 371
  • 正文 我出身青樓生年,卻偏偏與公主長得像婴程,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子抱婉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,976評論 2 355

推薦閱讀更多精彩內(nèi)容