mirror of
https://github.com/apache/impala.git
synced 2026-02-03 09:00:39 -05:00
The shutdown script should not abort if it can't write a log - it should continue to try and shut down impala. The entrypoint script should abort with an explicit error if the log directory isn't writable by the current user. Change-Id: If32d6eef75422b51f8877478bbfb1a709c02f756 Reviewed-on: http://gerrit.cloudera.org:8080/16237 Tested-by: Impala Public Jenkins <impala-public-jenkins@cloudera.com> Reviewed-by: Attila Jeges <attilaj@cloudera.com> Reviewed-by: Andrew Sherman <asherman@cloudera.com>
70 lines
2.5 KiB
Bash
Executable File
70 lines
2.5 KiB
Bash
Executable File
#!/bin/bash
|
|
# Licensed to the Apache Software Foundation (ASF) under one
|
|
# or more contributor license agreements. See the NOTICE file
|
|
# distributed with this work for additional information
|
|
# regarding copyright ownership. The ASF licenses this file
|
|
# to you 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.
|
|
|
|
# Wrapper script that runs the command-line provided as its arguments after
|
|
# setting up the environment required for the daemon processes to run.
|
|
#
|
|
# Supported environment variables:
|
|
# JAVA_TOOL_OPTIONS: additional options passed to any embedded JVMs. Can be used, e.g.
|
|
# to set a max heap size with JAVA_TOOL_OPTIONS="-Xmx4g".
|
|
|
|
export IMPALA_HOME=/opt/impala
|
|
|
|
# Add directories containing dynamic libraries required by the daemons that
|
|
# are not on the system library paths.
|
|
export LD_LIBRARY_PATH=/opt/impala/lib
|
|
LD_LIBRARY_PATH+=:/usr/lib/jvm/java-8-openjdk-amd64/jre/lib/amd64/
|
|
LD_LIBRARY_PATH+=:/usr/lib/jvm/java-8-openjdk-amd64/jre/lib/amd64/server/
|
|
|
|
# Add directory with optional plugins that can be mounted for the container.
|
|
LD_LIBRARY_PATH+=:/opt/impala/lib/plugins
|
|
|
|
# Configs should be first on classpath
|
|
export CLASSPATH=/opt/impala/conf
|
|
# Append all of the jars in /opt/impala/lib to the classpath.
|
|
for jar in /opt/impala/lib/*.jar
|
|
do
|
|
CLASSPATH+=:$jar
|
|
done
|
|
echo "CLASSPATH: $CLASSPATH"
|
|
echo "LD_LIBRARY_PATH: $LD_LIBRARY_PATH"
|
|
|
|
# Default to 2GB heap. Allow overriding by externally-set JAVA_TOOL_OPTIONS.
|
|
export JAVA_TOOL_OPTIONS="-Xmx2g $JAVA_TOOL_OPTIONS"
|
|
|
|
# Various Hadoop libraries depend on having a username. If we're running under
|
|
# an unknown username, create an entry in the password file for this user.
|
|
if ! whoami ; then
|
|
export USER=${HADOOP_USER_NAME:-dummyuser}
|
|
echo "${USER}:x:$(id -u):$(id -g):,,,:/opt/impala:/bin/bash" >> /etc/passwd
|
|
whoami
|
|
cat /etc/passwd
|
|
fi
|
|
|
|
# IMPALA-10006: avoid cryptic failures if log dir isn't writable.
|
|
LOG_DIR=$IMPALA_HOME/logs
|
|
if [[ ! -w "$LOG_DIR" ]]; then
|
|
echo "$LOG_DIR is not writable"
|
|
exit 1
|
|
fi
|
|
|
|
# Set ulimit core file size 0.
|
|
ulimit -c 0
|
|
|
|
exec "$@"
|