-
Notifications
You must be signed in to change notification settings - Fork 90
/
docker-entrypoint.sh
53 lines (49 loc) · 2.2 KB
/
docker-entrypoint.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
#!/bin/bash
# Copyright 2023 Google LLC
#
# 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.
#######################################
# Enables jemalloc as the default memory allocator if it's available, otherwise the default glibc
# allocator is used. jemalloc is added to avoid the memory leak created by the glibc allocator.
#
# This is inspired from the flink-docker repo -
# https://github.com/apache/flink-docker/blob/45c6d230407d89aa83b0d170dd056d6868cf808e/1.17/scala_2.12-java11-ubuntu/docker-entrypoint.sh#L92
#
# Refer to https://github.com/google/fhir-data-pipes/issues/777 for more details.
#######################################
enable_jemalloc() {
# Supports multiple processor architectures like x86_64, arm64 etc.
JEMALLOC_PATH="/usr/lib/$(uname -m)-linux-gnu/libjemalloc.so"
JEMALLOC_FALLBACK="/usr/lib/x86_64-linux-gnu/libjemalloc.so"
if [ -f "$JEMALLOC_PATH" ]; then
export LD_PRELOAD=$LD_PRELOAD:$JEMALLOC_PATH
elif [ -f "$JEMALLOC_FALLBACK" ]; then
export LD_PRELOAD=$LD_PRELOAD:$JEMALLOC_FALLBACK
else
if [ "$JEMALLOC_PATH" = "$JEMALLOC_FALLBACK" ]; then
MSG_PATH=$JEMALLOC_PATH
else
MSG_PATH="$JEMALLOC_PATH and $JEMALLOC_FALLBACK"
fi
echo "WARNING: attempted to load jemalloc from $MSG_PATH but the library couldn't be found. glibc will be used instead."
fi
}
enable_jemalloc
if [[ -z "$JAVA_OPTS" ]]; then
echo "JAVA_OPTS is empty, initialising with default values"
JAVA_OPTS="-Xms6g -Xmx6g"
fi
# The -Xmx value is to make sure there is a minimum amount of memory; it can be
# increased if more memory is available and is desired to be used by pipelines.
# Note this is related to the memory config in flink-conf.yaml too.
java $JAVA_OPTS -jar /app/controller-bundled.jar