3 changed files with 100 additions and 1 deletions
@ -0,0 +1,19 @@
|
||||
# Dockerfile for ZeroTier Central Controllers |
||||
FROM centos:7 |
||||
MAINTAINER Adam Ierymekno <adam.ierymenko@zerotier.com>, Grant Limberg <grant.limberg@zerotier.com> |
||||
|
||||
RUN yum update -y |
||||
RUN yum install -y https://download.postgresql.org/pub/repos/yum/10/redhat/rhel-7-x86_64/pgdg-centos10-10-2.noarch.rpm |
||||
RUN yum install -y bash postgresql10 libpqxx-devel |
||||
|
||||
RUN yum -y install epel-release && yum -y update && yum clean all |
||||
RUN yum -y install clang jemalloc jemalloc-devel |
||||
|
||||
|
||||
ADD zerotier-one /usr/local/bin/zerotier-one |
||||
RUN chmod a+x /usr/local/bin/zerotier-one |
||||
|
||||
ADD docker/main.sh / |
||||
RUN chmod a+x /main.sh |
||||
|
||||
ENTRYPOINT /main.sh |
||||
@ -0,0 +1,80 @@
|
||||
#!/bin/bash |
||||
|
||||
if [ -z "$ZT_IDENTITY_PATH" ]; then |
||||
echo '*** FAILED: ZT_IDENTITY_PATH environment variable is not defined' |
||||
exit 1 |
||||
fi |
||||
if [ -z "$ZT_DB_HOST" ]; then |
||||
echo '*** FAILED: ZT_DB_HOST environment variable not defined' |
||||
exit 1 |
||||
fi |
||||
if [ -z "$ZT_DB_PORT" ]; then |
||||
echo '*** FAILED: ZT_DB_PORT environment variable not defined' |
||||
exit 1 |
||||
fi |
||||
if [ -z "$ZT_DB_NAME" ]; then |
||||
echo '*** FAILED: ZT_DB_NAME environment variable not defined' |
||||
exit 1 |
||||
fi |
||||
if [ -z "$ZT_DB_USER" ]; then |
||||
echo '*** FAILED: ZT_DB_USER environment variable not defined' |
||||
exit 1 |
||||
fi |
||||
if [ -z "$ZT_DB_PASSWORD" ]; then |
||||
echo '*** FAILED: ZT_DB_PASSWORD environment variable not defined' |
||||
exit 1 |
||||
fi |
||||
|
||||
RMQ="" |
||||
if [ "$ZT_USE_RABBITMQ" == "true" ]; then |
||||
if [ -z "$RABBITMQ_HOST" ]; then |
||||
echo '*** FAILED: RABBITMQ_HOST environment variable not defined' |
||||
exit 1 |
||||
fi |
||||
if [ -z "$RABBITMQ_PORT" ]; then |
||||
echo '*** FAILED: RABBITMQ_PORT environment variable not defined' |
||||
exit 1 |
||||
fi |
||||
if [ -z "$RABBITMQ_USERNAME" ]; then |
||||
echo '*** FAILED: RABBITMQ_USERNAME environment variable not defined' |
||||
exit 1 |
||||
fi |
||||
if [ -z "$RABBITMQ_PASSWORD" ]; then |
||||
echo '*** FAILED: RABBITMQ_PASSWORD environment variable not defined' |
||||
exit 1 |
||||
fi |
||||
RMQ=", \"rabbitmq\": { |
||||
\"host\": \"${RABBITMQ_HOST}\", |
||||
\"port\": ${RABBITMQ_PORT}, |
||||
\"username\": \"${RABBITMQ_USERNAME}\", |
||||
\"password\": \"${RABBITMQ_PASSWORD}\" |
||||
}" |
||||
fi |
||||
|
||||
mkdir -p /var/lib/zerotier-one |
||||
|
||||
pushd /var/lib/zerotier-one |
||||
ln -s $ZT_IDENTITY_PATH/identity.public identity.public |
||||
ln -s $ZT_IDENTITY_PATH/identity.secret identity.secret |
||||
popd |
||||
|
||||
DEFAULT_PORT=9993 |
||||
|
||||
echo "{ |
||||
\"settings\": { |
||||
\"portMappingEnabled\": true, |
||||
\"softwareUpdate\": \"disable\", |
||||
\"interfacePrefixBlacklist\": [ |
||||
\"inot\", |
||||
\"nat64\" |
||||
], |
||||
\"controllerDbPath\": \"postgres:host=${ZT_DB_HOST} port=${ZT_DB_PORT} dbname=${ZT_DB_NAME} user=${ZT_DB_USER} password=${ZT_DB_PASSWORD} sslmode=prefer sslcert=${DB_CLIENT_CERT} sslkey=${DB_CLIENT_KEY} sslrootcert=${DB_SERVER_CA}\" |
||||
${RMQ} |
||||
} |
||||
} |
||||
" > /var/lib/zerotier-one/local.conf |
||||
|
||||
export GLIBCXX_FORCE_NEW=1 |
||||
export GLIBCPP_FORCE_NEW=1 |
||||
export LD_PRELOAD="/usr/lib64/libjemalloc.so" |
||||
exec /usr/local/bin/zerotier-one -p${ZT_CONTROLLER_PORT:-$DEFAULT_PORT} /var/lib/zerotier-one |
||||
Loading…
Reference in new issue