HCatalog-퀵 가이드

HCatalog는 무엇입니까?

HCatalog는 Hadoop 용 테이블 스토리지 관리 도구입니다. Hive 메타 스토어의 테이블 형식 데이터를 다른 Hadoop 애플리케이션에 노출합니다. 다양한 데이터 처리 도구 (Pig, MapReduce)를 사용하는 사용자가 그리드에 데이터를 쉽게 쓸 수 있습니다. 사용자는 데이터가 저장되는 위치 또는 형식에 대해 걱정할 필요가 없습니다.

HCatalog는 Hive의 핵심 구성 요소처럼 작동하며 사용자가 모든 형식 및 구조로 데이터를 저장할 수 있습니다.

왜 HCatalog인가?

올바른 작업을위한 올바른 도구 사용

Hadoop 에코 시스템에는 Hive, Pig 및 MapReduce와 같은 데이터 처리를위한 다양한 도구가 포함되어 있습니다. 이러한 도구에는 메타 데이터가 필요하지 않지만 메타 데이터가있는 경우에도 이점을 얻을 수 있습니다. 메타 데이터 저장소를 공유하면 여러 도구에서 사용자가 데이터를 더 쉽게 공유 할 수 있습니다. MapReduce 또는 Pig를 사용하여 데이터를로드하고 정규화 한 다음 Hive를 통해 분석하는 워크 플로는 매우 일반적입니다. 이러한 모든 도구가 하나의 메타 스토어를 공유하는 경우 각 도구의 사용자는 다른 도구로 생성 된 데이터에 즉시 액세스 할 수 있습니다. 로드 또는 전송 단계가 필요하지 않습니다.

공유를 활성화하기 위해 처리 상태 캡처

HCatalog는 분석 결과를 게시 할 수 있습니다. 따라서 다른 프로그래머는 "REST"를 통해 분석 플랫폼에 액세스 할 수 있습니다. 사용자가 게시 한 스키마는 다른 데이터 과학자에게도 유용합니다. 다른 데이터 과학자들은 귀하의 발견을 후속 발견에 대한 입력으로 사용합니다.

모든 것에 Hadoop 통합

처리 및 스토리지 환경으로서의 Hadoop은 기업에 많은 기회를 제공합니다. 그러나 채택을 촉진하려면 기존 도구와 함께 작동하고 확장해야합니다. Hadoop은 분석 플랫폼에 대한 입력으로 사용되거나 운영 데이터 저장소 및 웹 애플리케이션과 통합되어야합니다. 조직은 완전히 새로운 도구 세트를 배울 필요없이 Hadoop의 가치를 누려야합니다. REST 서비스는 친숙한 API 및 SQL과 유사한 언어로 엔터프라이즈에 플랫폼을 제공합니다. 엔터프라이즈 데이터 관리 시스템은 HCatalog를 사용하여 Hadoop 플랫폼과 더욱 긴밀하게 통합됩니다.

HCatalog 아키텍처

다음 그림은 HCatalog의 전체 아키텍처를 보여줍니다.

HCatalog는 모든 형식의 파일 읽기 및 쓰기를 지원합니다. SerDe(serializer-deserializer)를 쓸 수 있습니다. 기본적으로 HCatalog는 RCFile, CSV, JSON, SequenceFile 및 ORC 파일 형식을 지원합니다. 사용자 지정 형식을 사용하려면 InputFormat, OutputFormat 및 SerDe를 제공해야합니다.

HCatalog는 Hive 메타 스토어 위에 구축되며 Hive의 DDL을 통합합니다. HCatalog는 Pig 및 MapReduce에 대한 읽기 및 쓰기 인터페이스를 제공하고 Hive의 명령 줄 인터페이스를 사용하여 데이터 정의 및 메타 데이터 탐색 명령을 실행합니다.

Hive, Pig 및 HBase와 같은 모든 Hadoop 하위 프로젝트는 Linux 운영 체제를 지원합니다. 따라서 시스템에 Linux 특징을 설치해야합니다. HCatalog는 2013 년 3 월 26 일에 Hive 설치와 병합되었습니다. 버전 Hive-0.11.0부터 HCatalog는 Hive 설치와 함께 제공됩니다. 따라서 아래 단계에 따라 Hive를 설치하면 시스템에 HCatalog가 자동으로 설치됩니다.

1 단계 : JAVA 설치 확인

Hive를 설치하기 전에 시스템에 Java를 설치해야합니다. 다음 명령을 사용하여 시스템에 Java가 이미 설치되어 있는지 확인할 수 있습니다.

$ java –version

Java가 이미 시스템에 설치되어있는 경우 다음 응답이 표시됩니다.

java version "1.7.0_71"
Java(TM) SE Runtime Environment (build 1.7.0_71-b13)
Java HotSpot(TM) Client VM (build 25.0-b02, mixed mode)

시스템에 Java가 설치되어 있지 않은 경우 아래 단계를 따라야합니다.

2 단계 : Java 설치

다음 링크를 방문하여 Java (JDK <최신 버전>-X64.tar.gz)를 다운로드하십시오. http://www.oracle.com/

그때 jdk-7u71-linux-x64.tar.gz 시스템에 다운로드됩니다.

일반적으로 다운로드 폴더에서 다운로드 한 Java 파일을 찾을 수 있습니다. 그것을 확인하고 추출jdk-7u71-linux-x64.gz 다음 명령을 사용하여 파일.

$ cd Downloads/
$ ls jdk-7u71-linux-x64.gz $ tar zxf jdk-7u71-linux-x64.gz
$ ls
jdk1.7.0_71 jdk-7u71-linux-x64.gz

모든 사용자가 Java를 사용할 수 있도록하려면 "/ usr / local /"위치로 이동해야합니다. 루트를 열고 다음 명령을 입력하십시오.

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

설정 용 PATHJAVA_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 다운로드

다음 명령을 사용하여 Apache Software Foundation에서 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

Java를 사용하여 Hadoop 프로그램을 개발하려면 다음에서 Java 환경 변수를 재설정해야합니다. hadoop-env.sh 대체하여 파일 JAVA_HOME 시스템의 Java 위치와 함께 값.

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

다음은 Hadoop을 구성하기 위해 편집해야하는 파일 목록입니다.

core-site.xml

그만큼 core-site.xml 파일에는 Hadoop 인스턴스에 사용되는 포트 번호, 파일 시스템에 할당 된 메모리, 데이터 저장을위한 메모리 제한, 읽기 / 쓰기 버퍼 크기와 같은 정보가 포함됩니다.

core-site.xml을 열고 <configuration> 및 </ configuration> 태그 사이에 다음 속성을 추가합니다.

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

hdfs-site.xml

그만큼 hdfs-site.xml파일에는 복제 데이터 값, 이름 노드 경로 및 로컬 파일 시스템의 데이터 노드 경로와 같은 정보가 포함됩니다. Hadoop 인프라를 저장하려는 장소를 의미합니다.

다음 데이터를 가정 해 보겠습니다.

dfs.replication (data replication value) = 1

(In the following path /hadoop/ is the user name.
hadoopinfra/hdfs/namenode is the directory created by hdfs file system.)

namenode path = //home/hadoop/hadoopinfra/hdfs/namenode

(hadoopinfra/hdfs/datanode is the directory created by hdfs file system.)
datanode path = //home/hadoop/hadoopinfra/hdfs/datanode

이 파일을 열고이 파일의 <configuration>, </ configuration> 태그 사이에 다음 속성을 추가합니다.

<configuration>
   <property>
      <name>dfs.replication</name>
      <value>1</value>
   </property> 
   
   <property>
      <name>dfs.name.dir</name>
      <value>file:///home/hadoop/hadoopinfra/hdfs/namenode</value> 
   </property> 

   <property>
      <name>dfs.data.dir</name>
      <value>file:///home/hadoop/hadoopinfra/hdfs/datanode</value> 
   </property>
</configuration>

Note − 위 파일에서 모든 속성 값은 사용자 정의되며 Hadoop 인프라에 따라 변경할 수 있습니다.

yarn-site.xml

이 파일은 yarn을 Hadoop으로 구성하는 데 사용됩니다. yarn-site.xml 파일을 열고이 파일의 <configuration>, </ configuration> 태그 사이에 다음 특성을 추가하십시오.

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

mapred-site.xml

이 파일은 우리가 사용하는 MapReduce 프레임 워크를 지정하는 데 사용됩니다. 기본적으로 Hadoop에는 yarn-site.xml의 템플릿이 포함되어 있습니다. 우선, 파일을 복사해야합니다.mapred-site,xml.template ...에 mapred-site.xml 다음 명령을 사용하여 파일.

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

mapred-site.xml 파일을 열고이 파일의 <configuration>, </ configuration> 태그 사이에 다음 속성을 추가합니다.

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

6 단계 : Hadoop 설치 확인

다음 단계는 Hadoop 설치를 확인하는 데 사용됩니다.

네임 노드 설정

다음과 같이 "hdfs namenode -format"명령을 사용하여 namenode를 설정하십시오.

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

다음 명령은 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]

원사 스크립트 확인

다음 명령은 Yarn 스크립트를 시작하는 데 사용됩니다. 이 명령을 실행하면 Yarn 데몬이 시작됩니다.

$ 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입니다. 다음 URL을 사용하여 브라우저에서 Hadoop 서비스를 가져옵니다.

http://localhost:50070/

클러스터에 대한 모든 애플리케이션 확인

클러스터의 모든 애플리케이션에 액세스하기위한 기본 포트 번호는 8088입니다.이 서비스를 방문하려면 다음 URL을 사용하십시오.

http://localhost:8088/

Hadoop 설치가 완료되면 다음 단계로 진행하여 시스템에 Hive를 설치합니다.

7 단계 : Hive 다운로드

이 자습서에서는 hive-0.14.0을 사용합니다. 다음 링크를 방문하여 다운로드 할 수 있습니다.http://apache.petsads.us/hive/hive-0.14.0/. 이 파일이/Downloads예배 규칙서. 여기에서“apache-hive-0.14.0-bin.tar.gz”을 참조하십시오. 다음 명령은 다운로드를 확인하는 데 사용됩니다-

$ cd Downloads $ ls

성공적으로 다운로드하면 다음과 같은 응답이 표시됩니다.

apache-hive-0.14.0-bin.tar.gz

8 단계 : Hive 설치

시스템에 Hive를 설치하려면 다음 단계가 필요합니다. Hive 아카이브가/Downloads 예배 규칙서.

Hive 아카이브 추출 및 확인

다음 명령은 다운로드를 확인하고 Hive 아카이브를 추출하는 데 사용됩니다.

$ tar zxvf apache-hive-0.14.0-bin.tar.gz $ ls

성공적으로 다운로드하면 다음과 같은 응답이 표시됩니다.

apache-hive-0.14.0-bin apache-hive-0.14.0-bin.tar.gz

/ usr / local / hive 디렉토리에 파일 복사

수퍼 유저 "su-"의 파일을 복사해야합니다. 다음 명령을 사용하여 압축을 푼 디렉토리의 파일을/usr/local/hive”디렉토리.

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

Hive를위한 환경 설정

다음 줄을 추가하여 Hive 환경을 설정할 수 있습니다. ~/.bashrc 파일-

export HIVE_HOME=/usr/local/hive
export PATH=$PATH:$HIVE_HOME/bin export CLASSPATH=$CLASSPATH:/usr/local/Hadoop/lib/*:.
export CLASSPATH=$CLASSPATH:/usr/local/hive/lib/*:.

~ / .bashrc 파일을 실행하려면 다음 명령을 사용합니다.

$ source ~/.bashrc

9 단계 : Hive 구성

Hadoop으로 Hive를 구성하려면 다음을 편집해야합니다. hive-env.sh 파일은 $HIVE_HOME/conf예배 규칙서. 다음 명령은 Hive로 리디렉션됩니다.config 폴더 및 템플릿 파일 복사-

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

편집 hive-env.sh 다음 줄을 추가하여 파일-

export HADOOP_HOME=/usr/local/hadoop

이것으로 Hive 설치가 완료됩니다. 이제 Metastore를 구성하려면 외부 데이터베이스 서버가 필요합니다. Apache Derby 데이터베이스를 사용합니다.

10 단계 : Apache Derby 다운로드 및 설치

Apache Derby를 다운로드하고 설치하려면 아래 단계를 따르십시오.

Apache Derby 다운로드

다음 명령은 Apache Derby를 다운로드하는 데 사용됩니다. 다운로드하는 데 시간이 걸립니다.

$ cd ~ $ wget http://archive.apache.org/dist/db/derby/db-derby-10.4.2.0/db-derby-10.4.2.0-bin.tar.gz

다음 명령은 다운로드를 확인하는 데 사용됩니다-

$ ls

성공적으로 다운로드하면 다음과 같은 응답이 표시됩니다.

db-derby-10.4.2.0-bin.tar.gz

Derby 아카이브 추출 및 확인

다음 명령은 Derby 아카이브를 추출하고 확인하는 데 사용됩니다-

$ tar zxvf db-derby-10.4.2.0-bin.tar.gz
$ ls

성공적으로 다운로드하면 다음과 같은 응답이 표시됩니다.

db-derby-10.4.2.0-bin db-derby-10.4.2.0-bin.tar.gz

/ usr / local / derby 디렉토리에 파일 복사

수퍼 유저 "su-"에서 복사해야합니다. 다음 명령을 사용하여 압축을 푼 디렉토리의 파일을/usr/local/derby 디렉토리-

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

Derby를위한 환경 설정

다음 행을 추가하여 Derby 환경을 설정할 수 있습니다. ~/.bashrc 파일-

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

다음 명령을 사용하여 ~/.bashrc file

$ source ~/.bashrc

메타 스토어 용 디렉토리 생성

다음과 같은 디렉토리를 만듭니다. data $ DERBY_HOME 디렉토리에서 Metastore 데이터를 저장합니다.

$ mkdir $DERBY_HOME/data

이제 Derby 설치 및 환경 설정이 완료되었습니다.

11 단계 : Hive 메타 스토어 구성

메타 스토어 구성은 데이터베이스가 저장되는 Hive를 지정하는 것을 의미합니다. 이 작업은hive-site.xml 파일에 있습니다. $HIVE_HOME/conf예배 규칙서. 먼저 다음 명령을 사용하여 템플릿 파일을 복사하십시오.

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

편집하다 hive-site.xml 그리고 <configuration>과 </ configuration> 태그 사이에 다음 줄을 추가하십시오-

<property>
   <name>javax.jdo.option.ConnectionURL</name>
   <value>jdbc:derby://localhost:1527/metastore_db;create = true</value>
   <description>JDBC connect string for a JDBC metastore</description>
</property>

다음과 같은 파일을 만듭니다. jpox.properties 다음 줄을 추가하십시오-

javax.jdo.PersistenceManagerFactoryClass = org.jpox.PersistenceManagerFactoryImpl

org.jpox.autoCreateSchema = false
org.jpox.validateTables = false
org.jpox.validateColumns = false
org.jpox.validateConstraints = false

org.jpox.storeManagerType = rdbms
org.jpox.autoCreateSchema = true
org.jpox.autoStartMechanismMode = checked
org.jpox.transactionIsolation = read_committed

javax.jdo.option.DetachAllOnCommit = true
javax.jdo.option.NontransactionalRead = true
javax.jdo.option.ConnectionDriverName = org.apache.derby.jdbc.ClientDriver
javax.jdo.option.ConnectionURL = jdbc:derby://hadoop1:1527/metastore_db;create = true
javax.jdo.option.ConnectionUserName = APP
javax.jdo.option.ConnectionPassword = mine

12 단계 : Hive 설치 확인

Hive를 실행하기 전에 /tmp폴더 및 HDFS의 별도 Hive 폴더. 여기에서 우리는/user/hive/warehouse폴더. 아래와 같이 새로 생성 된 폴더에 대한 쓰기 권한을 설정해야합니다.

chmod g+w

이제 Hive를 확인하기 전에 HDFS에서 설정하십시오. 다음 명령을 사용하십시오-

$ $HADOOP_HOME/bin/hadoop fs -mkdir /tmp $ $HADOOP_HOME/bin/hadoop fs -mkdir /user/hive/warehouse $ $HADOOP_HOME/bin/hadoop fs -chmod g+w /tmp $ $HADOOP_HOME/bin/hadoop fs -chmod g+w /user/hive/warehouse

다음 명령은 Hive 설치를 확인하는 데 사용됩니다.

$ cd $HIVE_HOME $ bin/hive

Hive를 성공적으로 설치하면 다음 응답을 볼 수 있습니다.

Logging initialized using configuration in 
   jar:file:/home/hadoop/hive-0.9.0/lib/hive-common-0.9.0.jar!/
hive-log4j.properties Hive history
   =/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_HOME은 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는 다음 명령 줄 옵션을 지원합니다.

Sr. 아니요 선택권 예 및 설명
1 -지

hcat -g mygroup ...

생성 할 테이블에는 "mygroup"그룹이 있어야합니다.

2 -피

hcat -p rwxr-xr-x ...

생성 할 테이블에는 읽기, 쓰기 및 실행 권한이 있어야합니다.

-에프

hcat -f myscript.HCatalog ...

myscript.HCatalog는 실행할 DDL 명령이 포함 된 스크립트 파일입니다.

4 -이자형

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

다음 문자열을 DDL 명령으로 처리하고 실행하십시오.

5 -디

hcat -Dkey = value ...

키-값 쌍을 Java 시스템 특성으로 HCatalog에 전달합니다.

6 -

hcat

사용법 메시지를 인쇄합니다.

참고-

  • 그만큼 -g-p 옵션은 필수가 아닙니다.

  • 한 번에 -e 또는 -f 둘 다가 아닌 옵션을 제공 할 수 있습니다.

  • 옵션의 순서는 중요하지 않습니다. 순서에 상관없이 옵션을 지정할 수 있습니다.

Sr. 아니요 DDL 명령 및 설명
1

CREATE TABLE

HCatalog를 사용하여 테이블을 만듭니다. CLUSTERED BY 절을 사용하여 테이블을 생성하면 Pig 또는 MapReduce로 테이블에 쓸 수 없습니다.

2

ALTER TABLE

REBUILD 및 CONCATENATE 옵션을 제외하고 지원됩니다. 그 동작은 Hive에서와 동일하게 유지됩니다.

DROP TABLE

지원됩니다. Hive와 동일한 동작 (전체 테이블 및 구조 삭제).

4

CREATE/ALTER/DROP VIEW

지원됩니다. Hive와 동일한 동작.

Note − Pig와 MapReduce는 뷰에서 읽거나 쓸 수 없습니다.

5

SHOW TABLES

테이블 목록을 표시합니다.

6

SHOW PARTITIONS

파티션 목록을 표시합니다.

7

Create/Drop Index

CREATE 및 DROP FUNCTION 작업이 지원되지만 생성 된 함수는 여전히 Pig에 등록되고 MapReduce의 CLASSPATH에 배치되어야합니다.

8

DESCRIBE

지원됩니다. Hive와 동일한 동작. 구조를 설명하십시오.

위 표의 일부 명령은 다음 장에서 설명합니다.

이 장에서는 테이블을 만드는 방법과 테이블에 데이터를 삽입하는 방법에 대해 설명합니다. HCatalog에서 테이블을 만드는 규칙은 Hive를 사용하여 테이블을 만드는 것과 매우 유사합니다.

테이블 문 만들기

테이블 생성은 HCatalog를 사용하여 Hive 메타 스토어에서 테이블을 생성하는 데 사용되는 문입니다. 구문과 예는 다음과 같습니다.

통사론

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

Sr. 아니요 분야 명 데이터 형식
1 Eid int
2 이름
봉급 흙손
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에서 테이블을 생성 한 후 Insert 문을 사용하여 데이터를 삽입 할 수 있습니다. 그러나 HCatalog에서는 LOAD DATA 문을 사용하여 데이터를 삽입합니다.

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는 테이블의 데이터를 덮어 쓰는 옵션입니다.
  • PARTITION은 선택 사항입니다.

다음 데이터를 테이블에 삽입합니다. 다음과 같은 텍스트 파일입니다.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 문을 사용하여 Hive의 테이블을 변경할 수 있습니다.

통사론

이 명령문은 테이블에서 수정하려는 속성에 따라 다음 구문 중 하나를 사용합니다.

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 ...])

일부 시나리오는 아래에 설명되어 있습니다.

Rename To… 문

다음 쿼리는 다음에서 테이블 이름을 바꿉니다. employee ...에 emp.

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

변경 진술

다음 표에는 employee 변경 될 필드를 보여줍니다 (굵게 표시).

분야 명 데이터 유형에서 변환 필드 이름 변경 데이터 유형으로 변환
eid int eid int
이름 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');"

Replace 문

다음 쿼리는 employee 테이블로 교체하고 empname 열-

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

Drop Table 문

이 장에서는 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성명서. 보기는 단일 테이블, 여러 테이블 또는 다른보기에서 만들 수 있습니다.

보기를 만들려면 사용자에게 특정 구현에 따라 적절한 시스템 권한이 있어야합니다.

View 문 만들기

CREATE VIEW주어진 이름으로보기를 만듭니다. 같은 이름의 테이블이나 뷰가 이미 존재하면 오류가 발생합니다. 당신이 사용할 수있는IF NOT EXISTS 오류를 건너 뜁니다.

열 이름이 제공되지 않으면 뷰의 열 이름은 defining SELECT expression.

Note − SELECT에 x + y와 같이 별칭이 지정되지 않은 스칼라 표현식이 포함 된 경우 결과보기 열 이름은 _C0, _C1 등의 형식으로 생성됩니다.

열 이름을 바꿀 때 열 주석도 제공 할 수 있습니다. 주석은 기본 열에서 자동으로 상속되지 않습니다.

CREATE VIEW 문은보기가 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, 이름, 지정 및 급여 필드를 포함합니다.

+------+-------------+--------+-------------------+-------+
|  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 View 문

DROP VIEW는 지정된보기에 대한 메타 데이터를 제거합니다. 다른 뷰에서 참조하는 뷰를 삭제할 때 경고가 제공되지 않습니다 (종속 뷰는 유효하지 않은 상태로 유지되며 사용자가 삭제하거나 다시 만들어야 함).

통사론

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

파티션은 별도의 테이블이나 뷰를 만드는 데 사용되는 테이블 형식 데이터의 조건입니다. SHOW PARTITIONS는 주어진 기본 테이블에 대한 모든 기존 파티션을 나열합니다. 파티션은 알파벳 순서로 나열됩니다. Hive 0.6 이후에는 파티션 사양의 일부를 지정하여 결과 목록을 필터링 할 수도 있습니다.

SHOW PARTITIONS 명령을 사용하여 특정 테이블에있는 파티션을 볼 수 있습니다. 이 장에서는 HCatalog에서 특정 테이블의 파티션을 나열하는 방법에 대해 설명합니다.

Show Partitions 문

구문은 다음과 같습니다-

SHOW PARTITIONS table_name;

다음 쿼리는 employee

./hcat –e "Show partitions employee;"

쿼리가 성공적으로 실행되면 다음 응답을 볼 수 있습니다.

OK
Designation = IT
Time taken: 5.3 seconds

동적 파티션

HCatalog는 테이블을 파티션으로 구성합니다. 날짜, 도시, 부서 등 분할 된 열의 값을 기준으로 테이블을 관련 부분으로 나누는 방법입니다. 파티션을 사용하면 데이터의 일부를 쉽게 쿼리 할 수 ​​있습니다.

예를 들어, 이름이 Tab1ID, 이름, 부서 및 yoj (예 : 입사 연도)와 같은 직원 데이터가 포함됩니다. 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 / file2

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

/ tab1 / employeedata / 2013 / file3

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

파티션 추가

테이블을 변경하여 테이블에 파티션을 추가 할 수 있습니다. 다음과 같은 테이블이 있다고 가정하겠습니다.employee Id, Name, Salary, Designation, Dept 및 yoj와 같은 필드가 있습니다.

통사론

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, Designation 및 Dept 필드와 함께 이전에 사용한 테이블입니다. index_salarysalary 의 열 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를 사용하지 않고 병렬 입력 및 출력을위한 데이터 전송 API가 포함되어 있습니다. 이 API는 테이블과 행의 기본 저장소 추상화를 사용하여 Hadoop 클러스터에서 데이터를 읽고 여기에 데이터를 씁니다.

데이터 전송 API는 주로 세 가지 클래스를 포함합니다. 그것들은-

  • HCatReader − Hadoop 클러스터에서 데이터를 읽습니다.

  • HCatWriter − Hadoop 클러스터에 데이터를 씁니다.

  • DataTransferFactory − 리더 및 라이터 인스턴스를 생성합니다.

이 API는 마스터-슬레이브 노드 설정에 적합합니다. 에 대해 더 논의하겠습니다.HCatReaderHCatWriter.

HCatReader

HCatReader는 HCatalog 내부의 추상 클래스이며 레코드를 검색 할 기본 시스템의 복잡성을 추상화합니다.

S. 아니. 방법 이름 및 설명
1

Public abstract ReaderContext prepareRead() throws HCatException

이것은 마스터 노드에서 호출되어 ReaderContext를 얻은 다음 직렬화되고 슬레이브 노드로 전송되어야합니다.

2

Public abstract Iterator <HCatRecorder> read() throws HCaException

HCatRecord를 읽으려면 슬레이브 노드에서 호출해야합니다.

Public Configuration getConf()

구성 클래스 개체를 반환합니다.

HCatReader 클래스는 HDFS에서 데이터를 읽는 데 사용됩니다. 읽기는 첫 번째 단계가 외부 시스템의 마스터 노드에서 발생하는 2 단계 프로세스입니다. 두 번째 단계는 여러 슬레이브 노드에서 병렬로 수행됩니다.

읽기는 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를 얻는 것입니다.

ReaderContext cntxt = reader.prepareRead();

HCatWriter

이 추상화는 HCatalog 내부입니다. 이것은 외부 시스템에서 HCatalog에 쉽게 쓰기위한 것입니다. 이것을 직접 인스턴스화하지 마십시오. 대신 DataTransferFactory를 사용하십시오.

Sr. 아니. 방법 이름 및 설명
1

Public abstract WriterContext prepareRead() throws HCatException

외부 시스템은 마스터 노드에서 정확히 한 번이 메서드를 호출해야합니다. 그것은WriterContext. 이것은 직렬화되고 슬레이브 노드로 보내져HCatWriter 그곳에.

2

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

이 방법은 쓰기를 수행하기 위해 슬레이브 노드에서 사용되어야합니다. recordItr은 HCatalog에 기록 할 레코드 모음을 포함하는 반복기 개체입니다.

Public abstract void abort(WriterContext cntxt) throws HCatException

이 메서드는 마스터 노드에서 호출해야합니다. 이 방법의 주요 목적은 오류 발생시 정리를 수행하는 것입니다.

4

public abstract void commit(WriterContext cntxt) throws HCatException

이 메서드는 마스터 노드에서 호출해야합니다. 이 메서드의 목적은 메타 데이터 커밋을 수행하는 것입니다.

읽기와 마찬가지로 쓰기도 마스터 노드에서 첫 번째 단계가 발생하는 2 단계 프로세스입니다. 그 후 두 번째 단계는 슬레이브 노드에서 병렬로 발생합니다.

쓰기는 WriteEntity 읽기와 유사한 방식으로 구성 할 수 있습니다.

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

위 코드는 다음과 같은 entity테이블에 쓰는 데 사용할 수 있는 WriteEntity 객체 를 생성합니다.mytbl 데이터베이스에서 mydb.

WriteEntity를 생성 한 후 다음 단계는 WriterContext를 얻는 것입니다.

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

위의 모든 단계는 마스터 노드에서 발생합니다. 마스터 노드는 WriterContext 개체를 직렬화하여 모든 슬레이브에서 사용할 수 있도록합니다.

슬레이브 노드에서 다음과 같이 WriterContext를 사용하여 HCatWriter를 얻어야합니다.

HCatWriter writer = DataTransferFactory.getHCatWriter(context);

그런 다음 writerwrite메서드에 대한 인수로 반복자를 취합니다 -

writer.write(hCatRecordItr);

그만큼 writer 그런 다음 전화 getNext() 루프에서이 반복기에 대해 반복기에 연결된 모든 레코드를 기록합니다.

그만큼 TestReaderWriter.java파일은 HCatreader 및 HCatWriter 클래스를 테스트하는 데 사용됩니다. 다음 프로그램은 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

그만큼 HCatInputFormatHCatOutputFormat인터페이스는 HDFS에서 데이터를 읽고 처리 후 MapReduce 작업을 사용하여 결과 데이터를 HDFS에 쓰는 데 사용됩니다. 입력 및 출력 형식 인터페이스를 자세히 살펴 보겠습니다.

HCatInputFormat

그만큼 HCatInputFormatHCatalog 관리 테이블에서 데이터를 읽기 위해 MapReduce 작업과 함께 사용됩니다. HCatInputFormat은 데이터가 테이블에 게시 된 것처럼 읽기 위해 Hadoop 0.20 MapReduce API를 노출합니다.

Sr. 아니. 방법 이름 및 설명
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 작업에 대한 작업 구성으로 직렬화합니다.

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 포함하는 방법 projection schema, 출력 필드를 지정합니다. 스키마를 지정하지 않으면 테이블의 모든 열이 반환됩니다. getTableSchema 메소드를 사용하여 지정된 입력 테이블에 대한 테이블 스키마를 판별 할 수 있습니다.

HCatOutputFormat

HCatOutputFormat은 MapReduce 작업과 함께 사용되어 HCatalog 관리 테이블에 데이터를 기록합니다. HCatOutputFormat은 테이블에 데이터를 쓰기 위해 Hadoop 0.20 MapReduce API를 노출합니다. MapReduce 작업이 HCatOutputFormat을 사용하여 출력을 쓰는 경우 테이블에 대해 구성된 기본 OutputFormat이 사용되며 작업이 완료된 후 새 파티션이 테이블에 게시됩니다.

Sr. 아니. 방법 이름 및 설명
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

파티션에 기록되는 데이터의 스키마를 설정합니다. 테이블 스키마는 호출되지 않은 경우 파티션에 기본적으로 사용됩니다.

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

작업에 대한 기록 작가를 구하십시오. StorageHandler의 기본 OutputFormat을 사용하여 레코드 작성기를 가져옵니다.

4

public OutputCommitter getOutputCommitter (TaskAttemptContext context) throws IOException, InterruptedException

이 출력 형식에 대한 출력 커미터를 가져옵니다. 출력이 올바르게 커밋되었는지 확인합니다.

그만큼 HCatOutputFormat API는 다음과 같은 방법을 포함합니다-

  • 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이 응용 프로그램을 위해. 모든 Hive jar 및 HCatalog jar (HCatalog-core-0.5.0.jar, hive-metastore-0.10.0.jar, libthrift-0.7.0.jar, hive-exec-0.10.0.jar, 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)을 확인합니다.

그만큼 HCatLoaderHCatStorerAPI는 Pig 스크립트와 함께 HCatalog 관리 테이블에서 데이터를 읽고 쓰는 데 사용됩니다. 이러한 인터페이스에는 HCatalog 관련 설정이 필요하지 않습니다.

이 장을 더 잘 이해하려면 Apache Pig 스크립트에 대한 지식이있는 것이 좋습니다. 자세한 내용은 Apache Pig 자습서 를 참조하십시오 .

HCatloader

HCatLoader는 Pig 스크립트와 함께 HCatalog 관리 테이블에서 데이터를 읽는 데 사용됩니다. HCatloader를 사용하여 데이터를 HDFS로로드하려면 다음 구문을 사용하십시오.

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

테이블 이름은 작은 따옴표로 지정해야합니다. LOAD 'tablename'. 기본이 아닌 데이터베이스를 사용하는 경우 입력을 'dbname.tablename'.

Hive 메타 스토어를 사용하면 데이터베이스를 지정하지 않고도 테이블을 만들 수 있습니다. 이 방법으로 테이블을 생성 한 경우 데이터베이스 이름은'default' HCatLoader에 대한 테이블을 지정할 때 필요하지 않습니다.

다음 표에는 HCatloader 클래스의 중요한 메서드와 설명이 포함되어 있습니다.

Sr. 아니. 방법 이름 및 설명
1

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

HCatloader 클래스를 사용하여 로딩 데이터의 입력 형식을 읽습니다.

2

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

문자열 형식을 반환합니다. Absolute path.

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

작업을 실행할 수있는 위치를 설정합니다.

4

public Tuple getNext() throws IOException

현재 튜플 (keyvalue) 루프에서.

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'. Pig 스크립트를 실행하기 전에 데이터베이스와 테이블을 모두 만들어야합니다. 기본이 아닌 데이터베이스를 사용하는 경우 입력을 다음과 같이 지정해야합니다.'dbname.tablename'.

Hive 메타 스토어를 사용하면 데이터베이스를 지정하지 않고도 테이블을 만들 수 있습니다. 이 방법으로 테이블을 생성 한 경우 데이터베이스 이름은'default' 데이터베이스 이름을 지정할 필요가 없습니다. store 성명서.

에 대한 USING절에서 파티션의 키 / 값 쌍을 나타내는 문자열 인수를 가질 수 있습니다. 파티션을 나눈 테이블에 쓸 때 파티션 열이 출력 열에없는 경우 필수 인수입니다. 파티션 키 값은 따옴표로 묶어서는 안됩니다.

다음 표에는 HCatStorer 클래스의 중요한 메서드와 설명이 포함되어 있습니다.

Sr. 아니. 방법 이름 및 설명
1

public OutputFormat getOutputFormat() throws IOException

HCatStorer 클래스를 사용하여 저장된 데이터의 출력 형식을 읽습니다.

2

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

이것을 실행할 위치를 설정합니다 store 신청.

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로 Pig 실행

Pig는 HCatalog jar를 자동으로 선택하지 않습니다. 필요한 jar를 가져 오려면 Pig 명령에서 플래그를 사용하거나 환경 변수를 설정할 수 있습니다.PIG_CLASSPATHPIG_OPTS 아래에 설명 된대로.

HCatalog 작업을 위해 적절한 항아리를 가져 오려면 다음 플래그를 포함하십시오.

pig –useHCatalog <Sample pig scripts file>

실행을위한 CLASSPATH 설정

HCatalog를 Apache Pig와 동기화하려면 다음 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 다음 내용으로 HDFS에서.

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.

  • 스크립트의 두 번째 문은 관계의 튜플을 연령에 따라 내림차순으로 정렬하고 다음과 같이 저장합니다. student_order.

  • 세 번째 문은 처리 된 데이터를 저장합니다. student_order 다음과 같은 별도의 테이블이 생성됩니다. student_order_table.

  • 스크립트의 네 번째 문은 처음 4 개의 튜플을 저장합니다. 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)을 확인합니다.