import-hive.sh 4 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
#!/bin/bash
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#   http://www.apache.org/licenses/LICENSE-2.0
#
#  Unless required by applicable law or agreed to in writing, software
#  distributed under the License is distributed on an "AS IS" BASIS,
#  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
#  See the License for the specific language governing permissions and
#  limitations under the License. See accompanying LICENSE file.
#
# resolve links - $0 may be a softlink
PRG="${0}"

18 19
[[ `uname -s` == *"CYGWIN"* ]] && CYGWIN=true

20 21 22 23 24 25 26 27 28 29 30 31 32
while [ -h "${PRG}" ]; do
  ls=`ls -ld "${PRG}"`
  link=`expr "$ls" : '.*-> \(.*\)$'`
  if expr "$link" : '/.*' > /dev/null; then
    PRG="$link"
  else
    PRG=`dirname "${PRG}"`/"$link"
  fi
done

BASEDIR=`dirname ${PRG}`
BASEDIR=`cd ${BASEDIR}/..;pwd`

33
if test -z "${JAVA_HOME}"
34 35 36 37
then
    JAVA_BIN=`which java`
    JAR_BIN=`which jar`
else
38 39
    JAVA_BIN="${JAVA_HOME}/bin/java"
    JAR_BIN="${JAVA_HOME}/bin/jar"
40 41 42
fi
export JAVA_BIN

43
if [ ! -e "${JAVA_BIN}" ] || [ ! -e "${JAR_BIN}" ]; then
44 45 46 47
  echo "$JAVA_BIN and/or $JAR_BIN not found on the system. Please make sure java and jar commands are available."
  exit 1
fi

48 49
# Construct Atlas classpath using jars from hook/hive/atlas-hive-plugin-impl/ directory.
for i in "${BASEDIR}/hook/hive/atlas-hive-plugin-impl/"*.jar; do
50
  ATLASCPPATH="${ATLASCPPATH}:$i"
51 52
done

53
# log dir for applications
54 55 56
ATLAS_LOG_DIR="${ATLAS_LOG_DIR:-$BASEDIR/logs}"
export ATLAS_LOG_DIR
LOGFILE="$ATLAS_LOG_DIR/import-hive.log"
57 58 59

TIME=`date +%Y%m%d%H%M%s`

60
#Add hive conf in classpath
61
if [ ! -z "$HIVE_CONF_DIR" ]; then
62
    HIVE_CONF=$HIVE_CONF_DIR
63
elif [ ! -z "$HIVE_HOME" ]; then
64
    HIVE_CONF="$HIVE_HOME/conf"
65
elif [ -e /etc/hive/conf ]; then
66
    HIVE_CONF="/etc/hive/conf"
67 68 69 70 71
else
    echo "Could not find a valid HIVE configuration"
    exit 1
fi

72 73 74 75 76 77
echo Using Hive configuration directory ["$HIVE_CONF"]


if [ -f "${HIVE_CONF}/hive-env.sh" ]; then
  . "${HIVE_CONF}/hive-env.sh"
fi
78 79

if [ -z "$HIVE_HOME" ]; then
80 81 82 83 84 85
    if [ -d "${BASEDIR}/../hive" ]; then
        HIVE_HOME=${BASEDIR}/../hive
    else
        echo "Please set HIVE_HOME to the root of Hive installation"
        exit 1
    fi
86 87
fi

88 89
HIVE_CP="${HIVE_CONF}"

90 91 92 93
for i in "${HIVE_HOME}/lib/"*.jar; do
    HIVE_CP="${HIVE_CP}:$i"
done

94 95 96 97 98
#Add hadoop conf in classpath
if [ ! -z "$HADOOP_CLASSPATH" ]; then
    HADOOP_CP=$HADOOP_CLASSPATH
elif [ ! -z "$HADOOP_HOME" ]; then
    HADOOP_CP=`$HADOOP_HOME/bin/hadoop classpath`
99 100 101
elif [ $(command -v hadoop) ]; then
    HADOOP_CP=`hadoop classpath`
    echo $HADOOP_CP
102 103 104 105 106 107
else
    echo "Environment variable HADOOP_CLASSPATH or HADOOP_HOME need to be set"
    exit 1
fi

CP="${ATLASCPPATH}:${HIVE_CP}:${HADOOP_CP}"
108 109 110 111

# If running in cygwin, convert pathnames and classpath to Windows format.
if [ "${CYGWIN}" == "true" ]
then
112
   ATLAS_LOG_DIR=`cygpath -w ${ATLAS_LOG_DIR}`
113 114
   LOGFILE=`cygpath -w ${LOGFILE}`
   HIVE_CP=`cygpath -w ${HIVE_CP}`
115
   HADOOP_CP=`cygpath -w ${HADOOP_CP}`
116 117 118
   CP=`cygpath -w -p ${CP}`
fi

119
JAVA_PROPERTIES="$ATLAS_OPTS -Datlas.log.dir=$ATLAS_LOG_DIR -Datlas.log.file=import-hive.log
120
-Dlog4j.configuration=atlas-hive-import-log4j.xml"
121

122 123 124 125 126 127
IMPORT_ARGS=
JVM_ARGS=

while true
do
  option=$1
128
  shift
129 130 131 132 133 134 135 136 137 138 139

  case "$option" in
    -d) IMPORT_ARGS="$IMPORT_ARGS -d $1"; shift;;
    -t) IMPORT_ARGS="$IMPORT_ARGS -t $1"; shift;;
    -f) IMPORT_ARGS="$IMPORT_ARGS -f $1"; shift;;
    --database) IMPORT_ARGS="$IMPORT_ARGS --database $1"; shift;;
    --table) IMPORT_ARGS="$IMPORT_ARGS --table $1"; shift;;
    --filename) IMPORT_ARGS="$IMPORT_ARGS --filename $1"; shift;;
    "") break;;
    *) JVM_ARGS="$JVM_ARGS $option"
  esac
140 141
done

142 143
JAVA_PROPERTIES="${JAVA_PROPERTIES} ${JVM_ARGS}"

144 145
echo "Log file for import is $LOGFILE"

146
"${JAVA_BIN}" ${JAVA_PROPERTIES} -cp "${CP}" org.apache.atlas.hive.bridge.HiveMetaStoreBridge $IMPORT_ARGS
147 148

RETVAL=$?
149 150
[ $RETVAL -eq 0 ] && echo Hive Meta Data imported successfully!!!
[ $RETVAL -ne 0 ] && echo Failed to import Hive Meta Data!!!
151 152 153

exit $RETVAL