Add additional logging statements
[aai/schema-service.git] / aai-schema-service / src / main / docker / docker-entrypoint.sh
1 ###
2 # ============LICENSE_START=======================================================
3 # org.onap.aai
4 # ================================================================================
5 # Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6 # ================================================================================
7 # Licensed under the Apache License, Version 2.0 (the "License");
8 # you may not use this file except in compliance with the License.
9 # You may obtain a copy of the License at
10 #
11 #      http://www.apache.org/licenses/LICENSE-2.0
12 #
13 # Unless required by applicable law or agreed to in writing, software
14 # distributed under the License is distributed on an "AS IS" BASIS,
15 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 # See the License for the specific language governing permissions and
17 # limitations under the License.
18 # ============LICENSE_END=========================================================
19 ###
20
21 APP_HOME=$(pwd);
22 RESOURCES_HOME=${APP_HOME}/resources/;
23
24 export SERVER_PORT=${SERVER_PORT:-8452};
25
26 USER_ID=${LOCAL_USER_ID:-9001}
27 GROUP_ID=${LOCAL_GROUP_ID:-9001}
28
29 if [ $(cat /etc/passwd | grep aaiadmin | wc -l) -eq 0 ]; then
30
31         groupadd aaiadmin -g ${GROUP_ID} || {
32                 echo "Unable to create the group id for ${GROUP_ID}";
33                 exit 1;
34         }
35         useradd --shell=/bin/bash -u ${USER_ID} -g ${GROUP_ID} -o -c "" -m aaiadmin || {
36                 echo "Unable to create the user id for ${USER_ID}";
37                 exit 1;
38         }
39 fi;
40
41 chown -R aaiadmin:aaiadmin /opt/app /opt/aai/logroot
42 find /opt/app/ -name "*.sh" -exec chmod +x {} +
43
44 if [ -f ${APP_HOME}/aai.sh ]; then
45
46     gosu aaiadmin ln -s bin scripts
47     gosu aaiadmin ln -s /opt/aai/logroot/AAI-SS logs
48
49     mv ${APP_HOME}/aai.sh /etc/profile.d/aai.sh
50     chmod 755 /etc/profile.d/aai.sh
51
52     scriptName=$1;
53
54     if [ ! -z $scriptName ]; then
55
56         if [ -f ${APP_HOME}/bin/${scriptName} ]; then
57             shift 1;
58             gosu aaiadmin ${APP_HOME}/bin/${scriptName} "$@" || {
59                 echo "Failed to run the ${scriptName}";
60                 exit 1;
61             }
62         else
63             echo "Unable to find the script ${scriptName} in ${APP_HOME}/bin";
64             exit 1;
65         fi;
66
67         exit 0;
68     fi;
69
70     if [ ! -f "${APP_HOME}/scripts/updatePem.sh" ]; then
71         echo "Unable to find the updatePem script";
72         exit 1;
73     else
74         gosu aaiadmin ${APP_HOME}/scripts/updatePem.sh
75     fi;
76 fi;
77
78 mkdir -p /opt/app/aai-schema-service/logs/gc
79 chown -R aaiadmin:aaiadmin /opt/app/aai-schema-service/logs/gc
80
81 if [ -f ${APP_HOME}/resources/aai-schema-service-swm-vars.sh ]; then
82     source ${APP_HOME}/resources/aai-schema-service-swm-vars.sh;
83 fi;
84
85 if [ ! -z "${HEAP_SIZE}" ]; then
86     MIN_HEAP_SIZE=${HEAP_SIZE};
87     MAX_HEAP_SIZE=${HEAP_SIZE};
88 fi;
89
90 MIN_HEAP_SIZE=${MIN_HEAP_SIZE:-512m};
91 MAX_HEAP_SIZE=${MAX_HEAP_SIZE:-1024m};
92 MAX_METASPACE_SIZE=${MAX_METASPACE_SIZE:-512m};
93
94 JAVA_CMD="exec gosu aaiadmin java";
95
96 JVM_OPTS="${PRE_JVM_ARGS} -Xloggc:/opt/app/aai-schema-service/logs/gc/aai_gc.log";
97 JVM_OPTS="${JVM_OPTS} -XX:HeapDumpPath=/opt/app/aai-schema-service/logs/ajsc-jetty/heap-dump";
98 JVM_OPTS="${JVM_OPTS} -Xms${MIN_HEAP_SIZE}";
99 JVM_OPTS="${JVM_OPTS} -Xmx${MAX_HEAP_SIZE}";
100
101 JVM_OPTS="${JVM_OPTS} -XX:+PrintGCDetails";
102 JVM_OPTS="${JVM_OPTS} -XX:+PrintGCTimeStamps";
103 JVM_OPTS="${JVM_OPTS} -XX:MaxMetaspaceSize=${MAX_METASPACE_SIZE}";
104
105 JVM_OPTS="${JVM_OPTS} -server";
106 JVM_OPTS="${JVM_OPTS} -XX:NewSize=512m";
107 JVM_OPTS="${JVM_OPTS} -XX:MaxNewSize=512m";
108 JVM_OPTS="${JVM_OPTS} -XX:SurvivorRatio=8";
109 JVM_OPTS="${JVM_OPTS} -XX:+DisableExplicitGC";
110 JVM_OPTS="${JVM_OPTS} -verbose:gc";
111 JVM_OPTS="${JVM_OPTS} -XX:+UseParNewGC";
112 JVM_OPTS="${JVM_OPTS} -XX:+CMSParallelRemarkEnabled";
113 JVM_OPTS="${JVM_OPTS} -XX:+CMSClassUnloadingEnabled";
114 JVM_OPTS="${JVM_OPTS} -XX:+UseConcMarkSweepGC";
115 JVM_OPTS="${JVM_OPTS} -XX:-UseBiasedLocking";
116 JVM_OPTS="${JVM_OPTS} -XX:ParallelGCThreads=4";
117 JVM_OPTS="${JVM_OPTS} -XX:LargePageSizeInBytes=128m";
118 JVM_OPTS="${JVM_OPTS} -XX:+PrintGCDetails";
119 JVM_OPTS="${JVM_OPTS} -XX:+PrintGCTimeStamps";
120 JVM_OPTS="${JVM_OPTS} -Dsun.net.inetaddr.ttl=180";
121 JVM_OPTS="${JVM_OPTS} -XX:+HeapDumpOnOutOfMemoryError";
122 JVM_OPTS="${JVM_OPTS} ${POST_JVM_ARGS}";
123 JAVA_OPTS="${PRE_JAVA_OPTS} -DAJSC_HOME=$APP_HOME";
124 if [ -f ${INTROSCOPE_LIB}/Agent.jar ] && [ -f ${INTROSCOPE_AGENTPROFILE} ]; then
125         JAVA_OPTS="${JAVA_OPTS} -javaagent:${INTROSCOPE_LIB}/Agent.jar -noverify -Dcom.wily.introscope.agentProfile=${INTROSCOPE_AGENTPROFILE} -Dintroscope.agent.agentName=schema-service"
126 fi
127 JAVA_OPTS="${JAVA_OPTS} -Dserver.port=${SERVER_PORT}";
128 JAVA_OPTS="${JAVA_OPTS} -DBUNDLECONFIG_DIR=./resources";
129 JAVA_OPTS="${JAVA_OPTS} -Dserver.local.startpath=${RESOURCES_HOME}";
130 JAVA_OPTS="${JAVA_OPTS} -DAAI_CHEF_ENV=${AAI_CHEF_ENV}";
131 JAVA_OPTS="${JAVA_OPTS} -DSCLD_ENV=${SCLD_ENV}";
132 JAVA_OPTS="${JAVA_OPTS} -DAFT_ENVIRONMENT=${AFT_ENVIRONMENT}";
133 JAVA_OPTS="${JAVA_OPTS} -DlrmName=com.att.ajsc.aai-schema-service";
134 JAVA_OPTS="${JAVA_OPTS} -DAAI_BUILD_VERSION=${AAI_BUILD_VERSION}";
135 JAVA_OPTS="${JAVA_OPTS} -Djava.security.egd=file:/dev/./urandom";
136 JAVA_OPTS="${JAVA_OPTS} -Dlogback.configurationFile=./resources/logback.xml";
137 JAVA_OPTS="${JAVA_OPTS} -Dloader.path=$APP_HOME/resources";
138 JAVA_OPTS="${JAVA_OPTS} -Dgroovy.use.classvalue=true";
139 JAVA_OPTS="${JAVA_OPTS} ${POST_JAVA_OPTS}";
140
141 JAVA_MAIN_JAR=$(ls lib/aai-schema-service*.jar);
142
143 ${JAVA_CMD} ${JVM_OPTS} ${JAVA_OPTS} -jar ${JAVA_MAIN_JAR};