Hive - การติดตั้ง
โครงการย่อย Hadoop ทั้งหมดเช่น Hive, Pig และ HBase รองรับระบบปฏิบัติการ Linux ดังนั้นคุณต้องติดตั้งระบบปฏิบัติการที่มีรสชาติของ Linux ขั้นตอนง่ายๆต่อไปนี้ดำเนินการสำหรับการติดตั้ง Hive:
ขั้นตอนที่ 1: ตรวจสอบการติดตั้ง JAVA
ต้องติดตั้ง Java บนระบบของคุณก่อนติดตั้ง Hive ให้เราตรวจสอบการติดตั้ง java โดยใช้คำสั่งต่อไปนี้:
$ java –version
หากติดตั้ง Java บนระบบของคุณแล้วคุณจะเห็นการตอบสนองต่อไปนี้:
java version "1.7.0_71"
Java(TM) SE Runtime Environment (build 1.7.0_71-b13)
Java HotSpot(TM) Client VM (build 25.0-b02, mixed mode)
หากไม่ได้ติดตั้ง java ในระบบของคุณให้ทำตามขั้นตอนด้านล่างเพื่อติดตั้ง java
การติดตั้ง Java
ขั้นตอนที่ 1:
ดาวน์โหลด java (JDK <เวอร์ชั่นล่าสุด> - X64.tar.gz) โดยไปที่ลิงค์ต่อไปนี้ http://www.oracle.com/technetwork/java/javase/downloads/jdk7-downloads-1880260.html
จากนั้น jdk-7u71-linux-x64.tar.gz จะถูกดาวน์โหลดลงในระบบของคุณ
ขั้นตอนที่ II:
โดยทั่วไปคุณจะพบไฟล์ java ที่ดาวน์โหลดมาในโฟลเดอร์ดาวน์โหลด ตรวจสอบและแตกไฟล์ jdk-7u71-linux-x64.gz โดยใช้คำสั่งต่อไปนี้
$ cd Downloads/
$ ls
jdk-7u71-linux-x64.gz
$ tar zxf jdk-7u71-linux-x64.gz
$ ls
jdk1.7.0_71 jdk-7u71-linux-x64.gz
ขั้นตอนที่ 3:
เพื่อให้ผู้ใช้ทุกคนสามารถใช้ java ได้คุณต้องย้ายไปที่ตำแหน่ง“ / usr / local /” เปิดรูทและพิมพ์คำสั่งต่อไปนี้
$ su
password:
# mv jdk1.7.0_71 /usr/local/
# exit
ขั้นตอนที่ IV:
สำหรับการตั้งค่าตัวแปร PATH และ JAVA_HOME ให้เพิ่มคำสั่งต่อไปนี้ในไฟล์ ~ / .bashrc
export JAVA_HOME=/usr/local/jdk1.7.0_71
export PATH=$PATH:$JAVA_HOME/bin
ตอนนี้ใช้การเปลี่ยนแปลงทั้งหมดในระบบที่กำลังทำงานอยู่
$ source ~/.bashrc
ขั้นตอนที่ V:
ใช้คำสั่งต่อไปนี้เพื่อกำหนดค่าทางเลือก java:
# alternatives --install /usr/bin/java/java/usr/local/java/bin/java 2
# alternatives --install /usr/bin/javac/javac/usr/local/java/bin/javac 2
# alternatives --install /usr/bin/jar/jar/usr/local/java/bin/jar 2
# alternatives --set java/usr/local/java/bin/java
# alternatives --set javac/usr/local/java/bin/javac
# alternatives --set jar/usr/local/java/bin/jar
ตอนนี้ตรวจสอบการติดตั้งโดยใช้คำสั่ง java -version จากเทอร์มินัลตามที่อธิบายไว้ข้างต้น
ขั้นตอนที่ 2: ตรวจสอบการติดตั้ง Hadoop
ต้องติดตั้ง Hadoop บนระบบของคุณก่อนที่จะติดตั้ง Hive ให้เราตรวจสอบการติดตั้ง Hadoop โดยใช้คำสั่งต่อไปนี้:
$ hadoop version
หาก Hadoop ได้รับการติดตั้งในระบบของคุณแล้วคุณจะได้รับคำตอบดังต่อไปนี้:
Hadoop 2.4.1 Subversion https://svn.apache.org/repos/asf/hadoop/common -r 1529768
Compiled by hortonmu on 2013-10-07T06:28Z
Compiled with protoc 2.5.0
From source with checksum 79e53ce7994d1628b240f09af91e1af4
หากไม่ได้ติดตั้ง Hadoop ในระบบของคุณให้ดำเนินการตามขั้นตอนต่อไปนี้:
กำลังดาวน์โหลด Hadoop
ดาวน์โหลดและแยก Hadoop 2.4.1 จาก Apache Software Foundation โดยใช้คำสั่งต่อไปนี้
$ su
password:
# cd /usr/local
# wget http://apache.claz.org/hadoop/common/hadoop-2.4.1/
hadoop-2.4.1.tar.gz
# tar xzf hadoop-2.4.1.tar.gz
# mv hadoop-2.4.1/* to hadoop/
# exit
การติดตั้ง Hadoop ในโหมดกระจายหลอก
ขั้นตอนต่อไปนี้ใช้เพื่อติดตั้ง Hadoop 2.4.1 ในโหมดกระจายหลอก
ขั้นตอนที่ 1: การตั้งค่า Hadoop
คุณสามารถตั้งค่าตัวแปรสภาพแวดล้อม Hadoop ได้โดยต่อท้ายคำสั่งต่อไปนี้ ~/.bashrc ไฟล์.
export HADOOP_HOME=/usr/local/hadoop
export HADOOP_MAPRED_HOME=$HADOOP_HOME
export HADOOP_COMMON_HOME=$HADOOP_HOME
export HADOOP_HDFS_HOME=$HADOOP_HOME
export YARN_HOME=$HADOOP_HOME
export HADOOP_COMMON_LIB_NATIVE_DIR=$HADOOP_HOME/lib/native export
PATH=$PATH:$HADOOP_HOME/sbin:$HADOOP_HOME/bin
ตอนนี้ใช้การเปลี่ยนแปลงทั้งหมดในระบบที่กำลังทำงานอยู่
$ source ~/.bashrc
ขั้นตอนที่ II: การกำหนดค่า Hadoop
คุณสามารถค้นหาไฟล์การกำหนดค่า Hadoop ทั้งหมดได้ในตำแหน่ง“ $ HADOOP_HOME / etc / hadoop” คุณต้องทำการเปลี่ยนแปลงที่เหมาะสมในไฟล์กำหนดค่าเหล่านั้นตามโครงสร้างพื้นฐาน Hadoop ของคุณ
$ cd $HADOOP_HOME/etc/hadoop
ในการพัฒนาโปรแกรม Hadoop โดยใช้ java คุณต้องรีเซ็ตตัวแปรสภาพแวดล้อม java ใน hadoop-env.sh ไฟล์โดยแทนที่ไฟล์ JAVA_HOME ค่ากับตำแหน่งของ java ในระบบของคุณ
export JAVA_HOME=/usr/local/jdk1.7.0_71
ด้านล่างนี้คือรายการไฟล์ที่คุณต้องแก้ไขเพื่อกำหนดค่า Hadoop
core-site.xml
core-site.xml ไฟล์มีข้อมูลเช่นหมายเลขพอร์ตที่ใช้สำหรับอินสแตนซ์ Hadoop หน่วยความจำที่จัดสรรสำหรับระบบไฟล์ขีด จำกัด หน่วยความจำสำหรับจัดเก็บข้อมูลและขนาดของบัฟเฟอร์อ่าน / เขียน
เปิด core-site.xml และเพิ่มคุณสมบัติต่อไปนี้ระหว่างแท็ก <configuration> และ </configuration>
<configuration>
<property>
<name>fs.default.name</name>
<value>hdfs://localhost:9000</value>
</property>
</configuration>
hdfs-site.xml
hdfs-site.xmlไฟล์มีข้อมูลเช่นค่าของข้อมูลการจำลองแบบพา ธ namenode และพา ธ datanode ของระบบไฟล์โลคัลของคุณ หมายถึงสถานที่ที่คุณต้องการเก็บ Hadoop อินฟาเรด
ให้เราสมมติข้อมูลต่อไปนี้
dfs.replication (data replication value) = 1
(In the following path /hadoop/ is the user name.
hadoopinfra/hdfs/namenode is the directory created by hdfs file system.)
namenode path = //home/hadoop/hadoopinfra/hdfs/namenode
(hadoopinfra/hdfs/datanode is the directory created by hdfs file system.)
datanode path = //home/hadoop/hadoopinfra/hdfs/datanode
เปิดไฟล์นี้และเพิ่มคุณสมบัติต่อไปนี้ระหว่างแท็ก <configuration>, </configuration> ในไฟล์นี้
<configuration>
<property>
<name>dfs.replication</name>
<value>1</value>
</property>
<property>
<name>dfs.name.dir</name>
<value>file:///home/hadoop/hadoopinfra/hdfs/namenode </value>
</property>
<property>
<name>dfs.data.dir</name>
<value>file:///home/hadoop/hadoopinfra/hdfs/datanode </value >
</property>
</configuration>
Note: ในไฟล์ด้านบนค่าคุณสมบัติทั้งหมดเป็นค่าที่ผู้ใช้กำหนดและคุณสามารถเปลี่ยนแปลงได้ตามโครงสร้างพื้นฐาน Hadoop ของคุณ
yarn-site.xml
ไฟล์นี้ใช้เพื่อกำหนดค่าเส้นด้ายใน Hadoop เปิดไฟล์ yarn-site.xml และเพิ่มคุณสมบัติต่อไปนี้ระหว่างแท็ก <configuration>, </configuration> ในไฟล์นี้
<configuration>
<property>
<name>yarn.nodemanager.aux-services</name>
<value>mapreduce_shuffle</value>
</property>
</configuration>
mapred-site.xml
ไฟล์นี้ใช้เพื่อระบุเฟรมเวิร์ก MapReduce ที่เราใช้อยู่ โดยค่าเริ่มต้น Hadoop มีเทมเพลตของ yarn-site.xml ก่อนอื่นคุณต้องคัดลอกไฟล์จาก mapred-site, xml.template ไปยังไฟล์ mapred-site.xml โดยใช้คำสั่งต่อไปนี้
$ cp mapred-site.xml.template mapred-site.xml
เปิด mapred-site.xml ไฟล์และเพิ่มคุณสมบัติต่อไปนี้ระหว่างแท็ก <configuration>, </configuration> ในไฟล์นี้
<configuration>
<property>
<name>mapreduce.framework.name</name>
<value>yarn</value>
</property>
</configuration>
การตรวจสอบการติดตั้ง Hadoop
ขั้นตอนต่อไปนี้ใช้เพื่อตรวจสอบการติดตั้ง Hadoop
ขั้นตอนที่ 1: ตั้งชื่อโหนด
ตั้งค่า Namenode โดยใช้คำสั่ง“ hdfs namenode -format” ดังนี้
$ cd ~
$ hdfs namenode -format
ผลที่คาดว่าจะได้รับมีดังนี้
10/24/14 21:30:55 INFO namenode.NameNode: STARTUP_MSG:
/************************************************************
STARTUP_MSG: Starting NameNode
STARTUP_MSG: host = localhost/192.168.1.11
STARTUP_MSG: args = [-format]
STARTUP_MSG: version = 2.4.1
...
...
10/24/14 21:30:56 INFO common.Storage: Storage directory
/home/hadoop/hadoopinfra/hdfs/namenode has been successfully formatted.
10/24/14 21:30:56 INFO namenode.NNStorageRetentionManager: Going to
retain 1 images with txid >= 0
10/24/14 21:30:56 INFO util.ExitUtil: Exiting with status 0
10/24/14 21:30:56 INFO namenode.NameNode: SHUTDOWN_MSG:
/************************************************************
SHUTDOWN_MSG: Shutting down NameNode at localhost/192.168.1.11
************************************************************/
ขั้นตอนที่ II: การตรวจสอบ Hadoop dfs
คำสั่งต่อไปนี้ใช้เพื่อเริ่ม dfs การดำเนินการคำสั่งนี้จะเริ่มระบบไฟล์ Hadoop ของคุณ
$ start-dfs.sh
ผลลัพธ์ที่คาดหวังมีดังนี้:
10/24/14 21:37:56
Starting namenodes on [localhost]
localhost: starting namenode, logging to /home/hadoop/hadoop-2.4.1/logs/hadoop-hadoop-namenode-localhost.out
localhost: starting datanode, logging to /home/hadoop/hadoop-2.4.1/logs/hadoop-hadoop-datanode-localhost.out
Starting secondary namenodes [0.0.0.0]
ขั้นตอนที่ 3: การตรวจสอบสคริปต์เส้นด้าย
คำสั่งต่อไปนี้ใช้เพื่อเริ่มสคริปต์เส้นด้าย การดำเนินการคำสั่งนี้จะเริ่มต้นเส้นด้าย daemons ของคุณ
$ start-yarn.sh
ผลลัพธ์ที่คาดหวังมีดังนี้:
starting yarn daemons
starting resourcemanager, logging to /home/hadoop/hadoop-2.4.1/logs/yarn-hadoop-resourcemanager-localhost.out
localhost: starting nodemanager, logging to /home/hadoop/hadoop-2.4.1/logs/yarn-hadoop-nodemanager-localhost.out
ขั้นตอนที่ IV: การเข้าถึง Hadoop บนเบราว์เซอร์
หมายเลขพอร์ตเริ่มต้นในการเข้าถึง Hadoop คือ 50070 ใช้ url ต่อไปนี้เพื่อรับบริการ Hadoop บนเบราว์เซอร์ของคุณ
http://localhost:50070/
ขั้นตอนที่ V: ตรวจสอบแอปพลิเคชันทั้งหมดสำหรับคลัสเตอร์
หมายเลขพอร์ตเริ่มต้นเพื่อเข้าถึงแอปพลิเคชันทั้งหมดของคลัสเตอร์คือ 8088 ใช้ url ต่อไปนี้เพื่อเยี่ยมชมบริการนี้
http://localhost:8088/
ขั้นตอนที่ 3: ดาวน์โหลด Hive
เราใช้ hive-0.14.0 ในบทช่วยสอนนี้ คุณสามารถดาวน์โหลดได้โดยไปที่ลิงค์ต่อไปนี้http://apache.petsads.us/hive/hive-0.14.0/.ให้เราถือว่ามันถูกดาวน์โหลดลงในไดเร็กทอรี / Downloads ที่นี่เราดาวน์โหลดไฟล์เก็บถาวร Hive ชื่อ“ apache-hive-0.14.0-bin.tar.gz” สำหรับบทช่วยสอนนี้ คำสั่งต่อไปนี้ใช้เพื่อตรวจสอบการดาวน์โหลด:
$ cd Downloads
$ ls
เมื่อดาวน์โหลดสำเร็จคุณจะเห็นคำตอบต่อไปนี้:
apache-hive-0.14.0-bin.tar.gz
ขั้นตอนที่ 4: การติดตั้ง Hive
ขั้นตอนต่อไปนี้จำเป็นสำหรับการติดตั้ง Hive บนระบบของคุณ ให้เราถือว่าไฟล์เก็บถาวร Hive ถูกดาวน์โหลดไปยังไดเร็กทอรี / Downloads
การแยกและยืนยัน Hive Archive
คำสั่งต่อไปนี้ใช้เพื่อตรวจสอบการดาวน์โหลดและแตกไฟล์เก็บถาวรของกลุ่ม:
$ tar zxvf apache-hive-0.14.0-bin.tar.gz
$ ls
เมื่อดาวน์โหลดสำเร็จคุณจะเห็นคำตอบต่อไปนี้:
apache-hive-0.14.0-bin apache-hive-0.14.0-bin.tar.gz
การคัดลอกไฟล์ไปยังไดเร็กทอรี / usr / local / hive
เราจำเป็นต้องคัดลอกไฟล์จากผู้ใช้ขั้นสูง“ su -” คำสั่งต่อไปนี้ใช้เพื่อคัดลอกไฟล์จากไดเร็กทอรีที่แยกไปยังไดเร็กทอรี / usr / local / hive”
$ su -
passwd:
# cd /home/user/Download
# mv apache-hive-0.14.0-bin /usr/local/hive
# exit
การตั้งค่าสภาพแวดล้อมสำหรับ Hive
คุณสามารถตั้งค่าสภาพแวดล้อมไฮฟ์ได้โดยต่อท้ายบรรทัดต่อไปนี้ ~/.bashrc ไฟล์:
export HIVE_HOME=/usr/local/hive
export PATH=$PATH:$HIVE_HOME/bin
export CLASSPATH=$CLASSPATH:/usr/local/Hadoop/lib/*:.
export CLASSPATH=$CLASSPATH:/usr/local/hive/lib/*:.
คำสั่งต่อไปนี้ใช้เพื่อเรียกใช้ไฟล์ ~ / .bashrc
$ source ~/.bashrc
ขั้นตอนที่ 5: การกำหนดค่า Hive
ในการกำหนดค่า Hive ด้วย Hadoop คุณต้องแก้ไขไฟล์ hive-env.sh ซึ่งวางอยู่ในไฟล์ $HIVE_HOME/confไดเรกทอรี คำสั่งต่อไปนี้เปลี่ยนเส้นทางไปยัง Hiveconfig โฟลเดอร์และคัดลอกไฟล์เทมเพลต:
$ cd $HIVE_HOME/conf
$ cp hive-env.sh.template hive-env.sh
แก้ไขไฟล์ hive-env.sh ไฟล์โดยต่อท้ายบรรทัดต่อไปนี้:
export HADOOP_HOME=/usr/local/hadoop
การติดตั้ง Hive เสร็จสมบูรณ์ ตอนนี้คุณต้องการเซิร์ฟเวอร์ฐานข้อมูลภายนอกเพื่อกำหนดค่า Metastore เราใช้ฐานข้อมูล Apache Derby
ขั้นตอนที่ 6: การดาวน์โหลดและติดตั้ง Apache Derby
ทำตามขั้นตอนด้านล่างเพื่อดาวน์โหลดและติดตั้ง Apache Derby:
กำลังดาวน์โหลด Apache Derby
คำสั่งต่อไปนี้ใช้เพื่อดาวน์โหลด Apache Derby ใช้เวลาในการดาวน์โหลด
$ cd ~
$ wget http://archive.apache.org/dist/db/derby/db-derby-10.4.2.0/db-derby-10.4.2.0-bin.tar.gz
คำสั่งต่อไปนี้ใช้เพื่อตรวจสอบการดาวน์โหลด:
$ ls
เมื่อดาวน์โหลดสำเร็จคุณจะเห็นคำตอบต่อไปนี้:
db-derby-10.4.2.0-bin.tar.gz
การแยกและตรวจสอบการเก็บถาวร Derby
คำสั่งต่อไปนี้ใช้สำหรับการแตกและตรวจสอบ Derby archive:
$ tar zxvf db-derby-10.4.2.0-bin.tar.gz
$ ls
เมื่อดาวน์โหลดสำเร็จคุณจะเห็นคำตอบต่อไปนี้:
db-derby-10.4.2.0-bin db-derby-10.4.2.0-bin.tar.gz
การคัดลอกไฟล์ไปยังไดเร็กทอรี / usr / local / derby
เราจำเป็นต้องคัดลอกจากผู้ใช้ขั้นสูง“ su -” คำสั่งต่อไปนี้ใช้เพื่อคัดลอกไฟล์จากไดเร็กทอรีที่แยกไปยังไดเร็กทอรี / usr / local / derby:
$ su -
passwd:
# cd /home/user
# mv db-derby-10.4.2.0-bin /usr/local/derby
# exit
การตั้งค่าสภาพแวดล้อมสำหรับ Derby
คุณสามารถตั้งค่าสภาพแวดล้อม Derby โดยต่อท้ายบรรทัดต่อไปนี้ ~/.bashrc ไฟล์:
export DERBY_HOME=/usr/local/derby
export PATH=$PATH:$DERBY_HOME/bin
Apache Hive
18
export CLASSPATH=$CLASSPATH:$DERBY_HOME/lib/derby.jar:$DERBY_HOME/lib/derbytools.jar
คำสั่งต่อไปนี้ใช้เพื่อดำเนินการ ~/.bashrc ไฟล์:
$ source ~/.bashrc
สร้างไดเร็กทอรีเพื่อจัดเก็บ Metastore
สร้างไดเร็กทอรีชื่อ data ในไดเร็กทอรี $ DERBY_HOME เพื่อจัดเก็บข้อมูล Metastore
$ mkdir $DERBY_HOME/data
การติดตั้ง Derby และการตั้งค่าสภาพแวดล้อมเสร็จสมบูรณ์แล้ว
ขั้นตอนที่ 7: การกำหนดค่า Metastore of Hive
การกำหนดค่า Metastore หมายถึงการระบุ Hive ที่จัดเก็บฐานข้อมูล คุณสามารถทำได้โดยแก้ไขไฟล์ hive-site.xml ซึ่งอยู่ในไดเร็กทอรี $ HIVE_HOME / conf ก่อนอื่นให้คัดลอกไฟล์เทมเพลตโดยใช้คำสั่งต่อไปนี้:
$ cd $HIVE_HOME/conf
$ cp hive-default.xml.template hive-site.xml
แก้ไข hive-site.xml และต่อท้ายบรรทัดต่อไปนี้ระหว่างแท็ก <configuration> และ </configuration>:
<property>
<name>javax.jdo.option.ConnectionURL</name>
<value>jdbc:derby://localhost:1527/metastore_db;create=true </value>
<description>JDBC connect string for a JDBC metastore </description>
</property>
สร้างไฟล์ชื่อ jpox.properties และเพิ่มบรรทัดต่อไปนี้:
javax.jdo.PersistenceManagerFactoryClass =
org.jpox.PersistenceManagerFactoryImpl
org.jpox.autoCreateSchema = false
org.jpox.validateTables = false
org.jpox.validateColumns = false
org.jpox.validateConstraints = false
org.jpox.storeManagerType = rdbms
org.jpox.autoCreateSchema = true
org.jpox.autoStartMechanismMode = checked
org.jpox.transactionIsolation = read_committed
javax.jdo.option.DetachAllOnCommit = true
javax.jdo.option.NontransactionalRead = true
javax.jdo.option.ConnectionDriverName = org.apache.derby.jdbc.ClientDriver
javax.jdo.option.ConnectionURL = jdbc:derby://hadoop1:1527/metastore_db;create = true
javax.jdo.option.ConnectionUserName = APP
javax.jdo.option.ConnectionPassword = mine
ขั้นตอนที่ 8: การตรวจสอบการติดตั้ง Hive
ก่อนที่จะเรียกใช้ Hive คุณต้องสร้างไฟล์ /tmpโฟลเดอร์และโฟลเดอร์ Hive แยกต่างหากใน HDFS ที่นี่เราใช้ไฟล์/user/hive/warehouseโฟลเดอร์ คุณต้องตั้งค่าสิทธิ์ในการเขียนสำหรับโฟลเดอร์ที่สร้างขึ้นใหม่ดังที่แสดงด้านล่าง:
chmod g+w
ตั้งค่าเป็น HDFS ก่อนยืนยัน Hive ใช้คำสั่งต่อไปนี้:
$ $HADOOP_HOME/bin/hadoop fs -mkdir /tmp
$ $HADOOP_HOME/bin/hadoop fs -mkdir /user/hive/warehouse
$ $HADOOP_HOME/bin/hadoop fs -chmod g+w /tmp
$ $HADOOP_HOME/bin/hadoop fs -chmod g+w /user/hive/warehouse
คำสั่งต่อไปนี้ใช้เพื่อตรวจสอบการติดตั้ง Hive:
$ cd $HIVE_HOME
$ bin/hive
ในการติดตั้ง Hive สำเร็จคุณจะเห็นคำตอบต่อไปนี้:
Logging initialized using configuration in jar:file:/home/hadoop/hive-0.9.0/lib/hive-common-0.9.0.jar!/hive-log4j.properties
Hive history file=/tmp/hadoop/hive_job_log_hadoop_201312121621_1494929084.txt
………………….
hive>
คำสั่งตัวอย่างต่อไปนี้ถูกเรียกใช้เพื่อแสดงตารางทั้งหมด:
hive> show tables;
OK
Time taken: 2.798 seconds
hive>