hetu-core/docker/bin/shutdown-hetu

58 lines
1.6 KiB
Bash
Executable File

#!/bin/bash
# Copyright (C) 2020. Huawei Technologies Co., Ltd. All rights reserved.
# 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.
# check validity of user
if [ "$(id -un)" != "openlkadmin" ]
then
echo "unexpected user"
exit 1
fi
echo "shutting down hetu process"
# Read Hetu port number from config file. Default to 8080.
HETU_PORT=
CONFIG_FILE='/usr/lib/hetu/etc/config.properties'
if [ -f $CONFIG_FILE ]
then
HETU_PORT="$(grep "http-server.http.port" $CONFIG_FILE | cut -d "=" -f2)"
fi
if [ -z "${HETU_PORT}" ]
then
HETU_PORT=8080
elif [[ ! "${HETU_PORT}" =~ ^[0-9]+$ ]]
then
echo "unexpected value: port"
exit 1
fi
# Send shutdown request
curl -X PUT -H "X-Presto-User: openlk" -H "Content-Type: application/json" http://localhost:$HETU_PORT/v1/info/state -d '"SHUTTING_DOWN"'
# Wait for node to exit
while true
do
# Query current node state every second
sleep 1
state="$(curl --silent http://localhost:$HETU_PORT/v1/info/state)"
# Exit if state is no longer "SHUTTING_DOWN"
if [[ -z "${state}" || "${state}" != '"SHUTTING_DOWN"' ]]
then
break
fi
done
exit 0