#!/bin/bash set -e -o pipefail TERMINATE_TIMEOUT=9 readonly LOGS_DIR="/home/vcap/logs" function check_params { if [ -z "${NOTIFY_APP_NAME}" ]; then echo "You must set NOTIFY_APP_NAME" exit 1 fi if [ -z "${CW_APP_NAME}" ]; then CW_APP_NAME=${NOTIFY_APP_NAME} fi } function configure_aws_logs { # create files so that aws logs agent doesn't complain touch ${LOGS_DIR}/gunicorn_error.log touch ${LOGS_DIR}/app.log.json aws configure set plugins.cwlogs cwlogs cat > /home/vcap/app/awslogs.conf << EOF [general] state_file = ${LOGS_DIR}/awslogs-state [${LOGS_DIR}/app.log] file = ${LOGS_DIR}/app.log.json log_group_name = paas-${CW_APP_NAME}-application log_stream_name = {hostname} [${LOGS_DIR}/gunicorn_error.log] file = ${LOGS_DIR}/gunicorn_error.log log_group_name = paas-${CW_APP_NAME}-gunicorn log_stream_name = {hostname} EOF } function on_exit { echo "Terminating application process with pid ${APP_PID}" kill ${APP_PID} || true wait_time=0 while (kill -0 ${APP_PID} 2&>/dev/null); do echo "Application is still running.." sleep 1 let wait_time=wait_time+1 if [ "$wait_time" -ge "$TERMINATE_TIMEOUT" ]; then echo "Timeout reached, killing process with pid ${APP_PID}" kill -9 ${APP_PID} || true break fi done echo "Terminating remaining subprocesses.." kill 0 } function start_application { exec "$@" & APP_PID=`jobs -p` echo "Application process pid: ${APP_PID}" } function start_aws_logs_agent { exec aws logs push --region eu-west-1 --config-file /home/vcap/app/awslogs.conf & AWSLOGS_AGENT_PID=$! echo "AWS logs agent pid: ${AWSLOGS_AGENT_PID}" } function run { while true; do kill -0 ${APP_PID} 2&>/dev/null || break kill -0 ${AWSLOGS_AGENT_PID} 2&>/dev/null || start_aws_logs_agent sleep 1 done } echo "Run script pid: $$" check_params trap "on_exit" EXIT configure_aws_logs # The application has to start first! start_application "$@" start_aws_logs_agent run