mirror of
https://github.com/apple/foundationdb.git
synced 2025-06-02 19:25:52 +08:00
- make release images ALL based from centos:7 - keep eks images that are based from amazonlinux:2, but create strong alignment with release (centos7) images - use multi-stage Dockerfile(s) - have a single build-images script - remove per image directories (which would only contain scripts that are copied into images) - remove empty requirements.txt file for sidecar.py (the pip command, package and version are in the Dockerfile) - don't copy docker into PROJECT_BINARY_DIR - incorporate latest changes already in master
69 lines
2.4 KiB
Bash
Executable File
69 lines
2.4 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
#
|
|
# fdb.bash
|
|
#
|
|
# This source file is part of the FoundationDB open source project
|
|
#
|
|
# Copyright 2013-2021 Apple Inc. and the FoundationDB project authors
|
|
#
|
|
# 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.
|
|
#
|
|
|
|
function create_cluster_file() {
|
|
FDB_CLUSTER_FILE=${FDB_CLUSTER_FILE:-/etc/foundationdb/fdb.cluster}
|
|
mkdir -p "$(dirname $FDB_CLUSTER_FILE)"
|
|
|
|
if [[ -n "$FDB_CLUSTER_FILE_CONTENTS" ]]; then
|
|
echo "$FDB_CLUSTER_FILE_CONTENTS" > "$FDB_CLUSTER_FILE"
|
|
elif [[ -n $FDB_COORDINATOR ]]; then
|
|
coordinator_ip=$(dig +short "$FDB_COORDINATOR")
|
|
if [[ -z "$coordinator_ip" ]]; then
|
|
echo "Failed to look up coordinator address for $FDB_COORDINATOR" 1>&2
|
|
exit 1
|
|
fi
|
|
coordinator_port=${FDB_COORDINATOR_PORT:-4500}
|
|
echo "docker:docker@$coordinator_ip:$coordinator_port" > "$FDB_CLUSTER_FILE"
|
|
else
|
|
echo "FDB_COORDINATOR environment variable not defined" 1>&2
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
function create_server_environment() {
|
|
env_file=/var/fdb/.fdbenv
|
|
|
|
if [[ "$FDB_NETWORKING_MODE" == "host" ]]; then
|
|
public_ip=127.0.0.1
|
|
elif [[ "$FDB_NETWORKING_MODE" == "container" ]]; then
|
|
public_ip=$(hostname -i | awk '{print $1}')
|
|
else
|
|
echo "Unknown FDB Networking mode \"$FDB_NETWORKING_MODE\"" 1>&2
|
|
exit 1
|
|
fi
|
|
|
|
echo "export PUBLIC_IP=$public_ip" > $env_file
|
|
if [[ -z $FDB_COORDINATOR && -z "$FDB_CLUSTER_FILE_CONTENTS" ]]; then
|
|
FDB_CLUSTER_FILE_CONTENTS="docker:docker@$public_ip:$FDB_PORT"
|
|
fi
|
|
|
|
create_cluster_file
|
|
}
|
|
|
|
create_server_environment
|
|
source /var/fdb/.fdbenv
|
|
echo "Starting FDB server on $PUBLIC_IP:$FDB_PORT"
|
|
fdbserver --listen_address 0.0.0.0:"$FDB_PORT" --public_address "$PUBLIC_IP:$FDB_PORT" \
|
|
--datadir /var/fdb/data --logdir /var/fdb/logs \
|
|
--locality_zoneid="$(hostname)" --locality_machineid="$(hostname)" --class "$FDB_PROCESS_CLASS"
|