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

पारंपरिक अनुप्रयोग प्रबंधन प्रणाली, यानी RDBMS का उपयोग करके रिलेशनल डेटाबेस के साथ अनुप्रयोगों की सहभागिता, बिग डेटा उत्पन्न करने वाले स्रोतों में से एक है। RDBMS द्वारा जनरेट किया गया ऐसा बिग डेटा, रिलेशनल में संग्रहित हैDatabase Servers संबंधपरक डेटाबेस संरचना में।

जब Hadoop इकोसिस्टम के बिग डेटा स्टोरेज और एनालाइज़र जैसे MapReduce, Hive, HBase, Cassandra, Pig, आदि चित्र में आए, तो उन्हें बिग डेटा को आयात करने और उन्हें निर्यात करने के लिए रिलेशनल डेटाबेस सर्वर के साथ बातचीत करने के लिए एक उपकरण की आवश्यकता थी। यहाँ, Sqoop संबंधपरक डेटाबेस सर्वर और Hadoop के HDFS के बीच व्यवहार्य सहभागिता प्रदान करने के लिए Hadoop पारिस्थितिकी तंत्र में एक स्थान रखता है।

Sqoop - "SQL से Hadoop और Hadoop से SQL"

Sqoop Hadoop और रिलेशनल डेटाबेस सर्वर के बीच डेटा ट्रांसफर करने के लिए डिज़ाइन किया गया एक टूल है। इसका उपयोग MySQL, Oracle से Hadoop HDFS जैसे रिलेशनल डेटाबेस से डेटा आयात करने और Hadoop फ़ाइल सिस्टम से रिलेशनल डेटाबेस में निर्यात करने के लिए किया जाता है। यह Apache Software Foundation द्वारा प्रदान किया गया है।

Sqoop कैसे काम करता है?

निम्न छवि Sqoop के वर्कफ़्लो का वर्णन करती है।

सकोप आयात

आयात उपकरण RDBMS से HDFS में अलग-अलग तालिकाओं का आयात करता है। तालिका में प्रत्येक पंक्ति को HDFS में रिकॉर्ड के रूप में माना जाता है। सभी रिकॉर्ड पाठ फ़ाइलों में पाठ डेटा के रूप में या एवरो और अनुक्रम फ़ाइलों में द्विआधारी डेटा के रूप में संग्रहीत किए जाते हैं।

Sqoop Export

निर्यात उपकरण HDFS से वापस RDBMS फाइल का एक सेट निर्यात करता है। Sqoop के इनपुट के रूप में दी गई फाइलों में रिकॉर्ड होते हैं, जिन्हें तालिका में पंक्तियों के रूप में कहा जाता है। जिन्हें पढ़ा और रिकॉर्ड के एक सेट में रखा गया है और उपयोगकर्ता-निर्दिष्ट सीमांकक के साथ सीमांकित किया गया है।

जैसा कि सोकूप हादोप की एक उप-परियोजना है, यह केवल लिनक्स ऑपरेटिंग सिस्टम पर काम कर सकता है। अपने सिस्टम पर Sqoop स्थापित करने के लिए नीचे दिए गए चरणों का पालन करें।

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

Sqoop को स्थापित करने से पहले आपको अपने सिस्टम पर जावा इंस्टॉल करना होगा। निम्नलिखित कमांड का उपयोग करके जावा इंस्टॉलेशन को सत्यापित करते हैं -

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

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

जावा को स्थापित करना

अपने सिस्टम पर जावा को स्थापित करने के लिए नीचे दिए गए सरल चरणों का पालन करें।

चरण 1

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

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

चरण 2

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

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

$ su
password:

# mv jdk1.7.0_71 /usr/local/java
# exitStep IV:

चरण 4

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

export JAVA_HOME=/usr/local/java
export PATH=$PATH:$JAVA_HOME/bin

अब वर्तमान में चल रहे सिस्टम में सभी परिवर्तनों को लागू करें।

$ source ~/.bashrc

चरण 5

जावा विकल्प को कॉन्फ़िगर करने के लिए निम्नलिखित कमांड का उपयोग करें -

# 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 स्थापना

Sqoop स्थापित करने से पहले अपने सिस्टम पर 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 स्थापित नहीं है, तो निम्न चरणों के साथ आगे बढ़ें -

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

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

छद्म-वितरित मोड में Hadoop 2.4.1 को स्थापित करने के लिए नीचे दिए गए चरणों का पालन करें।

चरण 1: Hadoop की स्थापना

आप निम्न कमांड को ~ / .bashrc फ़ाइल में जोड़कर Hadoop परिवेश चर सेट कर सकते हैं।

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

चरण 2: Hadoop कॉन्फ़िगरेशन

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

$ cd $HADOOP_HOME/etc/hadoop

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

export JAVA_HOME=/usr/local/java

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

core-site.xml

कोर- 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 बुनियादी ढांचे के अनुसार परिवर्तन कर सकते हैं।

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

Hadoop स्थापना का सत्यापन

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

चरण 1: नाम नोड सेटअप

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

चरण 2: सत्यापन 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: यार्न स्क्रिप्ट का सत्यापन

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

$ start-yarn.sh

अपेक्षित उत्पादन निम्नानुसार है -

starting yarn daemons
starting resourcemanager, logging to /home/hadoop/hadoop-
2.4.1/logs/yarn-hadoop-resourcemanager-localhost.out
localhost: starting node manager, logging to /home/hadoop/hadoop-
2.4.1/logs/yarn-hadoop-nodemanager-localhost.out

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

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

http://localhost:50070/

निम्न छवि में एक Hadoop ब्राउज़र दर्शाया गया है।

चरण 5: क्लस्टर के लिए सभी एप्लिकेशन सत्यापित करें

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

http://localhost:8088/

निम्न छवि Hadoop क्लस्टर ब्राउज़र को दर्शाती है।

चरण 3: Sqoop डाउनलोड करना

हम निम्न लिंक से Sqoop का नवीनतम संस्करण डाउनलोड कर सकते हैं। इस ट्यूटोरियल के लिए, हम संस्करण 1.4.5 का उपयोग कर रहे हैं, अर्थात्।sqoop-1.4.5.bin__hadoop-2.0.4-alpha.tar.gz

चरण 4: Sqoop स्थापित करना

Sqoop टार बॉल निकालने और इसे "/ usr / lib / squp" डायरेक्टरी में ले जाने के लिए निम्न कमांड्स का उपयोग किया जाता है।

$tar -xvf sqoop-1.4.4.bin__hadoop-2.0.4-alpha.tar.gz $ su
password:

# mv sqoop-1.4.4.bin__hadoop-2.0.4-alpha /usr/lib/sqoop
#exit

चरण 5: bashrc कॉन्फ़िगर करना

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

#Sqoop
export SQOOP_HOME=/usr/lib/sqoop export PATH=$PATH:$SQOOP_HOME/bin

निम्नलिखित कमांड का उपयोग ~ / निष्पादित करने के लिए किया जाता है.bashrc फ़ाइल।

$ source ~/.bashrc

चरण 6: Sqoop कॉन्फ़िगर करना

सैदूप को हडोप के साथ कॉन्फ़िगर करने के लिए, आपको एडिट करना होगा sqoop-env.sh फ़ाइल, जिसमें रखा गया है $SQOOP_HOME/confनिर्देशिका। सबसे पहले, Sqoop config directory में रीडायरेक्ट करें और निम्न कमांड का उपयोग करके टेम्पलेट फ़ाइल को कॉपी करें -

$ cd $SQOOP_HOME/conf
$ mv sqoop-env-template.sh sqoop-env.sh

खुला हुआ sqoop-env.sh और निम्नलिखित पंक्तियों को संपादित करें -

export HADOOP_COMMON_HOME=/usr/local/hadoop 
export HADOOP_MAPRED_HOME=/usr/local/hadoop

चरण 7: mysql-कनेक्टर-जावा को डाउनलोड और कॉन्फ़िगर करें

हम डाउनलोड कर सकते हैं mysql-connector-java-5.1.30.tar.gzनिम्नलिखित लिंक से फ़ाइल ।

Mysql-कनेक्टर-जावा टैरबॉल निकालने और स्थानांतरित करने के लिए निम्न कमांड का उपयोग किया जाता है mysql-connector-java-5.1.30-bin.jar / usr / lib / squp / lib निर्देशिका के लिए।

$ tar -zxf mysql-connector-java-5.1.30.tar.gz
$ su
password:

# cd mysql-connector-java-5.1.30
# mv mysql-connector-java-5.1.30-bin.jar /usr/lib/sqoop/lib

चरण 8: Sqoop सत्यापित करना

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

$ cd $SQOOP_HOME/bin $ sqoop-version

अपेक्षित उत्पादन -

14/12/17 14:52:32 INFO sqoop.Sqoop: Running Sqoop version: 1.4.5
Sqoop 1.4.5 git commit id 5b34accaca7de251fc91161733f906af2eddbe83
Compiled by abe on Fri Aug 1 11:19:26 PDT 2014

Sqoop स्थापना पूर्ण है।

यह अध्याय बताता है कि MySQL डेटाबेस से डेटा को Hadoop HDFS में कैसे आयात किया जाए। 'आयात उपकरण' RDBMS से HDFS में अलग-अलग तालिकाओं का आयात करता है। तालिका में प्रत्येक पंक्ति को HDFS में रिकॉर्ड के रूप में माना जाता है। सभी रिकॉर्ड पाठ फ़ाइलों में पाठ डेटा के रूप में या एवरो और अनुक्रम फ़ाइलों में द्विआधारी डेटा के रूप में संग्रहीत किए जाते हैं।

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

एचडीएफएस में डेटा आयात करने के लिए निम्न सिंटैक्स का उपयोग किया जाता है।

$ sqoop import (generic-args) (import-args) $ sqoop-import (generic-args) (import-args)

उदाहरण

आइए हम तीन तालिकाओं का उदाहरण लें emp, emp_add, तथा emp_contact, जो MySQL डेटाबेस सर्वर में userdb नामक डेटाबेस में हैं।

तीन तालिकाओं और उनके डेटा निम्नानुसार हैं।

emp:

ईद नाम डिग्री वेतन विभाग
1201 गोपाल मैनेजर 50,000 टी.पी.
1202 मनीषा प्रमाण पाठक 50,000 टी.पी.
1203 खलील php देव 30,000 एसी
1204 प्रशांत php देव 30,000 एसी
1204 क्रांति व्यवस्थापक 20,000 टी.पी.

emp_add:

ईद HNO सड़क Faridabad
1201 288A vgiri jublee
1202 108I एओसी सेकंड-बुरा
1203 144Z pgutta Hyd
1204 78B पुराना शहर सेकंड-बुरा
1205 720X उच्च तकनीकीय सेकंड-बुरा

emp_contact:

ईद phno ईमेल
1201 2356742 gopal@tp.com
1202 1661663 manisha@tp.com
1203 8887776 khalil@ac.com
1204 9988774 prasanth@ac.com
1205 1231231 kranthi@tp.com

एक तालिका आयात करना

Sqoop tool 'import' का उपयोग टेबल डेटा को टेबुल से Hadoop फाइल सिस्टम में टेक्स्ट फाइल या बाइनरी फाइल के रूप में आयात करने के लिए किया जाता है।

आयात करने के लिए निम्न कमांड का उपयोग किया जाता है emp MySQL डेटाबेस सर्वर से HDFS के लिए तालिका।

$ sqoop import \
--connect jdbc:mysql://localhost/userdb \
--username root \
--table emp --m 1

यदि इसे सफलतापूर्वक निष्पादित किया जाता है, तो आपको निम्न आउटपुट मिलते हैं।

14/12/22 15:24:54 INFO sqoop.Sqoop: Running Sqoop version: 1.4.5
14/12/22 15:24:56 INFO manager.MySQLManager: Preparing to use a MySQL streaming resultset.
14/12/22 15:24:56 INFO tool.CodeGenTool: Beginning code generation
14/12/22 15:24:58 INFO manager.SqlManager: Executing SQL statement: 
   SELECT t.* FROM `emp` AS t LIMIT 1
14/12/22 15:24:58 INFO manager.SqlManager: Executing SQL statement: 
   SELECT t.* FROM `emp` AS t LIMIT 1
14/12/22 15:24:58 INFO orm.CompilationManager: HADOOP_MAPRED_HOME is /usr/local/hadoop
14/12/22 15:25:11 INFO orm.CompilationManager: Writing jar file: 
   /tmp/sqoop-hadoop/compile/cebe706d23ebb1fd99c1f063ad51ebd7/emp.jar
-----------------------------------------------------
-----------------------------------------------------
14/12/22 15:25:40 INFO mapreduce.Job: The url to track the job: 
   http://localhost:8088/proxy/application_1419242001831_0001/
14/12/22 15:26:45 INFO mapreduce.Job: Job job_1419242001831_0001 running in uber mode : 
   false
14/12/22 15:26:45 INFO mapreduce.Job: map 0% reduce 0%
14/12/22 15:28:08 INFO mapreduce.Job: map 100% reduce 0%
14/12/22 15:28:16 INFO mapreduce.Job: Job job_1419242001831_0001 completed successfully
-----------------------------------------------------
-----------------------------------------------------
14/12/22 15:28:17 INFO mapreduce.ImportJobBase: Transferred 145 bytes in 177.5849 seconds 
   (0.8165 bytes/sec)
14/12/22 15:28:17 INFO mapreduce.ImportJobBase: Retrieved 5 records.

एचडीएफएस में आयातित डेटा को सत्यापित करने के लिए, निम्न कमांड का उपयोग करें।

$ $HADOOP_HOME/bin/hadoop fs -cat /emp/part-m-*

यह आपको दिखाता है emp तालिका डेटा और फ़ील्ड अल्पविराम (,) से अलग किए गए हैं।

1201, gopal,    manager, 50000, TP
1202, manisha,  preader, 50000, TP
1203, kalil,    php dev, 30000, AC
1204, prasanth, php dev, 30000, AC
1205, kranthi,  admin,   20000, TP

लक्ष्य निर्देशिका में आयात करना

हम Sqoop आयात उपकरण का उपयोग करके HDFS में तालिका डेटा आयात करते समय लक्ष्य निर्देशिका निर्दिष्ट कर सकते हैं।

Sqoop आयात कमांड के विकल्प के रूप में लक्ष्य निर्देशिका को निर्दिष्ट करने के लिए सिंटैक्स निम्नलिखित है।

--target-dir <new or exist directory in HDFS>

आयात करने के लिए निम्न कमांड का उपयोग किया जाता है emp_add तालिका डेटा '/ क्वेरीसॉल्ट' निर्देशिका में।

$ sqoop import \
--connect jdbc:mysql://localhost/userdb \
--username root \
--table emp_add \
--m 1 \
--target-dir /queryresult

निम्न आदेश का उपयोग आयातित डेटा को / queryresult निर्देशिका फॉर्म में सत्यापित करने के लिए किया जाता है emp_add तालिका।

$ $HADOOP_HOME/bin/hadoop fs -cat /queryresult/part-m-*

यह आपको अल्पविराम (,) अलग किए गए फ़ील्ड के साथ emp_add टेबल डेटा दिखाएगा।

1201, 288A, vgiri,   jublee
1202, 108I, aoc,     sec-bad
1203, 144Z, pgutta,  hyd
1204, 78B,  oldcity, sec-bad
1205, 720C, hitech,  sec-bad

तालिका डेटा का आयात सबसेट

हम Sqoop आयात उपकरण में 'जहां' क्लॉज का उपयोग करके एक तालिका का सबसेट आयात कर सकते हैं। यह संबंधित डेटाबेस सर्वर में संबंधित SQL क्वेरी को निष्पादित करता है और परिणाम को एचडीएफएस में लक्ष्य निर्देशिका में संग्रहीत करता है।

जहाँ खंड के लिए वाक्य रचना इस प्रकार है।

--where <condition>

निम्न आदेश का उपयोग सबसेट को आयात करने के लिए किया जाता है emp_addतालिका डेटा। सबसे बड़ी क्वेरी कर्मचारी आईडी और पता प्राप्त करने की है, जो सिकंदराबाद शहर में रहता है।

$ sqoop import \
--connect jdbc:mysql://localhost/userdb \
--username root \
--table emp_add \
--m 1 \
--where “city =’sec-bad’” \
--target-dir /wherequery

निम्न आदेश का उपयोग आयातित डेटा को / जहाँ से निर्देशिका निर्देशिका में सत्यापित करने के लिए किया जाता है emp_add तालिका।

$ $HADOOP_HOME/bin/hadoop fs -cat /wherequery/part-m-*

यह आपको दिखाएगा emp_add अल्पविराम (,) के साथ तालिका डेटा अलग किए गए फ़ील्ड।

1202, 108I, aoc,     sec-bad
1204, 78B,  oldcity, sec-bad
1205, 720C, hitech,  sec-bad

वृद्धिशील आयात

वृद्धिशील आयात एक ऐसी तकनीक है जो एक तालिका में केवल नई जोड़ी गई पंक्तियों को आयात करती है। वृद्धिशील आयात करने के लिए 'वृद्धिशील', 'जाँच-स्तंभ' और 'अंतिम-मूल्य' विकल्प जोड़ना आवश्यक है।

निम्न वाक्यविन्यास Sqoop आयात कमांड में वृद्धिशील विकल्प के लिए उपयोग किया जाता है।

--incremental <mode>
--check-column <column name>
--last value <last check column value>

आइए हम नए जोड़े गए डेटा को मानते हैं emp तालिका इस प्रकार है -

1206, satish p, grp des, 20000, GR

में वृद्धिशील आयात करने के लिए निम्न कमांड का उपयोग किया जाता है emp तालिका।

$ sqoop import \
--connect jdbc:mysql://localhost/userdb \
--username root \
--table emp \
--m 1 \
--incremental append \
--check-column id \
-last value 1205

निम्न आदेश का उपयोग आयातित डेटा को सत्यापित करने के लिए किया जाता है emp एचडीएफएस सूची / निर्देशिका के लिए तालिका।

$ $HADOOP_HOME/bin/hadoop fs -cat /emp/part-m-*

यह आपको दिखाता है emp अल्पविराम (,) के साथ तालिका डेटा अलग किए गए फ़ील्ड।

1201, gopal,    manager, 50000, TP
1202, manisha,  preader, 50000, TP
1203, kalil,    php dev, 30000, AC
1204, prasanth, php dev, 30000, AC
1205, kranthi,  admin,   20000, TP
1206, satish p, grp des, 20000, GR

निम्न आदेश का उपयोग संशोधित या नई जोड़ी गई पंक्तियों को देखने के लिए किया जाता है emp तालिका।

$ $HADOOP_HOME/bin/hadoop fs -cat /emp/part-m-*1

यह आपको नई जोड़ी गई पंक्तियों को दिखाता है emp अल्पविराम (,) से अलग किए गए फ़ील्ड।

1206, satish p, grp des, 20000, GR

यह अध्याय वर्णन करता है कि RDBMS डेटाबेस सर्वर से HDFS में सभी तालिकाओं को कैसे आयात किया जाए। प्रत्येक तालिका डेटा को एक अलग निर्देशिका में संग्रहीत किया जाता है और निर्देशिका नाम तालिका नाम के समान है।

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

सभी तालिकाओं को आयात करने के लिए निम्न सिंटैक्स का उपयोग किया जाता है।

$ sqoop import-all-tables (generic-args) (import-args) $ sqoop-import-all-tables (generic-args) (import-args)

उदाहरण

आइए हम सभी तालिकाओं से आयात करने का एक उदाहरण लेते हैं userdbडेटाबेस। डेटाबेस कि तालिकाओं की सूचीuserdb इस प्रकार है।

+--------------------+
 |      Tables        |
 +--------------------+
 |      emp           |
 |      emp_add       |
 |      emp_contact   |
 +--------------------+

निम्न आदेश सभी तालिकाओं से आयात करने के लिए उपयोग किया जाता है userdb डेटाबेस।

$ sqoop import-all-tables \
--connect jdbc:mysql://localhost/userdb \
--username root

Note - यदि आप आयात-सभी-तालिकाओं का उपयोग कर रहे हैं, तो यह अनिवार्य है कि उस डेटाबेस की प्रत्येक तालिका में एक प्राथमिक कुंजी फ़ील्ड होनी चाहिए।

एचडीएफएस में उपयोगकर्ता डेटाबेस के लिए सभी तालिका डेटा को सत्यापित करने के लिए निम्न कमांड का उपयोग किया जाता है।

$ $HADOOP_HOME/bin/hadoop fs -ls

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

उत्पादन

drwxr-xr-x - hadoop supergroup 0 2014-12-22 22:50 _sqoop
drwxr-xr-x - hadoop supergroup 0 2014-12-23 01:46 emp
drwxr-xr-x - hadoop supergroup 0 2014-12-23 01:50 emp_add
drwxr-xr-x - hadoop supergroup 0 2014-12-23 01:52 emp_contact

यह अध्याय एचडीएफएस से आरडीबीएमएस डेटाबेस में डेटा वापस निर्यात करने का तरीका बताता है। लक्ष्य तालिका लक्ष्य डेटाबेस में मौजूद होनी चाहिए। Sqoop के इनपुट के रूप में दी गई फ़ाइलों में रिकॉर्ड होते हैं, जिन्हें तालिका में पंक्तियाँ कहा जाता है। जिन्हें पढ़ा और रिकॉर्ड के एक सेट में रखा गया है और उपयोगकर्ता-निर्दिष्ट सीमांकक के साथ सीमांकित किया गया है।

डिफ़ॉल्ट ऑपरेशन INSERT स्टेटमेंट का उपयोग करके इनपुट फ़ाइल से डेटाबेस तालिका में सभी रिकॉर्ड सम्मिलित करना है। अपडेट मोड में, Sqoop UPDATE स्टेटमेंट बनाता है जो मौजूदा रिकॉर्ड को डेटाबेस में बदल देता है।

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

निर्यात कमांड के लिए निम्नलिखित सिंटैक्स है।

$ sqoop export (generic-args) (export-args) 
$ sqoop-export (generic-args) (export-args)

उदाहरण

एचडीएफएस में फाइल में कर्मचारी डेटा का एक उदाहरण लेते हैं। कर्मचारी डेटा में उपलब्ध हैemp_dataHDFS में 'एम्पायर /' डायरेक्टरी में फाइल करें। emp_data इस प्रकार है।

1201, gopal,     manager, 50000, TP
1202, manisha,   preader, 50000, TP
1203, kalil,     php dev, 30000, AC
1204, prasanth,  php dev, 30000, AC
1205, kranthi,   admin,   20000, TP
1206, satish p,  grp des, 20000, GR

यह अनिवार्य है कि निर्यात की जाने वाली तालिका मैन्युअल रूप से बनाई गई है और डेटाबेस में मौजूद है जहां से इसे निर्यात किया जाना है।

Mysql कमांड लाइन में टेबल 'कर्मचारी' बनाने के लिए निम्नलिखित क्वेरी का उपयोग किया जाता है।

$ mysql
mysql> USE db;
mysql> CREATE TABLE employee ( 
   id INT NOT NULL PRIMARY KEY, 
   name VARCHAR(20), 
   deg VARCHAR(20),
   salary INT,
   dept VARCHAR(10));

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

$ sqoop export \
--connect jdbc:mysql://localhost/db \
--username root \
--table employee \ 
--export-dir /emp/emp_data

Mysql कमांड लाइन में तालिका को सत्यापित करने के लिए निम्न कमांड का उपयोग किया जाता है।

mysql>select * from employee;

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

+------+--------------+-------------+-------------------+--------+
| Id   | Name         | Designation | Salary            | Dept   |
+------+--------------+-------------+-------------------+--------+
| 1201 | gopal        | manager     | 50000             | TP     |
| 1202 | manisha      | preader     | 50000             | TP     |
| 1203 | kalil        | php dev     | 30000             | AC     |
| 1204 | prasanth     | php dev     | 30000             | AC     |
| 1205 | kranthi      | admin       | 20000             | TP     |
| 1206 | satish p     | grp des     | 20000             | GR     |
+------+--------------+-------------+-------------------+--------+

इस अध्याय में बताया गया है कि Sqoop नौकरियों का निर्माण और रखरखाव कैसे किया जाता है। Sqoop job आयात और निर्यात कमांड बनाता है और बचाता है। यह सहेजे गए कार्य को पहचानने और याद करने के लिए पैरामीटर निर्दिष्ट करता है। इस री-कॉलिंग या री-एक्जीक्यूटिंग को वृद्धिशील आयात में उपयोग किया जाता है, जो आरडीबीएमएस टेबल से एचडीएफएस तक अद्यतन पंक्तियों को आयात कर सकता है।

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

Sqoop job बनाने के लिए निम्नलिखित सिंटैक्स है।

$ sqoop job (generic-args) (job-args)
   [-- [subtool-name] (subtool-args)]

$ sqoop-job (generic-args) (job-args)
   [-- [subtool-name] (subtool-args)]

नौकरी बनाएँ (- बनाएँ)

यहां हम नाम के साथ एक नौकरी पैदा कर रहे हैं myjob, जो RDBMS तालिका से HDFS में तालिका डेटा आयात कर सकता है। निम्न कमांड का उपयोग उस कार्य को बनाने के लिए किया जाता है जो डेटा आयात कर रहा हैemployee में तालिका db HDFS फ़ाइल के लिए डेटाबेस।

$ sqoop job --create myjob \
-- import \
--connect jdbc:mysql://localhost/db \
--username root \
--table employee --m 1

नौकरी सत्यापित करें (- सूची)

‘--list’सहेजी गई नौकरियों को सत्यापित करने के लिए तर्क का उपयोग किया जाता है। निम्न कमांड का उपयोग सहेजे गए नौकरी की सूची को सत्यापित करने के लिए किया जाता है।

$ sqoop job --list

यह सहेजी गई नौकरियों की सूची दिखाता है।

Available jobs: 
   myjob

नौकरी का निरीक्षण (-)

‘--show’तर्क का उपयोग विशेष नौकरियों और उनके विवरणों का निरीक्षण या सत्यापन करने के लिए किया जाता है। निम्नलिखित कमांड और नमूना आउटपुट का उपयोग किसी कार्य को सत्यापित करने के लिए किया जाता हैmyjob

$ sqoop job --show myjob

यह उन औजारों और उनके विकल्पों को दर्शाता है, जिनका उपयोग किया जाता है myjob

Job: myjob 
 Tool: import Options:
 ---------------------------- 
 direct.import = true
 codegen.input.delimiters.record = 0
 hdfs.append.dir = false 
 db.table = employee
 ...
 incremental.last.value = 1206
 ...

निष्पादित नौकरी (--exec)

‘--exec’विकल्प का उपयोग किसी सहेजे गए कार्य को निष्पादित करने के लिए किया जाता है। निम्न कमांड का उपयोग सहेजे गए कार्य को निष्पादित करने के लिए किया जाता हैmyjob

$ sqoop job --exec myjob

यह आपको निम्न आउटपुट दिखाता है।

10/08/19 13:08:45 INFO tool.CodeGenTool: Beginning code generation 
...

यह अध्याय 'कोडजेन' टूल के महत्व का वर्णन करता है। ऑब्जेक्ट-ओरिएंटेड एप्लिकेशन के दृष्टिकोण से, प्रत्येक डेटाबेस तालिका में एक DAO वर्ग होता है जिसमें ऑब्जेक्ट्स को इनिशियलाइज़ करने के लिए 'गेट्टर' और 'सेटर' विधियाँ होती हैं। यह उपकरण (-codegen) स्वचालित रूप से DAO वर्ग उत्पन्न करता है।

यह तालिका स्कीमा संरचना के आधार पर जावा में DAO वर्ग उत्पन्न करता है। आयात प्रक्रिया के एक हिस्से के रूप में जावा परिभाषा को तुरंत तैयार किया गया है। इस उपकरण का मुख्य उपयोग यह जांचने के लिए है कि क्या जावा ने जावा कोड खो दिया है। यदि ऐसा है, तो यह खेतों के बीच डिफ़ॉल्ट सीमांकक के साथ जावा का एक नया संस्करण बनाएगा।

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

Sqoop codegen कमांड के लिए सिंटैक्स निम्नलिखित है।

$ sqoop codegen (generic-args) (codegen-args) 
$ sqoop-codegen (generic-args) (codegen-args)

उदाहरण

आइए एक उदाहरण लेते हैं जो जावा कोड को उत्पन्न करता है emp में तालिका userdb डेटाबेस।

दिए गए उदाहरण को निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

$ sqoop codegen \
--connect jdbc:mysql://localhost/userdb \
--username root \ 
--table emp

यदि कमांड सफलतापूर्वक निष्पादित होता है, तो यह टर्मिनल पर निम्न आउटपुट का उत्पादन करेगा।

14/12/23 02:34:40 INFO sqoop.Sqoop: Running Sqoop version: 1.4.5
14/12/23 02:34:41 INFO tool.CodeGenTool: Beginning code generation
……………….
14/12/23 02:34:42 INFO orm.CompilationManager: HADOOP_MAPRED_HOME is /usr/local/hadoop
Note: /tmp/sqoop-hadoop/compile/9a300a1f94899df4a9b10f9935ed9f91/emp.java uses or 
   overrides a deprecated API.
Note: Recompile with -Xlint:deprecation for details.

14/12/23 02:34:47 INFO orm.CompilationManager: Writing jar file: 
   /tmp/sqoop-hadoop/compile/9a300a1f94899df4a9b10f9935ed9f91/emp.jar

सत्यापन

आइए आउटपुट पर एक नज़र डालें। पथ, जो बोल्ड में है, वह स्थान है जिसका जावा कोड हैempतालिका उत्पन्न और संग्रहीत करता है। आइए निम्न कमांड्स का उपयोग करके उस स्थान की फाइलों को सत्यापित करें।

$ cd /tmp/sqoop-hadoop/compile/9a300a1f94899df4a9b10f9935ed9f91/ $ ls
emp.class
emp.jar
emp.java

यदि आप गहराई से सत्यापित करना चाहते हैं, तो तुलना करें emp में तालिका userdb डेटाबेस और emp.java निम्नलिखित निर्देशिका में

/ Tmp / sqoop-Hadoop / संकलन / 9a300a1f94899df4a9b10f9935ed9f91 /।

यह अध्याय बताता है कि Sqoop 'eval' टूल का उपयोग कैसे करें। यह उपयोगकर्ताओं को संबंधित डेटाबेस सर्वर के खिलाफ उपयोगकर्ता-परिभाषित प्रश्नों को निष्पादित करने और कंसोल में परिणाम का पूर्वावलोकन करने की अनुमति देता है। इसलिए, उपयोगकर्ता परिणामी तालिका डेटा आयात करने की अपेक्षा कर सकता है। Eval का उपयोग करके, हम किसी भी प्रकार की SQL क्वेरी का मूल्यांकन कर सकते हैं जो DDL या DML स्टेटमेंट हो सकती है।

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

निम्न सिंटैक्स का उपयोग Sqoop eval कमांड के लिए किया जाता है।

$ sqoop eval (generic-args) (eval-args) $ sqoop-eval (generic-args) (eval-args)

क्वेरी मूल्यांकन चुनें

Eval टूल का उपयोग करके, हम किसी भी प्रकार की SQL क्वेरी का मूल्यांकन कर सकते हैं। आइए हम सीमित पंक्तियों को चुनने का एक उदाहरण लेते हैंemployee की तालिका dbडेटाबेस। निम्न आदेश का उपयोग SQL क्वेरी का उपयोग करके दिए गए उदाहरण का मूल्यांकन करने के लिए किया जाता है।

$ sqoop eval \
--connect jdbc:mysql://localhost/db \
--username root \ 
--query “SELECT * FROM employee LIMIT 3”

यदि कमांड सफलतापूर्वक निष्पादित होता है, तो यह टर्मिनल पर निम्न आउटपुट का उत्पादन करेगा।

+------+--------------+-------------+-------------------+--------+
| Id   | Name         | Designation | Salary            | Dept   |
+------+--------------+-------------+-------------------+--------+
| 1201 | gopal        | manager     | 50000             | TP     |
| 1202 | manisha      | preader     | 50000             | TP     |
| 1203 | khalil       | php dev     | 30000             | AC     |
+------+--------------+-------------+-------------------+--------+

क्वेरी मूल्यांकन डालें

Sqoop eval टूल मॉडलिंग और SQL कथनों को परिभाषित करने दोनों के लिए लागू हो सकता है। इसका मतलब है कि, हम एक्सट्रेक्ट का इस्तेमाल इंसर्ट स्टेटमेंट के लिए भी कर सकते हैं। में एक नई पंक्ति सम्मिलित करने के लिए निम्न कमांड का उपयोग किया जाता हैemployee की तालिका db डेटाबेस।

$ sqoop eval \
--connect jdbc:mysql://localhost/db \
--username root \ 
-e “INSERT INTO employee VALUES(1207,‘Raju’,‘UI dev’,15000,‘TP’)”

यदि कमांड सफलतापूर्वक निष्पादित होता है, तो यह कंसोल पर अद्यतन पंक्तियों की स्थिति प्रदर्शित करेगा।

या फिर, आप MySQL कंसोल पर कर्मचारी तालिका को सत्यापित कर सकते हैं। निम्नलिखित पंक्तियों का उपयोग पंक्तियों के सत्यापन के लिए किया जाता हैemployee की तालिका db डेटाबेस 'क्वेरी का चयन करें।

mysql>
mysql> use db;
mysql> SELECT * FROM employee;
+------+--------------+-------------+-------------------+--------+
| Id   | Name         | Designation | Salary            | Dept   |
+------+--------------+-------------+-------------------+--------+
| 1201 | gopal        | manager     | 50000             | TP     |
| 1202 | manisha      | preader     | 50000             | TP     |
| 1203 | khalil       | php dev     | 30000             | AC     |
| 1204 | prasanth     | php dev     | 30000             | AC     |
| 1205 | kranthi      | admin       | 20000             | TP     |
| 1206 | satish p     | grp des     | 20000             | GR     |
| 1207 | Raju         | UI dev      | 15000             | TP     |
+------+--------------+-------------+-------------------+--------+

यह अध्याय बताता है कि Sqoop का उपयोग करके डेटाबेस को कैसे सूचीबद्ध किया जाए। Sqoop सूची-डेटाबेस टूल पार्स करता है और डेटाबेस सर्वर के खिलाफ 'SHOW DATABASES' क्वेरी निष्पादित करता है। इसके बाद, यह सर्वर पर मौजूद डेटाबेस को सूचीबद्ध करता है।

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

निम्न सिंटैक्स का उपयोग Sqoop सूची-डेटाबेस कमांड के लिए किया जाता है।

$ sqoop list-databases (generic-args) (list-databases-args) $ sqoop-list-databases (generic-args) (list-databases-args)

नमूना क्वेरी

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

$ sqoop list-databases \
--connect jdbc:mysql://localhost/ \
--username root

यदि कमांड सफलतापूर्वक निष्पादित होता है, तो यह आपके MySQL डेटाबेस सर्वर में डेटाबेस की सूची निम्नानुसार प्रदर्शित करेगा।

...
13/05/31 16:45:58 INFO manager.MySQLManager: Preparing to use a MySQL streaming resultset.

mysql
test
userdb
db

यह अध्याय बताता है कि Sqoop का उपयोग करके MySQL डेटाबेस सर्वर में किसी विशेष डेटाबेस की तालिकाओं को कैसे सूचीबद्ध किया जाए। Sqoop सूची-तालिका उपकरण पार्स करता है और किसी विशेष डेटाबेस के विरुद्ध 'SHOW TABLES' क्वेरी निष्पादित करता है। इसके बाद, यह एक डेटाबेस में मौजूद तालिकाओं को सूचीबद्ध करता है।

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

निम्न सिंटैक्स का उपयोग Sqoop सूची-तालिकाओं कमांड के लिए किया जाता है।

$ sqoop list-tables (generic-args) (list-tables-args) 
$ sqoop-list-tables (generic-args) (list-tables-args)

नमूना क्वेरी

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

$ sqoop list-tables \
--connect jdbc:mysql://localhost/userdb \
--username root

यदि कमांड सफलतापूर्वक निष्पादित होता है, तो यह टेबल की सूची को प्रदर्शित करेगा userdb डेटाबेस निम्नानुसार है।

...
13/05/31 16:45:58 INFO manager.MySQLManager: Preparing to use a MySQL streaming resultset.

emp
emp_add
emp_contact

यह अध्याय बताता है कि Sqoop का उपयोग करके MySQL डेटाबेस सर्वर में किसी विशेष डेटाबेस की तालिकाओं को कैसे सूचीबद्ध किया जाए। Sqoop सूची-तालिका उपकरण पार्स करता है और किसी विशेष डेटाबेस के विरुद्ध 'SHOW TABLES' क्वेरी निष्पादित करता है। इसके बाद, यह एक डेटाबेस में मौजूद तालिकाओं को सूचीबद्ध करता है।

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

निम्न सिंटैक्स का उपयोग Sqoop सूची-तालिकाओं कमांड के लिए किया जाता है।

$ sqoop list-tables (generic-args) (list-tables-args) $ sqoop-list-tables (generic-args) (list-tables-args)

नमूना क्वेरी

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

$ sqoop list-tables \
--connect jdbc:mysql://localhost/userdb \
--username root

यदि कमांड सफलतापूर्वक निष्पादित होता है, तो यह टेबल की सूची को प्रदर्शित करेगा userdb डेटाबेस निम्नानुसार है।

...
13/05/31 16:45:58 INFO manager.MySQLManager: Preparing to use a MySQL streaming resultset.

emp
emp_add
emp_contact