HCatalog - त्वरित गाइड

HCatalog क्या है?

HCatalog Hadoop के लिए एक टेबल स्टोरेज मैनेजमेंट टूल है। यह Hive मेटास्टोर के सारणीबद्ध डेटा को अन्य Hadoop अनुप्रयोगों के लिए उजागर करता है। यह उपयोगकर्ताओं को विभिन्न डेटा प्रोसेसिंग टूल (Pig, MapReduce) से आसानी से ग्रिड पर डेटा लिखने में सक्षम बनाता है। यह सुनिश्चित करता है कि उपयोगकर्ताओं को इस बात की चिंता नहीं है कि उनका डेटा कहाँ और किस प्रारूप में संग्रहीत है।

HCatalog हाइव के एक प्रमुख घटक की तरह काम करता है और यह उपयोगकर्ताओं को किसी भी प्रारूप और किसी भी संरचना में अपने डेटा को संग्रहीत करने में सक्षम बनाता है।

क्यों HCatalog?

सही नौकरी के लिए सही उपकरण सक्षम करना

Hadoop ecosystem में डाटा प्रोसेसिंग के लिए विभिन्न उपकरण होते हैं जैसे Hive, Pig, और MapReduce। यद्यपि इन उपकरणों को मेटाडेटा की आवश्यकता नहीं होती है, फिर भी वे मौजूद होने पर इससे लाभ उठा सकते हैं। मेटाडेटा स्टोर साझा करना उपयोगकर्ताओं को टूल के माध्यम से डेटा को अधिक आसानी से साझा करने में सक्षम बनाता है। एक वर्कफ़्लो जहाँ डेटा को लोड किया जाता है और MapReduce या Pig का उपयोग करके उसे सामान्यीकृत किया जाता है और फिर Hive के माध्यम से विश्लेषण किया जाता है। यदि ये सभी उपकरण एक मेटास्टोर साझा करते हैं, तो प्रत्येक उपकरण के उपयोगकर्ताओं के पास दूसरे उपकरण के साथ बनाए गए डेटा तक तत्काल पहुंच होती है। कोई लोडिंग या स्थानांतरण कदम की आवश्यकता नहीं है।

शेयरिंग सक्षम करने के लिए प्रोसेसिंग स्टेट्स कैप्चर करें

HCatalog आपके विश्लेषण परिणामों को प्रकाशित कर सकता है। तो अन्य प्रोग्रामर "REST" के माध्यम से आपके एनालिटिक्स प्लेटफॉर्म तक पहुंच सकता है। आपके द्वारा प्रकाशित स्कीमा अन्य डेटा वैज्ञानिकों के लिए भी उपयोगी है। अन्य डेटा वैज्ञानिक आपकी खोजों का उपयोग बाद की खोज में इनपुट के रूप में करते हैं।

सब कुछ के साथ Hadoop एकीकृत करें

एक प्रसंस्करण और भंडारण वातावरण के रूप में Hadoop उद्यम के लिए बहुत सारे अवसर खोलता है; हालांकि, गोद लेने के लिए ईंधन, यह मौजूदा उपकरणों के साथ काम करना और बढ़ाना होगा। Hadoop को आपके एनालिटिक्स प्लेटफॉर्म में इनपुट के रूप में काम करना चाहिए या अपने ऑपरेशनल डेटा स्टोर्स और वेब एप्लिकेशन के साथ एकीकृत होना चाहिए। संगठन को पूरी तरह से नया टूलसेट सीखने के बिना Hadoop के मूल्य का आनंद लेना चाहिए। REST सेवाएँ एक परिचित API और SQL जैसी भाषा के साथ एंटरप्राइज़ को प्लेटफ़ॉर्म खोलती हैं। एंटरप्राइज़ डेटा प्रबंधन सिस्टम Hadoop प्लेटफ़ॉर्म के साथ अधिक गहराई से HCatalog का उपयोग करते हैं।

HCatalog वास्तुकला

निम्नलिखित दृष्टांत HCatalog की समग्र वास्तुकला को दर्शाता है।

HCatalog किसी भी प्रारूप में फ़ाइलों को पढ़ने और लिखने का समर्थन करता है जिसके लिए a SerDe(क्रमिक-निरूपक) लिखा जा सकता है। डिफ़ॉल्ट रूप से, HCatalog RCFile, CSV, JSON, SequenceFile और ORC फ़ाइल स्वरूपों का समर्थन करता है। एक कस्टम प्रारूप का उपयोग करने के लिए, आपको InputFormat, OutputFormat और SerDe प्रदान करना होगा।

HCatalog हाइव मेटास्टोर के ऊपर बनाया गया है और इसमें Hive का DDL शामिल है। HCatalog सुअर और MapReduce के लिए इंटरफेस पढ़ना और लिखना प्रदान करता है और डेटा परिभाषा और मेटाडेटा अन्वेषण कमांड जारी करने के लिए हाइव की कमांड लाइन इंटरफ़ेस का उपयोग करता है।

सभी Hadoop उप-परियोजनाएं जैसे Hive, Pig, और HBase लिनक्स ऑपरेटिंग सिस्टम को सपोर्ट करती हैं। इसलिए, आपको अपने सिस्टम पर लिनक्स स्वाद स्थापित करने की आवश्यकता है। 26 मार्च 2013 को HCatalog का हाइव इंस्टॉलेशन के साथ विलय कर दिया गया है। संस्करण Hive-0.11.0 से, HCatalog हाइव इंस्टॉलेशन के साथ आता है। इसलिए, हाइव को स्थापित करने के लिए नीचे दिए गए चरणों का पालन करें जो बदले में स्वचालित रूप से आपके सिस्टम पर HCatalog स्थापित करेगा।

चरण 1: जावा इंस्टॉलेशन को सत्यापित करना

Hive को इंस्टॉल करने से पहले जावा को आपके सिस्टम पर इंस्टॉल किया जाना चाहिए। आप अपने सिस्टम पर पहले से जावा स्थापित है या नहीं, यह जांचने के लिए आप निम्न कमांड का उपयोग कर सकते हैं -

$ java –version

यदि जावा आपके सिस्टम पर पहले से इंस्टॉल है, तो आपको निम्न प्रतिक्रिया देखने को मिलती है -

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)

यदि आपके पास जावा आपके सिस्टम पर स्थापित नहीं है, तो आपको नीचे दिए गए चरणों का पालन करने की आवश्यकता है।

चरण 2: जावा को स्थापित करना

निम्नलिखित लिंक पर जाकर जावा (JDK <नवीनतम संस्करण> - X64.tar.gz) डाउनलोड करें http://www.oracle.com/

फिर jdk-7u71-linux-x64.tar.gz आपके सिस्टम पर डाउनलोड किया जाएगा।

आम तौर पर आपको डाउनलोड किए गए जावा फ़ाइल डाउनलोड फ़ोल्डर में मिलेंगे। इसे सत्यापित करें और निकालें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

जावा को सभी उपयोगकर्ताओं के लिए उपलब्ध कराने के लिए, आपको इसे "/ usr / स्थानीय /" स्थान पर ले जाना होगा। रूट खोलें, और निम्न कमांड टाइप करें।

$ su
password:
# mv jdk1.7.0_71 /usr/local/
# exit

स्थापित करने के लिए PATH तथा JAVA_HOME चर, निम्नलिखित कमांड को इसमें जोड़ें ~/.bashrc फ़ाइल।

export JAVA_HOME=/usr/local/jdk1.7.0_71
export PATH=PATH:$JAVA_HOME/bin

अब कमांड का उपयोग करके इंस्टॉलेशन को सत्यापित करें java -version ऊपर बताए अनुसार टर्मिनल से।

चरण 3: सत्यापन Hadoop स्थापना

Hive स्थापित करने से पहले आपके सिस्टम पर Hadoop स्थापित होना चाहिए। आइए निम्नलिखित कमांड का उपयोग करके 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 स्थापित नहीं है, तो निम्न चरणों के साथ आगे बढ़ें -

चरण 4: Hadoop डाउनलोड करना

निम्नलिखित कमांड का उपयोग करके अपाचे सॉफ्टवेयर फाउंडेशन से Hadoop 2.4.1 डाउनलोड और निकालें।

$ 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

चरण 5: छद्म वितरित मोड में Hadoop स्थापित करना

स्थापित करने के लिए निम्न चरणों का उपयोग किया जाता है Hadoop 2.4.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

Hadoop कॉन्फ़िगरेशन

आप "HADOOP_HOME / etc / hadoop" स्थान में सभी Hadoop कॉन्फ़िगरेशन फ़ाइलों को पा सकते हैं। आपको अपने Hadoop बुनियादी ढांचे के अनुसार उन कॉन्फ़िगरेशन फ़ाइलों में उपयुक्त परिवर्तन करने की आवश्यकता है।

$ cd $HADOOP_HOME/etc/hadoop

जावा का उपयोग करके Hadoop कार्यक्रमों को विकसित करने के लिए, आपको जावा वातावरण चर को रीसेट करना होगा hadoop-env.sh फ़ाइल को प्रतिस्थापित करके JAVA_HOME आपके सिस्टम में जावा के स्थान के साथ मूल्य।

export JAVA_HOME=/usr/local/jdk1.7.0_71

नीचे दी गई फ़ाइलों की सूची है जिन्हें आपको Hadoop को कॉन्फ़िगर करने के लिए संपादित करना है।

कोर-site.xml

core-site.xml फ़ाइल में Hadoop उदाहरण के लिए उपयोग की जाने वाली पोर्ट संख्या, फ़ाइल सिस्टम के लिए आवंटित मेमोरी, डेटा को संग्रहीत करने के लिए मेमोरी की सीमा और रीड / राइट बफ़र्स के आकार जैसी जानकारी शामिल है।

कोर- site.xml खोलें और <कॉन्फ़िगरेशन> और </ कॉन्फ़िगरेशन> टैग के बीच निम्न गुण जोड़ें।

<configuration>
   <property>
      <name>fs.default.name</name>
      <value>hdfs://localhost:9000</value>
   </property>
</configuration>

HDFS-site.xml

hdfs-site.xmlफ़ाइल में प्रतिकृति डेटा के मान, नामेनोड पथ और आपके स्थानीय फ़ाइल सिस्टम के डेटाैनोड पथ जैसी जानकारी होती है। इसका अर्थ है वह स्थान जहाँ आप 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>
   <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 बुनियादी ढांचे के अनुसार परिवर्तन कर सकते हैं।

सूत-site.xml

इस फ़ाइल का उपयोग यार्न को Hadoop में कॉन्फ़िगर करने के लिए किया जाता है। यार्न-site.xml फ़ाइल खोलें और इस फ़ाइल में <कॉन्फ़िगरेशन>, </ कॉन्फ़िगरेशन> टैग के बीच निम्न गुण जोड़ें।

<configuration>
   <property>
      <name>yarn.nodemanager.aux-services</name>
      <value>mapreduce_shuffle</value>
   </property>
</configuration>

mapred-site.xml

यह फ़ाइल निर्दिष्ट करने के लिए उपयोग की जाती है कि हम किस MapReduce ढांचे का उपयोग कर रहे हैं। डिफ़ॉल्ट रूप से, Hadoop में यार्न-site.xml का टेम्प्लेट होता है। सबसे पहले, आपको फ़ाइल को कॉपी करने की आवश्यकता हैmapred-site,xml.template सेवा mapred-site.xml निम्न कमांड का उपयोग करके फ़ाइल।

$ cp mapred-site.xml.template mapred-site.xml

Mapred-site.xml फ़ाइल खोलें और इस फ़ाइल में <कॉन्फ़िगरेशन>, </ कॉन्फ़िगरेशन> टैग के बीच निम्न गुण जोड़ें।

<configuration>
   <property>
      <name>mapreduce.framework.name</name>
      <value>yarn</value>
   </property>
</configuration>

चरण 6: सत्यापन Hadoop स्थापना

Hadoop स्थापना को सत्यापित करने के लिए निम्न चरणों का उपयोग किया जाता है।

नामेनोड सेटअप

निम्नानुसार कमांड "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
************************************************************/

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

यार्न स्क्रिप्ट का सत्यापन

यार्न स्क्रिप्ट शुरू करने के लिए निम्न कमांड का उपयोग किया जाता है। इस आदेश को निष्पादित करने से आपके यार्न डेमॉन शुरू हो जाएंगे।

$ 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

ब्राउज़र पर Hadoop तक पहुँचना

Hadoop तक पहुंचने के लिए डिफ़ॉल्ट पोर्ट संख्या 50070 है। अपने ब्राउज़र पर Hadoop सेवाएं प्राप्त करने के लिए निम्न URL का उपयोग करें।

http://localhost:50070/

क्लस्टर के लिए सभी आवेदन सत्यापित करें

क्लस्टर के सभी अनुप्रयोगों तक पहुँचने के लिए डिफ़ॉल्ट पोर्ट संख्या 8088 है। इस सेवा पर जाने के लिए निम्न यूआरएल का उपयोग करें।

http://localhost:8088/

एक बार जब आप Hadoop की स्थापना के साथ किया जाता है, तो अगले चरण पर जाएं और अपने सिस्टम पर Hive स्थापित करें।

चरण 7: हाइव को डाउनलोड करना

हम इस ट्यूटोरियल में 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

चरण 8: हाइव स्थापित करना

आपके सिस्टम पर हाइव स्थापित करने के लिए निम्न चरणों की आवश्यकता होती है। मान लें कि Hive आर्काइव को डाउनलोड किया गया है/Downloads निर्देशिका।

हाइव आर्काइव को निकालना और सत्यापित करना

निम्न आदेश का उपयोग हाइव संग्रह को डाउनलोड करने और निकालने के लिए किया जाता है -

$ 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 / स्थानीय / हाइव निर्देशिका में कॉपी करना

हमें सुपरयुसर "su -" से फाइल कॉपी करने की आवश्यकता है। निम्न कमांड का उपयोग एक्सट्रैक्टेड डायरेक्टरी से फाइल को कॉपी करने के लिए किया जाता है/usr/local/hive" निर्देशिका।

$ su -
passwd:
# cd /home/user/Download
# mv apache-hive-0.14.0-bin /usr/local/hive
# exit

हाइव के लिए पर्यावरण की स्थापना

आप निम्न लाइनों को जोड़कर हाइव वातावरण सेट कर सकते हैं ~/.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

चरण 9: हाइव को कॉन्फ़िगर करना

Hadoop के साथ Hive को कॉन्फ़िगर करने के लिए, आपको एडिट करना होगा hive-env.sh फ़ाइल, जिसमें रखा गया है $HIVE_HOME/confनिर्देशिका। निम्न आदेश हाइव पर पुनर्निर्देशित करता हैconfig फ़ोल्डर और टेम्पलेट फ़ाइल की प्रतिलिपि बनाएँ -

$ cd $HIVE_HOME/conf $ cp hive-env.sh.template hive-env.sh

संपादित करें hive-env.sh निम्नलिखित पंक्ति को जोड़कर फ़ाइल -

export HADOOP_HOME=/usr/local/hadoop

इसके साथ, हाइव इंस्टॉलेशन पूरा हो गया है। अब आपको मेटास्टोर को कॉन्फ़िगर करने के लिए एक बाहरी डेटाबेस सर्वर की आवश्यकता है। हम अपाचे डर्बी डेटाबेस का उपयोग करते हैं।

चरण 10: अपाचे डर्बी को डाउनलोड और इंस्टॉल करना

Apache Derby को डाउनलोड और इंस्टॉल करने के लिए नीचे दिए गए चरणों का पालन करें -

Downloading अपाचे डर्बी

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

डर्बी आर्काइव को निकालना और सत्यापित करना

निम्नलिखित आदेश डर्बी संग्रह को निकालने और सत्यापित करने के लिए उपयोग किए जाते हैं -

$ 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 / स्थानीय / डर्बी निर्देशिका में कॉपी करना

हमें सुपरसियर "सु -" से कॉपी करने की आवश्यकता है। निम्न कमांड का उपयोग एक्सट्रैक्टेड डायरेक्टरी से फाइल को कॉपी करने के लिए किया जाता है/usr/local/derby निर्देशिका -

$ su -
passwd:
# cd /home/user
# mv db-derby-10.4.2.0-bin /usr/local/derby
# exit

डर्बी के लिए पर्यावरण की स्थापना

आप निम्नलिखित पंक्तियों को जोड़कर डर्बी पर्यावरण की स्थापना कर सकते हैं ~/.bashrc फ़ाइल -

export DERBY_HOME=/usr/local/derby
export PATH=$PATH:$DERBY_HOME/bin
export CLASSPATH=$CLASSPATH:$DERBY_HOME/lib/derby.jar:$DERBY_HOME/lib/derbytools.jar

निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है ~/.bashrc file -

$ source ~/.bashrc

Metastore के लिए एक निर्देशिका बनाएँ

एक निर्देशिका बनाएँ data Metastore डेटा संग्रहीत करने के लिए $ DERBY_HOME निर्देशिका में।

$ mkdir $DERBY_HOME/data

डर्बी की स्थापना और पर्यावरणीय स्थापना अब पूरी हो गई है।

चरण 11: हाइव मेटास्टोर को कॉन्फ़िगर करना

मेटास्टोर को कॉन्फ़िगर करने का अर्थ है हाइव को निर्दिष्ट करना जहां डेटाबेस संग्रहीत है। आप इसे संपादित करके कर सकते हैंhive-site.xml फ़ाइल, जो में है $HIVE_HOME/confनिर्देशिका। सबसे पहले, निम्नलिखित कमांड का उपयोग करके टेम्पलेट फ़ाइल को कॉपी करें -

$ cd $HIVE_HOME/conf
$ cp hive-default.xml.template hive-site.xml

संपादित करें hive-site.xml और <कॉन्फ़िगरेशन> और </ कॉन्फ़िगरेशन> टैग के बीच निम्न पंक्तियाँ जोड़ें -

<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

चरण 12: हाइव स्थापना को सत्यापित करना

हाइव चलाने से पहले, आपको बनाने की आवश्यकता है /tmpएचडीएफएस में फ़ोल्डर और एक अलग हाइव फ़ोल्डर। यहां, हम उपयोग करते हैं/user/hive/warehouseफ़ोल्डर। आपको इन नव निर्मित फ़ोल्डरों के लिए लिखित अनुमति सेट करने की आवश्यकता है जैसा कि नीचे दिखाया गया है -

chmod g+w

अब हाइव को सत्यापित करने से पहले उन्हें एचडीएफएस में सेट करें। निम्न आदेशों का उपयोग करें -

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

निम्न आदेश का उपयोग हाइव स्थापना को सत्यापित करने के लिए किया जाता है -

$ cd $HIVE_HOME $ bin/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
   =/tmp/hadoop/hive_job_log_hadoop_201312121621_1494929084.txt
………………….
hive>

आप सभी तालिकाओं को प्रदर्शित करने के लिए निम्न नमूना कमांड निष्पादित कर सकते हैं -

hive> show tables;
OK Time taken: 2.798 seconds
hive>

चरण 13: HCatalog स्थापना की जाँच करें

सिस्टम चर सेट करने के लिए निम्न कमांड का उपयोग करें HCAT_HOME HCatalog होम के लिए।

export HCAT_HOME = $HiVE_HOME/HCatalog

HCatalog स्थापना को सत्यापित करने के लिए निम्न आदेश का उपयोग करें।

cd $HCAT_HOME/bin
./hcat

यदि स्थापना सफल होती है, तो आपको निम्न आउटपुट देखने को मिलेंगे -

SLF4J: Actual binding is of type [org.slf4j.impl.Log4jLoggerFactory]
usage: hcat { -e "<query>" | -f "<filepath>" } 
   [ -g "<group>" ] [ -p "<perms>" ] 
   [ -D"<name> = <value>" ]
	
-D <property = value>    use hadoop value for given property
-e <exec>                hcat command given from command line
-f <file>                hcat commands in file
-g <group>               group for the db/table specified in CREATE statement
-h,--help                Print help information
-p <perms>               permissions for the db/table specified in CREATE statement

HCatalog कमांड लाइन इंटरफेस (CLI) कमांड से मंगवाया जा सकता है $HIVE_HOME/HCatalog/bin/hcat जहाँ $ HIVE_HIVE Hive की होम डायरेक्टरी है। hcat एक कमांड को HCatalog सर्वर को इनिशियलाइज़ करने के लिए प्रयोग किया जाता है।

HCatalog कमांड लाइन को इनिशियलाइज़ करने के लिए निम्न कमांड का उपयोग करें।

cd $HCAT_HOME/bin
./hcat

यदि स्थापना सही ढंग से की गई है, तो आपको निम्नलिखित आउटपुट मिलेगा -

SLF4J: Actual binding is of type [org.slf4j.impl.Log4jLoggerFactory]
usage: hcat { -e "<query>" | -f "<filepath>" } 
   [ -g "<group>" ] [ -p "<perms>" ] 
   [ -D"<name> = <value>" ]
	
-D <property = value>    use hadoop value for given property
-e <exec>                hcat command given from command line
-f <file>                hcat commands in file
-g <group>               group for the db/table specified in CREATE statement
-h,--help                Print help information
-p <perms>               permissions for the db/table specified in CREATE statement

HCatalog CLI इन कमांड लाइन विकल्पों का समर्थन करता है -

अनु क्रमांक विकल्प उदाहरण और विवरण
1 जी

hcat -g mygroup ...

बनाई जाने वाली तालिका में समूह "माइग्रुप" होना चाहिए।

2 -पी

hcat -p rwxr-xr-x ...

बनाई जाने वाली तालिका को अनुमतियों को पढ़ना, लिखना और निष्पादित करना होगा।

3 एफ

hcat -f myscript.HCatalog ...

myscript.HCatalog एक स्क्रिप्ट फ़ाइल है जिसमें DDL कमांड निष्पादित होती है।

4 -इ

hcat -e 'create table mytable(a int);' ...

निम्न स्ट्रिंग को DDL कमांड के रूप में मानें और इसे निष्पादित करें।

5 डी

hcat -Dkey = value ...

जावा सिस्टम प्रॉपर्टी के रूप में HCatalog कुंजी-मूल्य जोड़ी पास करता है।

6 -

hcat

उपयोग संदेश प्रिंट करता है।

नोट -

  • -g तथा -p विकल्प अनिवार्य नहीं हैं।

  • एक समय में, या तो -e या -f विकल्प प्रदान किया जा सकता है, दोनों नहीं।

  • विकल्पों का क्रम सारहीन है; आप किसी भी क्रम में विकल्प निर्दिष्ट कर सकते हैं।

अनु क्रमांक DDL कमांड और विवरण
1

CREATE TABLE

HCatalog का उपयोग कर एक तालिका बनाएँ। यदि आप एक तालिका को क्लायंटेड बाय क्लाज के साथ बनाते हैं, तो आप इसे पिग या मैपरेड के साथ नहीं लिख पाएंगे।

2

ALTER TABLE

REBUILD और CONCATENATE विकल्पों को छोड़कर समर्थित। इसका व्यवहार हाइव के समान ही रहता है।

3

DROP TABLE

समर्थित। हाइव के समान व्यवहार (पूर्ण तालिका और संरचना को छोड़ें)।

4

CREATE/ALTER/DROP VIEW

समर्थित। हाइव जैसा व्यवहार।

Note सुअर और MapReduce विचारों से पढ़ या लिख ​​नहीं सकते।

5

SHOW TABLES

तालिकाओं की सूची प्रदर्शित करें।

6

SHOW PARTITIONS

विभाजन की एक सूची प्रदर्शित करें।

7

Create/Drop Index

क्रिएट और ड्रॉप फंक्शन संचालन का समर्थन किया जाता है, लेकिन बनाए गए कार्यों को अभी भी सुअर में पंजीकृत होना चाहिए और MapReduce के लिए CLASSPATH में रखा जाना चाहिए।

8

DESCRIBE

समर्थित। हाइव जैसा व्यवहार। संरचना का वर्णन करें।

उपरोक्त सारणी के कुछ आदेश बाद के अध्यायों में बताए गए हैं।

यह अध्याय बताता है कि तालिका कैसे बनाई जाए और उसमें डेटा कैसे डाला जाए। HCatalog में एक तालिका बनाने की परंपराएं हाइव का उपयोग करके तालिका बनाने के समान है।

टेबल स्टेटमेंट बनाएं

Create Table एक कथन है जिसका उपयोग HCatalog का उपयोग करके हाइव मेटास्टोर में एक तालिका बनाने के लिए किया जाता है। इसका सिंटैक्स और उदाहरण इस प्रकार है -

वाक्य - विन्यास

CREATE [TEMPORARY] [EXTERNAL] TABLE [IF NOT EXISTS] [db_name.] table_name
[(col_name data_type [COMMENT col_comment], ...)]
[COMMENT table_comment]
[ROW FORMAT row_format]
[STORED AS file_format]

उदाहरण

हमें मान लेते हैं कि आपको नाम की एक तालिका बनाने की आवश्यकता है employee का उपयोग करते हुए CREATE TABLEबयान। निम्न तालिका फ़ील्ड और उनके डेटा प्रकारों को सूचीबद्ध करती हैemployee तालिका -

अनु क्रमांक कार्यक्षेत्र नाम डाटा प्रकार
1 ईद पूर्णांक
2 नाम तार
3 वेतन फ्लोट
4 पद तार

निम्न डेटा समर्थित फ़ील्ड जैसे कि परिभाषित करता है Comment, पंक्ति जैसे खेतों को स्वरूपित किया Field terminator, Lines terminator, तथा Stored File type

COMMENT ‘Employee details’
FIELDS TERMINATED BY ‘\t’
LINES TERMINATED BY ‘\n’
STORED IN TEXT FILE

निम्न क्वेरी नाम की तालिका बनाती है employee उपरोक्त डेटा का उपयोग करना।

./hcat –e "CREATE TABLE IF NOT EXISTS employee ( eid int, name String, 
   salary String, destination String) \
COMMENT 'Employee details' \
ROW FORMAT DELIMITED \
FIELDS TERMINATED BY ‘\t’ \
LINES TERMINATED BY ‘\n’ \
STORED AS TEXTFILE;"

यदि आप विकल्प जोड़ते हैं IF NOT EXISTS, HCatalog यदि तालिका पहले से मौजूद है, तो कथन को अनदेखा करता है।

तालिका के सफल निर्माण पर, आपको निम्न प्रतिक्रिया देखने को मिलेगी -

OK
Time taken: 5.905 seconds

डेटा स्टेटमेंट लोड करें

आमतौर पर, SQL में एक टेबल बनाने के बाद, हम इन्सर्ट स्टेटमेंट का उपयोग करके डेटा डाल सकते हैं। लेकिन HCatalog में, हम LOAD डेटा स्टेटमेंट का उपयोग करके डेटा डालते हैं।

HCatalog में डेटा सम्मिलित करते समय, थोक रिकॉर्ड को संग्रहीत करने के लिए LOAD DATA का उपयोग करना बेहतर होता है। डेटा लोड करने के दो तरीके हैं: एक से हैlocal file system और दूसरा है Hadoop file system

वाक्य - विन्यास

LOAD DATA का सिंटैक्स इस प्रकार है -

LOAD DATA [LOCAL] INPATH 'filepath' [OVERWRITE] INTO TABLE tablename
[PARTITION (partcol1=val1, partcol2=val2 ...)]
  • स्थानीय पथ को निर्दिष्ट करने के लिए LOCAL पहचानकर्ता है। यह वैकल्पिक है।
  • OVERWRITE तालिका में डेटा को अधिलेखित करने के लिए वैकल्पिक है।
  • विभाजन वैकल्पिक है।

उदाहरण

हम निम्न डेटा को तालिका में सम्मिलित करेंगे। यह एक टेक्स्ट फाइल है जिसका नाम हैsample.txt में /home/user निर्देशिका।

1201  Gopal        45000    Technical manager
1202  Manisha      45000    Proof reader
1203  Masthanvali  40000    Technical writer
1204  Kiran        40000    Hr Admin
1205  Kranthi      30000    Op Admin

निम्न क्वेरी तालिका में दिए गए पाठ को लोड करती है।

./hcat –e "LOAD DATA LOCAL INPATH '/home/user/sample.txt'
OVERWRITE INTO TABLE employee;"

सफल डाउनलोड पर, आपको निम्न प्रतिक्रिया देखने को मिलती है -

OK
Time taken: 15.905 seconds

यह अध्याय बताता है कि तालिका की विशेषताओं को कैसे बदला जाए जैसे कि इसका तालिका नाम बदलना, कॉलम नाम बदलना, कॉलम जोड़ना और कॉलम हटाना या बदलना।

ऑल्टर टेबल स्टेटमेंट

आप हाइव में तालिका को बदलने के लिए ALTER TABLE स्टेटमेंट का उपयोग कर सकते हैं।

वाक्य - विन्यास

किसी तालिका में संशोधित करने के लिए हम किन विशेषताओं के आधार पर कथन निम्न में से किसी भी वाक्यविन्यास को लेते हैं।

ALTER TABLE name RENAME TO new_name
ALTER TABLE name ADD COLUMNS (col_spec[, col_spec ...])
ALTER TABLE name DROP [COLUMN] column_name
ALTER TABLE name CHANGE column_name new_name new_type
ALTER TABLE name REPLACE COLUMNS (col_spec[, col_spec ...])

कुछ परिदृश्य नीचे दिए गए हैं।

नाम बदलें ... कथन

निम्न क्वेरी से एक तालिका का नाम बदल जाता है employee सेवा emp

./hcat –e "ALTER TABLE employee RENAME TO emp;"

बयान बदलें

निम्न तालिका में फ़ील्ड हैं employee तालिका और यह फ़ील्ड को बोल्ड करने के लिए दिखाता है (बोल्ड में)।

कार्यक्षेत्र नाम डेटा प्रकार से परिवर्तित करें फ़ील्ड नाम बदलें डेटा प्रकार में कनवर्ट करें
ईद पूर्णांक ईद पूर्णांक
नाम तार Ename तार
वेतन फ्लोट वेतन दोहरा
पद तार पद तार

उपरोक्त क्वेरीज़ उपरोक्त डेटा का उपयोग करके कॉलम नाम और कॉलम डेटा प्रकार का नाम बदल देती हैं -

./hcat –e "ALTER TABLE employee CHANGE name ename String;"
./hcat –e "ALTER TABLE employee CHANGE salary salary Double;"

कॉलम स्टेटमेंट जोड़ें

निम्न क्वेरी नाम का एक कॉलम जोड़ती है dept को employee तालिका।

./hcat –e "ALTER TABLE employee ADD COLUMNS (dept STRING COMMENT 'Department name');"

स्टेटमेंट बदलें

निम्न क्वेरी से सभी स्तंभों को हटा देता है employee तालिका और इसके साथ प्रतिस्थापित करती है emp तथा name कॉलम -

./hcat – e "ALTER TABLE employee REPLACE COLUMNS ( eid INT empid Int, ename STRING name String);"

ड्रॉप टेबल स्टेटमेंट

यह अध्याय बताता है कि HCatalog में तालिका कैसे छोड़ें। जब आप मेटास्टोर से एक टेबल ड्रॉप करते हैं, तो यह टेबल / कॉलम डेटा और उनके मेटाडेटा को हटा देता है। यह एक सामान्य तालिका (मेटास्टोर में संग्रहीत) या एक बाहरी तालिका (स्थानीय फ़ाइल सिस्टम में संग्रहीत) हो सकती है; HCatalog दोनों ही तरह से व्यवहार करते हैं, भले ही उनके प्रकार चाहे जो भी हों।

वाक्य विन्यास इस प्रकार है -

DROP TABLE [IF EXISTS] table_name;

निम्न क्वेरी नाम की तालिका को गिरा देती है employee -

./hcat –e "DROP TABLE IF EXISTS employee;"

क्वेरी के सफल निष्पादन पर, आपको निम्न प्रतिक्रिया देखने को मिलती है -

OK
Time taken: 5.3 seconds

यह अध्याय वर्णन करता है कि कैसे बनाएं और प्रबंधित करें viewHCatalog में। डेटाबेस दृश्य का उपयोग कर बनाया जाता हैCREATE VIEWबयान। दृश्य एक ही तालिका, कई तालिकाओं या किसी अन्य दृश्य से बनाए जा सकते हैं।

एक दृश्य बनाने के लिए, उपयोगकर्ता को विशिष्ट कार्यान्वयन के अनुसार उपयुक्त सिस्टम विशेषाधिकार होना चाहिए।

व्यू स्टेटमेंट बनाएं

CREATE VIEWदिए गए नाम के साथ एक दृश्य बनाता है। यदि कोई तालिका या दृश्य समान नाम के साथ पहले से मौजूद है, तो एक त्रुटि है। आप उपयोग कर सकते हैंIF NOT EXISTS त्रुटि को छोड़ने के लिए।

यदि कोई कॉलम नाम नहीं दिया गया है, तो दृश्य के कॉलम के नाम स्वचालित रूप से प्राप्त किए जाएंगे defining SELECT expression

Note - यदि SELECT में x- y के रूप में अन-एलाइड स्केलर अभिव्यक्तियाँ हैं, तो परिणामी दृश्य कॉलम नाम _C0, _C1, आदि में उत्पन्न होंगे।

कॉलम का नाम बदलने पर, कॉलम टिप्पणियों की आपूर्ति भी की जा सकती है। टिप्पणियाँ स्वचालित रूप से अंतर्निहित कॉलम से विरासत में नहीं मिली हैं।

अगर व्यू है तो क्रिएट व्यू स्टेटमेंट फेल हो जाएगा defining SELECT expression अमान्य है।

वाक्य - विन्यास

CREATE VIEW [IF NOT EXISTS] [db_name.]view_name [(column_name [COMMENT column_comment], ...) ]
[COMMENT view_comment]
[TBLPROPERTIES (property_name = property_value, ...)]
AS SELECT ...;

उदाहरण

कर्मचारी तालिका डेटा निम्न है। अब देखते हैं कि नाम का व्यू कैसे बनाया जाता हैEmp_Deg_View 35,000 से अधिक वेतन वाले फ़ील्ड आईडी, नाम, पदनाम, और किसी कर्मचारी का वेतन।

+------+-------------+--------+-------------------+-------+
|  ID  |    Name     | Salary |    Designation    | Dept  |
+------+-------------+--------+-------------------+-------+
| 1201 |    Gopal    | 45000  | Technical manager |  TP   |
| 1202 |   Manisha   | 45000  | Proofreader       |  PR   |
| 1203 | Masthanvali | 30000  | Technical writer  |  TP   |
| 1204 |    Kiran    | 40000  | Hr Admin          |  HR   |
| 1205 |   Kranthi   | 30000  | Op Admin          | Admin |
+------+-------------+--------+-------------------+-------+

निम्नलिखित दिए गए डेटा के आधार पर एक दृश्य बनाने का आदेश है।

./hcat –e "CREATE VIEW Emp_Deg_View (salary COMMENT ' salary more than 35,000')
   AS SELECT id, name, salary, designation FROM employee WHERE salary ≥ 35000;"

उत्पादन

OK
Time taken: 5.3 seconds

ड्रॉप व्यू स्टेटमेंट

DROP दृश्य निर्दिष्ट दृश्य के लिए मेटाडेटा निकालता है। अन्य विचारों द्वारा संदर्भित दृश्य को छोड़ने पर, कोई चेतावनी नहीं दी जाती है (आश्रित विचार अमान्य के रूप में झूलने से रह जाते हैं और उन्हें उपयोगकर्ता द्वारा छोड़ दिया जाना चाहिए या फिर से बनाया जाना चाहिए)।

वाक्य - विन्यास

DROP VIEW [IF EXISTS] view_name;

उदाहरण

निम्नलिखित आदेश का उपयोग नाम के दृश्य को गिराने के लिए किया जाता है Emp_Deg_View

DROP VIEW Emp_Deg_View;

आप अक्सर किसी डेटाबेस में सभी तालिकाओं को सूचीबद्ध करना चाहते हैं या किसी तालिका के सभी स्तंभों को सूचीबद्ध करना चाहते हैं। जाहिर है, टेबल और कॉलम को सूचीबद्ध करने के लिए हर डेटाबेस का अपना सिंटैक्स होता है।

Show Tablesकथन सभी तालिकाओं के नाम प्रदर्शित करता है। डिफ़ॉल्ट रूप से, यह वर्तमान डेटाबेस से या के साथ तालिकाओं को सूचीबद्ध करता हैIN क्लॉज, एक निर्दिष्ट डेटाबेस में।

यह अध्याय बताता है कि HCatalog में वर्तमान डेटाबेस से सभी तालिकाओं को कैसे सूचीबद्ध किया जाए।

टेबल्स स्टेटमेंट दिखाएं

SHOW TABLES का वाक्य विन्यास इस प्रकार है -

SHOW TABLES [IN database_name] ['identifier_with_wildcards'];

निम्न क्वेरी तालिकाओं की एक सूची प्रदर्शित करती है -

./hcat –e "Show tables;"

क्वेरी के सफल निष्पादन पर, आपको निम्न प्रतिक्रिया देखने को मिलती है -

OK
emp
employee
Time taken: 5.3 seconds

एक विभाजन सारणीबद्ध डेटा के लिए एक शर्त है जो एक अलग तालिका या दृश्य बनाने के लिए उपयोग किया जाता है। शो पार्टिशन दिए गए बेस टेबल के लिए सभी मौजूदा पार्टिशन को सूचीबद्ध करता है। विभाजन वर्णमाला क्रम में सूचीबद्ध हैं। हाइव 0.6 के बाद, परिणामी सूची को फ़िल्टर करने के लिए एक विभाजन विनिर्देश के कुछ हिस्सों को निर्दिष्ट करना भी संभव है।

किसी विशेष तालिका में मौजूद विभाजनों को देखने के लिए आप SHOW PARTITIONS कमांड का उपयोग कर सकते हैं। यह अध्याय बताता है कि HCatalog में किसी विशेष तालिका के विभाजन को कैसे सूचीबद्ध किया जाए।

विभाजन विवरण दिखाएँ

वाक्य विन्यास इस प्रकार है -

SHOW PARTITIONS table_name;

निम्न क्वेरी नाम की तालिका को गिरा देती है employee -

./hcat –e "Show partitions employee;"

क्वेरी के सफल निष्पादन पर, आपको निम्न प्रतिक्रिया देखने को मिलती है -

OK
Designation = IT
Time taken: 5.3 seconds

गतिशील विभाजन

HCatalog विभाजन में तालिकाओं का आयोजन करता है। यह विभाजन तालिका, जैसे तिथि, शहर और विभाग के मूल्यों के आधार पर एक तालिका को संबंधित भागों में विभाजित करने का एक तरीका है। विभाजन का उपयोग करना, डेटा के एक हिस्से को क्वेरी करना आसान है।

उदाहरण के लिए, नाम की एक तालिका Tab1जिसमें आईडी, नाम, विभाग और योज (यानी जुड़ने का वर्ष) जैसे कर्मचारी डेटा शामिल हैं। मान लीजिए कि आपको 2012 में शामिल हुए सभी कर्मचारियों के विवरण को पुनः प्राप्त करना होगा। एक क्वेरी आवश्यक जानकारी के लिए पूरी तालिका खोजती है। हालाँकि, यदि आप वर्ष के साथ कर्मचारी डेटा को विभाजित करते हैं और इसे एक अलग फ़ाइल में संग्रहीत करते हैं, तो यह क्वेरी प्रसंस्करण समय को कम करता है। निम्न उदाहरण दिखाता है कि फ़ाइल और उसके डेटा को कैसे विभाजित किया जाए -

निम्न फ़ाइल में है employeedata तालिका।

/ Tab1 / employeedata / file1

id, name,   dept, yoj
1,  gopal,   TP, 2012
2,  kiran,   HR, 2012
3,  kaleel,  SC, 2013
4, Prasanth, SC, 2013

उपरोक्त डेटा को वर्ष का उपयोग करके दो फ़ाइलों में विभाजित किया गया है।

/ Tab1 / employeedata / 2012 / करें 2

1, gopal, TP, 2012
2, kiran, HR, 2012

/ Tab1 / employeedata / 2013 / file3

3, kaleel,   SC, 2013
4, Prasanth, SC, 2013

एक विभाजन जोड़ना

हम तालिका को बदलकर एक तालिका में विभाजन जोड़ सकते हैं। आइए हम मान लें कि हमारे पास एक तालिका हैemployee आईडी, नाम, वेतन, पदनाम, विभाग और योजना जैसे क्षेत्रों के साथ।

वाक्य - विन्यास

ALTER TABLE table_name ADD [IF NOT EXISTS] PARTITION partition_spec
[LOCATION 'location1'] partition_spec [LOCATION 'location2'] ...;
partition_spec:
: (p_column = p_col_value, p_column = p_col_value, ...)

निम्नलिखित विभाजन का उपयोग किसी विभाजन को जोड़ने के लिए किया जाता है employee तालिका।

./hcat –e "ALTER TABLE employee ADD PARTITION (year = '2013') location '/2012/part2012';"

एक पार्टी का नाम बदलना

आप किसी पार्टीशन का नाम बदलने के लिए RENAME-TO कमांड का उपयोग कर सकते हैं। इसका सिंटैक्स इस प्रकार है -

./hact –e "ALTER TABLE table_name PARTITION partition_spec RENAME TO PARTITION partition_spec;"

विभाजन का नाम बदलने के लिए निम्नलिखित क्वेरी का उपयोग किया जाता है -

./hcat –e "ALTER TABLE employee PARTITION (year=’1203’) RENAME TO PARTITION (Yoj='1203');"

एक विभाजन गिरा

विभाजन को गिराने के लिए प्रयुक्त कमांड का वाक्य विन्यास इस प्रकार है -

./hcat –e "ALTER TABLE table_name DROP [IF EXISTS] PARTITION partition_spec,.
   PARTITION partition_spec,...;"

विभाजन को छोड़ने के लिए निम्नलिखित क्वेरी का उपयोग किया जाता है -

./hcat –e "ALTER TABLE employee DROP [IF EXISTS] PARTITION (year=’1203’);"

एक सूचकांक बनाना

एक सूचकांक एक तालिका के एक विशेष स्तंभ पर एक संकेतक के अलावा कुछ भी नहीं है। एक इंडेक्स बनाने का मतलब है कि किसी टेबल के किसी विशेष कॉलम पर पॉइंटर बनाना। इसका सिंटैक्स इस प्रकार है -

CREATE INDEX index_name
ON TABLE base_table_name (col_name, ...)
AS 'index.handler.class.name'
[WITH DEFERRED REBUILD]
[IDXPROPERTIES (property_name = property_value, ...)]
[IN TABLE index_table_name]
[PARTITIONED BY (col_name, ...)][
   [ ROW FORMAT ...] STORED AS ...
   | STORED BY ...
]
[LOCATION hdfs_path]
[TBLPROPERTIES (...)]

उदाहरण

इंडेक्स की अवधारणा को समझने के लिए एक उदाहरण लेते हैं। उसी का उपयोग करेंemployee तालिका जिसका उपयोग हमने पहले Id, Name, Salary, पदनाम, और विभाग के साथ किया है index_salary पर salary का कॉलम employee तालिका।

निम्नलिखित प्रश्न एक सूचकांक बनाता है -

./hcat –e "CREATE INDEX inedx_salary ON TABLE employee(salary)
AS 'org.apache.hadoop.hive.ql.index.compact.CompactIndexHandler';"

यह एक सूचक है salaryस्तंभ। यदि स्तंभ को संशोधित किया गया है, तो परिवर्तनों को एक सूचकांक मान का उपयोग करके संग्रहीत किया जाता है।

एक सूचकांक छोड़ने

सूचकांक को छोड़ने के लिए निम्नलिखित सिंटैक्स का उपयोग किया जाता है -

DROP INDEX <index_name> ON <table_name>

निम्नलिखित क्वेरी अनुक्रमणिका index_salary को छोड़ देती है -

./hcat –e "DROP INDEX index_salary ON employee;"

HCatalog में MapReduce का उपयोग किए बिना समानांतर इनपुट और आउटपुट के लिए डेटा ट्रांसफर एपीआई शामिल है। यह एपीआई Hadoop क्लस्टर से डेटा पढ़ने और उसमें डेटा लिखने के लिए तालिकाओं और पंक्तियों के मूल भंडारण अमूर्त का उपयोग करता है।

डेटा ट्रांसफर एपीआई में मुख्य रूप से तीन वर्ग होते हैं; वे हैं -

  • HCatReader - एक Hadoop क्लस्टर से डेटा पढ़ता है।

  • HCatWriter - एक Hadoop क्लस्टर में डेटा लिखता है।

  • DataTransferFactory - पाठक और लेखक उदाहरण उत्पन्न करता है।

यह API मास्टर-स्लेव नोड सेटअप के लिए उपयुक्त है। आइए हम अधिक चर्चा करेंHCatReader तथा HCatWriter

HCatReader

HCatReader, HCatalog में एक अमूर्त वर्ग आंतरिक है और अंतर्निहित सिस्टम की जटिलताओं को दूर करता है जहाँ से रिकॉर्ड को पुनः प्राप्त किया जाना है।

एस। विधि का नाम और विवरण
1

Public abstract ReaderContext prepareRead() throws HCatException

यह ReaderContext को प्राप्त करने के लिए मास्टर नोड पर बुलाया जाना चाहिए जिसे तब क्रमबद्ध किया जाना चाहिए और दास नोड्स को भेजा जाना चाहिए।

2

Public abstract Iterator <HCatRecorder> read() throws HCaException

इसे HCATRecords को पढ़ने के लिए दास नोड्स पर बुलाया जाना चाहिए।

3

Public Configuration getConf()

यह कॉन्फ़िगरेशन क्लास ऑब्जेक्ट वापस कर देगा।

HDFS से डेटा पढ़ने के लिए HCatReader क्लास का उपयोग किया जाता है। पढ़ना एक दो-चरण प्रक्रिया है जिसमें पहला चरण बाहरी सिस्टम के मास्टर नोड पर होता है। दूसरा चरण कई दास नोड्स पर समानांतर में किया जाता है।

एक पर किए जाते हैं ReadEntity। इससे पहले कि आप पढ़ना शुरू करें, आपको एक ReadEntity को परिभाषित करना होगा जिसमें से पढ़ना है। इसके माध्यम से किया जा सकता हैReadEntity.Builder। आप एक डेटाबेस का नाम, तालिका का नाम, विभाजन और फ़िल्टर स्ट्रिंग निर्दिष्ट कर सकते हैं। उदाहरण के लिए -

ReadEntity.Builder builder = new ReadEntity.Builder();
ReadEntity entity = builder.withDatabase("mydb").withTable("mytbl").build(); 10.

उपरोक्त कोड स्निपेट ReadEntity ऑब्जेक्ट ("एंटिटी") को परिभाषित करता है, जिसमें एक तालिका नाम है mytbl नाम के एक डेटाबेस में mydb, जिसका उपयोग इस तालिका की सभी पंक्तियों को पढ़ने के लिए किया जा सकता है। ध्यान दें कि इस ऑपरेशन के शुरू होने से पहले यह तालिका HCatalog में मौजूद होनी चाहिए।

ReadEntity को परिभाषित करने के बाद, आप ReadEntity और क्लस्टर कॉन्फ़िगरेशन का उपयोग करके HCatReader का एक उदाहरण प्राप्त करते हैं -

HCatReader reader = DataTransferFactory.getHCatReader(entity, config);

अगला कदम पाठक से एक रीडर कॉन्टेक्ट प्राप्त करना है -

ReaderContext cntxt = reader.prepareRead();

HCatWriter

यह अमूर्त HCatalog आंतरिक है। यह बाहरी सिस्टम से HCatalog लिखने की सुविधा है। इसे सीधे करने की कोशिश न करें। इसके बजाय, DataTransferFactory का उपयोग करें।

अनु क्रमांक। विधि का नाम और विवरण
1

Public abstract WriterContext prepareRead() throws HCatException

बाहरी सिस्टम को एक मास्टर नोड से एक बार इस विधि को लागू करना चाहिए। यह एक रिटर्नWriterContext। यह क्रमबद्ध किया जाना चाहिए और निर्माण के लिए दास नोड्स को भेजा जाना चाहिएHCatWriter वहाँ।

2

Public abstract void write(Iterator<HCatRecord> recordItr) throws HCaException

इस विधि का उपयोग लिखने के लिए दास नोड्स में किया जाना चाहिए। RecordItr एक पुनरावृत्त वस्तु है जिसमें अभिलेखों का संग्रह HCatalog में लिखा जाना है।

3

Public abstract void abort(WriterContext cntxt) throws HCatException

इस विधि को मास्टर नोड पर बुलाया जाना चाहिए। इस पद्धति का प्राथमिक उद्देश्य विफलताओं के मामले में सफाई करना है।

4

public abstract void commit(WriterContext cntxt) throws HCatException

इस विधि को मास्टर नोड पर बुलाया जाना चाहिए। इस विधि का उद्देश्य मेटाडेटा कमिट करना है।

पढ़ने के समान, लेखन भी एक दो-चरणीय प्रक्रिया है जिसमें पहला कदम मास्टर नोड पर होता है। बाद में, दूसरा चरण दास नोड्स पर समानांतर में होता है।

राइट ए पर किए जाते हैं WriteEntity जिसका निर्माण पठन के समान फैशन में किया जा सकता है -

WriteEntity.Builder builder = new WriteEntity.Builder();
WriteEntity entity = builder.withDatabase("mydb").withTable("mytbl").build();

उपरोक्त कोड एक WriteEntity ऑब्जेक्ट बनाता है जिसका entityउपयोग नाम की तालिका में लिखने के लिए किया जा सकता हैmytbl डेटाबेस में mydb

एक WriteEntity बनाने के बाद, अगला कदम एक WriterContext प्राप्त करना है -

HCatWriter writer = DataTransferFactory.getHCatWriter(entity, config);
WriterContext info = writer.prepareWrite();

उपरोक्त सभी चरण मास्टर नोड पर होते हैं। मास्टर नोड तब WriterContext ऑब्जेक्ट को क्रमबद्ध करता है और इसे सभी दासों को उपलब्ध कराता है।

दास नोड्स पर, आपको निम्न के रूप में लेखककॉनटेक्स्ट का उपयोग करके एक एचसीएटविटर प्राप्त करना होगा -

HCatWriter writer = DataTransferFactory.getHCatWriter(context);

फिर writerwriteविधि के तर्क के रूप में एक पुनरावृत्ति लेता है -

writer.write(hCatRecordItr);

writer फिर कॉल करता है getNext() एक लूप में इस इटरेटर पर और इटरेटर से जुड़े सभी रिकॉर्ड को लिखता है।

TestReaderWriter.javaफ़ाइल का उपयोग एचसीएट्रेडर और एचसीएट्रविटर कक्षाओं का परीक्षण करने के लिए किया जाता है। निम्न प्रोग्राम दर्शाता है कि किसी स्रोत फ़ाइल से डेटा को पढ़ने के लिए HCatReader और HCatWriter API का उपयोग कैसे करें और बाद में इसे एक गंतव्य फ़ाइल पर लिखें।

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;

import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hive.metastore.api.MetaException;
import org.apache.hadoop.hive.ql.CommandNeedRetryException;
import org.apache.hadoop.mapreduce.InputSplit;

import org.apache.hive.HCatalog.common.HCatException;
import org.apache.hive.HCatalog.data.transfer.DataTransferFactory;
import org.apache.hive.HCatalog.data.transfer.HCatReader;
import org.apache.hive.HCatalog.data.transfer.HCatWriter;
import org.apache.hive.HCatalog.data.transfer.ReadEntity;
import org.apache.hive.HCatalog.data.transfer.ReaderContext;
import org.apache.hive.HCatalog.data.transfer.WriteEntity;
import org.apache.hive.HCatalog.data.transfer.WriterContext;
import org.apache.hive.HCatalog.mapreduce.HCatBaseTest;

import org.junit.Assert;
import org.junit.Test;

public class TestReaderWriter extends HCatBaseTest {
   @Test
   public void test() throws MetaException, CommandNeedRetryException,
      IOException, ClassNotFoundException {
		
      driver.run("drop table mytbl");
      driver.run("create table mytbl (a string, b int)");
		
      Iterator<Entry<String, String>> itr = hiveConf.iterator();
      Map<String, String> map = new HashMap<String, String>();
		
      while (itr.hasNext()) {
         Entry<String, String> kv = itr.next();
         map.put(kv.getKey(), kv.getValue());
      }
		
      WriterContext cntxt = runsInMaster(map);
      File writeCntxtFile = File.createTempFile("hcat-write", "temp");
      writeCntxtFile.deleteOnExit();
		
      // Serialize context.
      ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(writeCntxtFile));
      oos.writeObject(cntxt);
      oos.flush();
      oos.close();
		
      // Now, deserialize it.
      ObjectInputStream ois = new ObjectInputStream(new FileInputStream(writeCntxtFile));
      cntxt = (WriterContext) ois.readObject();
      ois.close();
      runsInSlave(cntxt);
      commit(map, true, cntxt);
		
      ReaderContext readCntxt = runsInMaster(map, false);
      File readCntxtFile = File.createTempFile("hcat-read", "temp");
      readCntxtFile.deleteOnExit();
      oos = new ObjectOutputStream(new FileOutputStream(readCntxtFile));
      oos.writeObject(readCntxt);
      oos.flush();
      oos.close();
		
      ois = new ObjectInputStream(new FileInputStream(readCntxtFile));
      readCntxt = (ReaderContext) ois.readObject();
      ois.close();
		
      for (int i = 0; i < readCntxt.numSplits(); i++) {
         runsInSlave(readCntxt, i);
      }
   }
	
   private WriterContext runsInMaster(Map<String, String> config) throws HCatException {
      WriteEntity.Builder builder = new WriteEntity.Builder();
      WriteEntity entity = builder.withTable("mytbl").build();
		
      HCatWriter writer = DataTransferFactory.getHCatWriter(entity, config);
      WriterContext info = writer.prepareWrite();
      return info;
   }
	
   private ReaderContext runsInMaster(Map<String, String> config, 
      boolean bogus) throws HCatException {
      ReadEntity entity = new ReadEntity.Builder().withTable("mytbl").build();
      HCatReader reader = DataTransferFactory.getHCatReader(entity, config);
      ReaderContext cntxt = reader.prepareRead();
      return cntxt;
   }
	
   private void runsInSlave(ReaderContext cntxt, int slaveNum) throws HCatException {
      HCatReader reader = DataTransferFactory.getHCatReader(cntxt, slaveNum);
      Iterator<HCatRecord> itr = reader.read();
      int i = 1;
		
      while (itr.hasNext()) {
         HCatRecord read = itr.next();
         HCatRecord written = getRecord(i++);
			
         // Argh, HCatRecord doesnt implement equals()
         Assert.assertTrue("Read: " + read.get(0) + "Written: " + written.get(0),
         written.get(0).equals(read.get(0)));
			
         Assert.assertTrue("Read: " + read.get(1) + "Written: " + written.get(1),
         written.get(1).equals(read.get(1)));
			
         Assert.assertEquals(2, read.size());
      }
		
      //Assert.assertFalse(itr.hasNext());
   }
	
   private void runsInSlave(WriterContext context) throws HCatException {
      HCatWriter writer = DataTransferFactory.getHCatWriter(context);
      writer.write(new HCatRecordItr());
   }
	
   private void commit(Map<String, String> config, boolean status,
      WriterContext context) throws IOException {
      WriteEntity.Builder builder = new WriteEntity.Builder();
      WriteEntity entity = builder.withTable("mytbl").build();
      HCatWriter writer = DataTransferFactory.getHCatWriter(entity, config);
		
      if (status) {
         writer.commit(context);
      } else {
         writer.abort(context);
      }
   }
	
   private static HCatRecord getRecord(int i) {
      List<Object> list = new ArrayList<Object>(2);
      list.add("Row #: " + i);
      list.add(i);
      return new DefaultHCatRecord(list);
   }
	
   private static class HCatRecordItr implements Iterator<HCatRecord> {
      int i = 0;
		
      @Override
      public boolean hasNext() {
         return i++ < 100 ? true : false;
      }
		
      @Override
      public HCatRecord next() {
         return getRecord(i);
      }
		
      @Override
      public void remove() {
         throw new RuntimeException();
      }
   }
}

उपरोक्त कार्यक्रम HDFS से रिकॉर्ड के रूप में डेटा को पढ़ता है और रिकॉर्ड डेटा को लिखता है mytable

HCatInputFormat तथा HCatOutputFormatHDFS से डेटा पढ़ने के लिए इंटरफेस का उपयोग किया जाता है और प्रसंस्करण के बाद, MapReduce जॉब का उपयोग करके परिणामी डेटा को HDFS में लिखें। चलिए इनपुट और आउटपुट प्रारूप इंटरफेस को विस्तृत करते हैं।

HCatInputFormat

HCatInputFormatHCatalog प्रबंधित तालिकाओं से डेटा पढ़ने के लिए MapReduce नौकरियों के साथ प्रयोग किया जाता है। HCatInputFormat डेटा पढ़ने के लिए एक Hadoop 0.20 MapReduce एपीआई को उजागर करता है जैसे कि यह एक मेज पर प्रकाशित किया गया था।

अनु क्रमांक। विधि का नाम और विवरण
1

public static HCatInputFormat setInput(Job job, String dbName, String tableName)throws IOException

नौकरी के लिए उपयोग करने के लिए इनपुट सेट करें। यह दिए गए इनपुट विनिर्देश के साथ मेटास्टोर पर सवाल उठाता है और MapReduce कार्यों के लिए कार्य कॉन्फ़िगरेशन में मिलान विभाजन को क्रमबद्ध करता है।

2

public static HCatInputFormat setInput(Configuration conf, String dbName, String tableName) throws IOException

नौकरी के लिए उपयोग करने के लिए इनपुट सेट करें। यह दिए गए इनपुट विनिर्देश के साथ मेटास्टोर पर सवाल उठाता है और MapReduce कार्यों के लिए कार्य कॉन्फ़िगरेशन में मिलान विभाजन को क्रमबद्ध करता है।

3

public HCatInputFormat setFilter(String filter)throws IOException

इनपुट टेबल पर एक फिल्टर सेट करें।

4

public HCatInputFormat setProperties(Properties properties) throws IOException

इनपुट प्रारूप के लिए गुण सेट करें।

HCatInputFormat API में निम्नलिखित विधियाँ शामिल हैं -

  • setInput
  • setOutputSchema
  • getTableSchema

काम में लाना HCatInputFormat डेटा पढ़ने के लिए, पहले तुरंत ए InputJobInfo पढ़ी जा रही तालिका से आवश्यक जानकारी और फिर फोन करें setInput उसके साथ InputJobInfo

आप उपयोग कर सकते हैं setOutputSchema शामिल करने की विधि a projection schema, उत्पादन क्षेत्रों को निर्दिष्ट करने के लिए। यदि एक स्कीमा निर्दिष्ट नहीं है, तो तालिका के सभी कॉलम वापस आ जाएंगे। आप निर्दिष्ट इनपुट तालिका के लिए तालिका स्कीमा निर्धारित करने के लिए getTableSchema विधि का उपयोग कर सकते हैं।

HCatOutputFormat

HCATOutputFormat का उपयोग MapReduce नौकरियों के साथ HCatalog प्रबंधित तालिकाओं में डेटा लिखने के लिए किया जाता है। HCatOutputFormat एक तालिका में डेटा लिखने के लिए एक Hadoop 0.20 MapReduce API को उजागर करता है। जब कोई MapReduce कार्य आउटपुट लिखने के लिए HCatOutputFormat का उपयोग करता है, तो तालिका के लिए कॉन्फ़िगर किया गया डिफ़ॉल्ट OutputFormat उपयोग किया जाता है और नया विभाजन कार्य पूरा होने के बाद तालिका में प्रकाशित किया जाता है।

अनु क्रमांक। विधि का नाम और विवरण
1

public static void setOutput (Configuration conf, Credentials credentials, OutputJobInfo outputJobInfo) throws IOException

नौकरी के लिए लिखने के लिए आउटपुट के बारे में जानकारी सेट करें। यह तालिका के लिए उपयोग करने के लिए StorageHandler को खोजने के लिए मेटाडेटा सर्वर से पूछताछ करता है। यह एक त्रुटि फेंकता है यदि विभाजन पहले से ही प्रकाशित है।

2

public static void setSchema (Configuration conf, HCatSchema schema) throws IOException

विभाजन के लिए लिखे जा रहे डेटा के लिए स्कीमा सेट करें। तालिका स्कीमा का उपयोग डिफ़ॉल्ट रूप से विभाजन के लिए किया जाता है यदि यह नहीं कहा जाता है।

3

public RecordWriter <WritableComparable<?>, HCatRecord > getRecordWriter (TaskAttemptContext context)throws IOException, InterruptedException

नौकरी के लिए रिकॉर्ड राइटर लें। यह StorageHandler के डिफ़ॉल्ट OutputFormat का उपयोग रिकॉर्ड लेखक को पाने के लिए करता है।

4

public OutputCommitter getOutputCommitter (TaskAttemptContext context) throws IOException, InterruptedException

इस आउटपुट प्रारूप के लिए आउटपुट कमिटर प्राप्त करें। यह सुनिश्चित करता है कि आउटपुट सही ढंग से प्रतिबद्ध है।

HCatOutputFormat एपीआई में निम्नलिखित विधियाँ शामिल हैं -

  • setOutput
  • setSchema
  • getTableSchema

HCatOutputFormat पर पहली कॉल होनी चाहिए setOutput; कोई अन्य कॉल अपवाद को यह कहते हुए फेंक देगा कि आउटपुट प्रारूप आरंभीकृत नहीं है।

डेटा जो लिखा जा रहा है, उसके लिए स्कीमा द्वारा निर्दिष्ट किया गया है setSchemaतरीका। आपको इस विधि को कॉल करना होगा, जो आपके द्वारा लिखे जा रहे डेटा का स्कीमा प्रदान करेगा। यदि आपके डेटा में टेबल स्कीमा के समान स्कीमा है, तो आप उपयोग कर सकते हैंHCatOutputFormat.getTableSchema() तालिका स्कीमा प्राप्त करने के लिए और उसके बाद पास करें setSchema()

उदाहरण

निम्न MapReduce प्रोग्राम एक तालिका से डेटा पढ़ता है जिसे वह दूसरे कॉलम ("कॉलम 1") में पूर्णांक मानता है, और गिनता है कि प्रत्येक भिन्न मान के कितने उदाहरण मिलते हैं। यही है, यह "के बराबर हैselect col1, count(*) from $table group by col1;"।

उदाहरण के लिए, यदि दूसरे कॉलम में मान {1, 1, 1, 3, 3, 5} हैं, तो प्रोग्राम निम्न मानों और काउंट्स के आउटपुट का उत्पादन करेगा -

1, 3
3, 2
5, 1

आइये अब एक नजर डालते हैं प्रोग्राम कोड पर -

import java.io.IOException;
import java.util.Iterator;

import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.conf.Configured;
import org.apache.hadoop.io.IntWritable;
import org.apache.hadoop.io.Text;
import org.apache.hadoop.io.WritableComparable;

import org.apache.hadoop.mapreduce.Job;
import org.apache.hadoop.mapreduce.Mapper;
import org.apache.hadoop.mapreduce.Reducer;

import org.apache.hadoop.util.GenericOptionsParser;
import org.apache.hadoop.util.Tool;
import org.apache.hadoop.util.ToolRunner;

import org.apache.HCatalog.common.HCatConstants;
import org.apache.HCatalog.data.DefaultHCatRecord;
import org.apache.HCatalog.data.HCatRecord;
import org.apache.HCatalog.data.schema.HCatSchema;

import org.apache.HCatalog.mapreduce.HCatInputFormat;
import org.apache.HCatalog.mapreduce.HCatOutputFormat;
import org.apache.HCatalog.mapreduce.InputJobInfo;
import org.apache.HCatalog.mapreduce.OutputJobInfo;

public class GroupByAge extends Configured implements Tool {

   public static class Map extends Mapper<WritableComparable, 
      HCatRecord, IntWritable, IntWritable> {
      int age;
		
      @Override
      protected void map(
         WritableComparable key, HCatRecord value,
         org.apache.hadoop.mapreduce.Mapper<WritableComparable,
         HCatRecord, IntWritable, IntWritable>.Context context
      )throws IOException, InterruptedException {
         age = (Integer) value.get(1);
         context.write(new IntWritable(age), new IntWritable(1));
      }
   }
	
   public static class Reduce extends Reducer<IntWritable, IntWritable,
      WritableComparable, HCatRecord> {
      @Override
      protected void reduce(
         IntWritable key, java.lang.Iterable<IntWritable> values,
         org.apache.hadoop.mapreduce.Reducer<IntWritable, IntWritable,
         WritableComparable, HCatRecord>.Context context
      )throws IOException ,InterruptedException {
         int sum = 0;
         Iterator<IntWritable> iter = values.iterator();
			
         while (iter.hasNext()) {
            sum++;
            iter.next();
         }
			
         HCatRecord record = new DefaultHCatRecord(2);
         record.set(0, key.get());
         record.set(1, sum);
         context.write(null, record);
      }
   }
	
   public int run(String[] args) throws Exception {
      Configuration conf = getConf();
      args = new GenericOptionsParser(conf, args).getRemainingArgs();
		
      String serverUri = args[0];
      String inputTableName = args[1];
      String outputTableName = args[2];
      String dbName = null;
      String principalID = System
		
      .getProperty(HCatConstants.HCAT_METASTORE_PRINCIPAL);
      if (principalID != null)
      conf.set(HCatConstants.HCAT_METASTORE_PRINCIPAL, principalID);
      Job job = new Job(conf, "GroupByAge");
      HCatInputFormat.setInput(job, InputJobInfo.create(dbName, inputTableName, null));

      // initialize HCatOutputFormat
      job.setInputFormatClass(HCatInputFormat.class);
      job.setJarByClass(GroupByAge.class);
      job.setMapperClass(Map.class);
      job.setReducerClass(Reduce.class);
		
      job.setMapOutputKeyClass(IntWritable.class);
      job.setMapOutputValueClass(IntWritable.class);
      job.setOutputKeyClass(WritableComparable.class);
      job.setOutputValueClass(DefaultHCatRecord.class);
		
      HCatOutputFormat.setOutput(job, OutputJobInfo.create(dbName, outputTableName, null));
      HCatSchema s = HCatOutputFormat.getTableSchema(job);
      System.err.println("INFO: output schema explicitly set for writing:" + s);
      HCatOutputFormat.setSchema(job, s);
      job.setOutputFormatClass(HCatOutputFormat.class);
      return (job.waitForCompletion(true) ? 0 : 1);
   }
	
   public static void main(String[] args) throws Exception {
      int exitCode = ToolRunner.run(new GroupByAge(), args);
      System.exit(exitCode);
   }
}

उपरोक्त कार्यक्रम को संकलित करने से पहले, आपको कुछ डाउनलोड करना होगा jars और उन लोगों को जोड़ें classpathइस आवेदन के लिए। आपको सभी हाइव जार और HCatalog जार (HCatalog-core-0.5.0.jar, hive-metastore-0.10.0.jar, libthrift-0.7.0.jar, hive-exec-0.10.0jar, डाउनलोड करने की आवश्यकता है libfb303-0.7.0.jar, jdo2-api-2.3-ec.jar, slf4j-api-1.6.1.jar)।

उन की प्रतिलिपि बनाने के लिए निम्न आदेशों का उपयोग करें jar से फ़ाइलें local सेवा HDFS और उन लोगों को जोड़ें classpath

bin/hadoop fs -copyFromLocal $HCAT_HOME/share/HCatalog/HCatalog-core-0.5.0.jar /tmp bin/hadoop fs -copyFromLocal $HIVE_HOME/lib/hive-metastore-0.10.0.jar /tmp
bin/hadoop fs -copyFromLocal $HIVE_HOME/lib/libthrift-0.7.0.jar /tmp bin/hadoop fs -copyFromLocal $HIVE_HOME/lib/hive-exec-0.10.0.jar /tmp
bin/hadoop fs -copyFromLocal $HIVE_HOME/lib/libfb303-0.7.0.jar /tmp bin/hadoop fs -copyFromLocal $HIVE_HOME/lib/jdo2-api-2.3-ec.jar /tmp
bin/hadoop fs -copyFromLocal $HIVE_HOME/lib/slf4j-api-1.6.1.jar /tmp

export LIB_JARS=hdfs:///tmp/HCatalog-core-0.5.0.jar,
hdfs:///tmp/hive-metastore-0.10.0.jar,
hdfs:///tmp/libthrift-0.7.0.jar,
hdfs:///tmp/hive-exec-0.10.0.jar,
hdfs:///tmp/libfb303-0.7.0.jar,
hdfs:///tmp/jdo2-api-2.3-ec.jar,
hdfs:///tmp/slf4j-api-1.6.1.jar

दिए गए प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग करें।

$HADOOP_HOME/bin/hadoop jar GroupByAge tmp/hive

अब, आउटपुट के लिए अपनी आउटपुट डायरेक्टरी (hdfs: user / tmp / hive) देखें (part_0000, part_0001)।

HCatLoader तथा HCatStorerHCatalog प्रबंधित तालिकाओं में डेटा पढ़ने और लिखने के लिए सुअर स्क्रिप्ट के साथ API का उपयोग किया जाता है। इन इंटरफेस के लिए कोई HCatalog- विशिष्ट सेटअप आवश्यक नहीं है।

इस अध्याय को बेहतर समझने के लिए Apache Pig स्क्रिप्ट पर कुछ ज्ञान होना बेहतर है। आगे के संदर्भ के लिए, कृपया हमारे Apache Pig ट्यूटोरियल से गुजरें।

HCatloader

HCatLoader का उपयोग Pig स्क्रिप्ट के साथ HCatalog- प्रबंधित तालिकाओं के डेटा को पढ़ने के लिए किया जाता है। एचसीएफएस में एचसीटीएस लोडर का उपयोग करके डेटा को लोड करने के लिए निम्न सिंटैक्स का उपयोग करें।

A = LOAD 'tablename' USING org.apache.HCatalog.pig.HCatLoader();

आपको एकल उद्धरणों में तालिका का नाम निर्दिष्ट करना होगा: LOAD 'tablename'। यदि आप एक गैर-डिफ़ॉल्ट डेटाबेस का उपयोग कर रहे हैं, तो आपको अपना इनपुट 'dbname.tablename'

हाइव मेटास्टोर आपको डेटाबेस निर्दिष्ट किए बिना टेबल बनाने देता है। यदि आपने इस तरह से तालिकाओं का निर्माण किया है, तो डेटाबेस का नाम है'default' और HCatLoader के लिए तालिका निर्दिष्ट करते समय इसकी आवश्यकता नहीं है।

निम्न तालिका में एचसीएटोडर वर्ग के महत्वपूर्ण तरीके और विवरण शामिल हैं।

अनु क्रमांक। विधि का नाम और विवरण
1

public InputFormat<?,?> getInputFormat()throws IOException

HCatloader वर्ग का उपयोग करके लोडिंग डेटा का इनपुट प्रारूप पढ़ें।

2

public String relativeToAbsolutePath(String location, Path curDir) throws IOException

यह स्ट्रिंग प्रारूप को लौटाता है Absolute path

3

public void setLocation(String location, Job job) throws IOException

यह उस स्थान को सेट करता है जहां नौकरी निष्पादित की जा सकती है।

4

public Tuple getNext() throws IOException

वर्तमान टपल लौटाता है (key तथा value) लूप से।

HCatStorer

HCatStorer का उपयोग Pig स्क्रिप्ट के साथ HCatalog- प्रबंधित तालिकाओं में डेटा लिखने के लिए किया जाता है। भंडारण के संचालन के लिए निम्नलिखित सिंटैक्स का उपयोग करें।

A = LOAD ...
B = FOREACH A ...
...
...
my_processed_data = ...

STORE my_processed_data INTO 'tablename' USING org.apache.HCatalog.pig.HCatStorer();

आपको एकल उद्धरणों में तालिका का नाम निर्दिष्ट करना होगा: LOAD 'tablename'। आपके पिग स्क्रिप्ट को चलाने से पहले डेटाबेस और टेबल दोनों को बनाया जाना चाहिए। यदि आप एक गैर-डिफ़ॉल्ट डेटाबेस का उपयोग कर रहे हैं, तो आपको अपना इनपुट निर्दिष्ट करना होगा'dbname.tablename'

हाइव मेटास्टोर आपको डेटाबेस निर्दिष्ट किए बिना टेबल बनाने देता है। यदि आपने इस तरह से तालिकाओं का निर्माण किया है, तो डेटाबेस का नाम है'default' और आपको डेटाबेस का नाम निर्दिष्ट करने की आवश्यकता नहीं है store बयान।

के लिए USINGखंड, आपके पास एक स्ट्रिंग तर्क हो सकता है जो विभाजन के लिए कुंजी / मान जोड़े का प्रतिनिधित्व करता है। यह एक अनिवार्य तर्क है जब आप एक विभाजन तालिका में लिख रहे हैं और विभाजन कॉलम आउटपुट कॉलम में नहीं है। विभाजन कुंजियों के मान को उद्धृत नहीं किया जाना चाहिए।

निम्न तालिका में महत्वपूर्ण तरीके और विवरण HCATStorer वर्ग के हैं।

अनु क्रमांक। विधि का नाम और विवरण
1

public OutputFormat getOutputFormat() throws IOException

HCatStorer वर्ग का उपयोग करके संग्रहीत डेटा का आउटपुट स्वरूप पढ़ें।

2

public void setStoreLocation (String location, Job job) throws IOException

उस स्थान को सेट करता है जहां इसे निष्पादित करना है store आवेदन।

3

public void storeSchema (ResourceSchema schema, String arg1, Job job) throws IOException

स्कीमा स्टोर करें।

4

public void prepareToWrite (RecordWriter writer) throws IOException

यह RecordWriter का उपयोग करके किसी विशेष फ़ाइल में डेटा लिखने में मदद करता है।

5

public void putNext (Tuple tuple) throws IOException

फ़ाइल में टपल डेटा लिखता है।

HCatalog के साथ सुअर चल रहा है

सुअर स्वचालित रूप से HCatalog जार नहीं उठाता है। आवश्यक जार में लाने के लिए, आप या तो सुअर कमांड में एक ध्वज का उपयोग कर सकते हैं या पर्यावरण चर सेट कर सकते हैंPIG_CLASSPATH तथा PIG_OPTS निम्नलिखित अनुसार।

HCatalog के साथ काम करने के लिए उपयुक्त जार में लाने के लिए, बस निम्नलिखित ध्वज शामिल करें -

pig –useHCatalog <Sample pig scripts file>

निष्पादन के लिए CLASSPATH की स्थापना

Apache Pig के साथ HCatalog सिंक्रनाइज़ करने के लिए निम्नलिखित CLASSPATH सेटिंग का उपयोग करें।

export HADOOP_HOME = <path_to_hadoop_install>
export HIVE_HOME = <path_to_hive_install>
export HCAT_HOME = <path_to_hcat_install>

export PIG_CLASSPATH = $HCAT_HOME/share/HCatalog/HCatalog-core*.jar:\ $HCAT_HOME/share/HCatalog/HCatalog-pig-adapter*.jar:\
$HIVE_HOME/lib/hive-metastore-*.jar:$HIVE_HOME/lib/libthrift-*.jar:\
$HIVE_HOME/lib/hive-exec-*.jar:$HIVE_HOME/lib/libfb303-*.jar:\
$HIVE_HOME/lib/jdo2-api-*-ec.jar:$HIVE_HOME/conf:$HADOOP_HOME/conf:\ $HIVE_HOME/lib/slf4j-api-*.jar

उदाहरण

मान लें कि हमारे पास एक फ़ाइल है student_details.txt एचडीएफएस निम्नलिखित सामग्री के साथ।

student_details.txt

001, Rajiv,    Reddy,       21, 9848022337, Hyderabad
002, siddarth, Battacharya, 22, 9848022338, Kolkata
003, Rajesh,   Khanna,      22, 9848022339, Delhi
004, Preethi,  Agarwal,     21, 9848022330, Pune
005, Trupthi,  Mohanthy,    23, 9848022336, Bhuwaneshwar
006, Archana,  Mishra,      23, 9848022335, Chennai
007, Komal,    Nayak,       24, 9848022334, trivendram
008, Bharathi, Nambiayar,   24, 9848022333, Chennai

हमारे पास नाम के साथ एक नमूना स्क्रिप्ट भी है sample_script.pig, उसी HDFS निर्देशिका में। इस फ़ाइल में संचालन और परिवर्तन करने वाले वक्तव्य हैंstudent संबंध, जैसा कि नीचे दिखाया गया है।

student = LOAD 'hdfs://localhost:9000/pig_data/student_details.txt' USING 
   PigStorage(',') as (id:int, firstname:chararray, lastname:chararray,
   phone:chararray, city:chararray);
	
student_order = ORDER student BY age DESC;
STORE student_order INTO 'student_order_table' USING org.apache.HCatalog.pig.HCatStorer();
student_limit = LIMIT student_order 4;
Dump student_limit;
  • स्क्रिप्ट का पहला स्टेटमेंट नाम की फाइल में डेटा लोड करेगा student_details.txt नाम के एक रिश्ते के रूप में student

  • पटकथा का दूसरा कथन, उम्र के आधार पर, अवरोही क्रम में संबंध के tuples को व्यवस्थित करेगा और इसे स्टोर करेगा student_order

  • तीसरा विवरण संसाधित डेटा संग्रहीत करता है student_order नाम की एक अलग तालिका में परिणाम student_order_table

  • स्क्रिप्ट का चौथा कथन पहले चार टुपल्स को संग्रहित करेगा student_order जैसा student_limit

  • अंत में पाँचवाँ कथन संबंध की सामग्री को खोद देगा student_limit

अब हम निष्पादित करते हैं sample_script.pig जैसा की नीचे दिखाया गया।

$./pig -useHCatalog hdfs://localhost:9000/pig_data/sample_script.pig

अब, आउटपुट के लिए अपनी आउटपुट डायरेक्टरी (hdfs: user / tmp / hive) देखें (part_0000, part_0001)।