From 4d39a9de2a44c80ba7dd1c8421dea8b870fa409e Mon Sep 17 00:00:00 2001 From: devanbenz <devandbenz@gmail.com> Date: Wed, 16 Apr 2025 16:15:24 -0500 Subject: [PATCH] feat: Adds 1.12 docker information --- influxdb/1.12/Dockerfile | 32 +++++ influxdb/1.12/alpine/Dockerfile | 49 +++++++ influxdb/1.12/alpine/entrypoint.sh | 12 ++ influxdb/1.12/alpine/influxdb.conf | 7 + influxdb/1.12/alpine/init-influxdb.sh | 128 +++++++++++++++++++ influxdb/1.12/data/Dockerfile | 27 ++++ influxdb/1.12/data/alpine/Dockerfile | 35 +++++ influxdb/1.12/data/alpine/entrypoint.sh | 14 ++ influxdb/1.12/data/alpine/influxdb.conf | 10 ++ influxdb/1.12/data/alpine/init-influxdb.sh | 128 +++++++++++++++++++ influxdb/1.12/data/entrypoint.sh | 14 ++ influxdb/1.12/data/influxdb.conf | 10 ++ influxdb/1.12/data/init-influxdb.sh | 128 +++++++++++++++++++ influxdb/1.12/entrypoint.sh | 12 ++ influxdb/1.12/influxdb.conf | 7 + influxdb/1.12/init-influxdb.sh | 128 +++++++++++++++++++ influxdb/1.12/meta/Dockerfile | 26 ++++ influxdb/1.12/meta/alpine/Dockerfile | 34 +++++ influxdb/1.12/meta/alpine/entrypoint.sh | 35 +++++ influxdb/1.12/meta/alpine/influxdb-meta.conf | 2 + influxdb/1.12/meta/entrypoint.sh | 35 +++++ influxdb/1.12/meta/influxdb-meta.conf | 2 + 22 files changed, 875 insertions(+) create mode 100644 influxdb/1.12/Dockerfile create mode 100644 influxdb/1.12/alpine/Dockerfile create mode 100755 influxdb/1.12/alpine/entrypoint.sh create mode 100644 influxdb/1.12/alpine/influxdb.conf create mode 100755 influxdb/1.12/alpine/init-influxdb.sh create mode 100644 influxdb/1.12/data/Dockerfile create mode 100644 influxdb/1.12/data/alpine/Dockerfile create mode 100755 influxdb/1.12/data/alpine/entrypoint.sh create mode 100644 influxdb/1.12/data/alpine/influxdb.conf create mode 100755 influxdb/1.12/data/alpine/init-influxdb.sh create mode 100755 influxdb/1.12/data/entrypoint.sh create mode 100644 influxdb/1.12/data/influxdb.conf create mode 100755 influxdb/1.12/data/init-influxdb.sh create mode 100755 influxdb/1.12/entrypoint.sh create mode 100644 influxdb/1.12/influxdb.conf create mode 100755 influxdb/1.12/init-influxdb.sh create mode 100644 influxdb/1.12/meta/Dockerfile create mode 100644 influxdb/1.12/meta/alpine/Dockerfile create mode 100755 influxdb/1.12/meta/alpine/entrypoint.sh create mode 100644 influxdb/1.12/meta/alpine/influxdb-meta.conf create mode 100755 influxdb/1.12/meta/entrypoint.sh create mode 100644 influxdb/1.12/meta/influxdb-meta.conf diff --git a/influxdb/1.12/Dockerfile b/influxdb/1.12/Dockerfile new file mode 100644 index 0000000..39156a4 --- /dev/null +++ b/influxdb/1.12/Dockerfile @@ -0,0 +1,32 @@ +FROM buildpack-deps:bookworm-curl + +RUN addgroup --system --gid 1500 influxdb && \ + adduser --system --uid 1500 --ingroup influxdb --home /var/lib/influxdb --shell /bin/false influxdb + +ARG INFLUXDB_VERSION=1.12.0 +RUN gpg --batch --keyserver hkp://keyserver.ubuntu.com --recv-keys 9D539D90D3328DC7D6C8D3B9D8FF8E1F7DF8B07E && \ + export DEBIAN_FRONTEND=noninteractive && \ + apt-get update && \ + case "$(dpkg --print-architecture)" in \ + *amd64) ARCH=amd64 ;; \ + *arm64) ARCH=arm64 ;; \ + *) exit 1 ;; \ + esac && \ + export INFLUXDB_DEB=influxdb-${INFLUXDB_VERSION}-${ARCH}.deb && \ + export INFLUXDB_ASC=influxdb-${INFLUXDB_VERSION}-${ARCH}.deb.asc && \ + curl -fLO "https://dl.influxdata.com/influxdb/releases/${INFLUXDB_DEB}" && \ + curl -fLO "https://dl.influxdata.com/influxdb/releases/${INFLUXDB_ASC}" && \ + gpg --batch --verify "${INFLUXDB_ASC}" "${INFLUXDB_DEB}" && \ + apt-get install -y "./${INFLUXDB_DEB}" && \ + rm -rf "${INFLUXDB_DEB}" \ + "${INFLUXDB_ASC}" \ + /var/lib/apt/lists/* +COPY influxdb.conf /etc/influxdb/influxdb.conf + +EXPOSE 8086 +VOLUME /var/lib/influxdb +COPY entrypoint.sh /entrypoint.sh +COPY init-influxdb.sh /init-influxdb.sh +USER influxdb +ENTRYPOINT ["/entrypoint.sh"] +CMD ["influxd"] diff --git a/influxdb/1.12/alpine/Dockerfile b/influxdb/1.12/alpine/Dockerfile new file mode 100644 index 0000000..7680b26 --- /dev/null +++ b/influxdb/1.12/alpine/Dockerfile @@ -0,0 +1,49 @@ +FROM alpine:3.20 + +RUN apk add --no-cache \ + bash \ + ca-certificates \ + tzdata && \ + update-ca-certificates + +ARG INFLUXDB_VERSION=1.12.0 +RUN apk add --no-cache --virtual .build-deps \ + curl \ + gnupg \ + tar && \ + gpg --batch --keyserver hkp://keyserver.ubuntu.com --recv-keys 9D539D90D3328DC7D6C8D3B9D8FF8E1F7DF8B07E && \ + case "$(apk --print-arch)" in \ + x86_64) ARCH=amd64 ;; \ + aarch64) ARCH=arm64 ;; \ + *) exit 1 ;; \ + esac && \ + export INFLUXDB_TAR=influxdb-${INFLUXDB_VERSION}-linux-${ARCH}.tar.gz && \ + export INFLUXDB_ASC=influxdb-${INFLUXDB_VERSION}-linux-${ARCH}.tar.gz.asc && \ + curl -fLO "https://dl.influxdata.com/influxdb/releases/${INFLUXDB_TAR}" && \ + curl -fLO "https://dl.influxdata.com/influxdb/releases/${INFLUXDB_ASC}" && \ + gpg --batch --verify "${INFLUXDB_ASC}" "${INFLUXDB_TAR}" && \ + tar -xf "${INFLUXDB_TAR}" -C /usr/bin \ + influx \ + influx_inspect \ + influxd && \ + rm -rf "${INFLUXDB_TAR}" \ + "${INFLUXDB_ASC}" && \ + apk del .build-deps +COPY influxdb.conf /etc/influxdb/influxdb.conf + +RUN addgroup --system --gid 1500 influxdb && \ + adduser --system --uid 1500 --ingroup influxdb --home /var/lib/influxdb --shell /bin/false influxdb && \ + mkdir -p /var/lib/influxdb && \ + mkdir -p /var/log/influxdb && \ + chown influxdb:influxdb /var/lib/influxdb && \ + chown influxdb:influxdb /var/log/influxdb && \ + chmod 0750 /var/lib/influxdb && \ + chmod 0750 /var/log/influxdb + +EXPOSE 8086 +VOLUME /var/lib/influxdb +COPY entrypoint.sh /entrypoint.sh +COPY init-influxdb.sh /init-influxdb.sh +USER influxdb +ENTRYPOINT ["/entrypoint.sh"] +CMD ["influxd"] diff --git a/influxdb/1.12/alpine/entrypoint.sh b/influxdb/1.12/alpine/entrypoint.sh new file mode 100755 index 0000000..26e6bd7 --- /dev/null +++ b/influxdb/1.12/alpine/entrypoint.sh @@ -0,0 +1,12 @@ +#!/bin/bash +set -e + +if [ "${1:0:1}" = '-' ]; then + set -- influxd "$@" +fi + +if [ "$1" = 'influxd' ]; then + /init-influxdb.sh "${@:2}" +fi + +exec "$@" diff --git a/influxdb/1.12/alpine/influxdb.conf b/influxdb/1.12/alpine/influxdb.conf new file mode 100644 index 0000000..986803a --- /dev/null +++ b/influxdb/1.12/alpine/influxdb.conf @@ -0,0 +1,7 @@ +[meta] + dir = "/var/lib/influxdb/meta" + +[data] + dir = "/var/lib/influxdb/data" + engine = "tsm1" + wal-dir = "/var/lib/influxdb/wal" diff --git a/influxdb/1.12/alpine/init-influxdb.sh b/influxdb/1.12/alpine/init-influxdb.sh new file mode 100755 index 0000000..3f7349a --- /dev/null +++ b/influxdb/1.12/alpine/init-influxdb.sh @@ -0,0 +1,128 @@ +#!/bin/bash +set -e + +AUTH_ENABLED="$INFLUXDB_HTTP_AUTH_ENABLED" + +if [ -z "$AUTH_ENABLED" ]; then + AUTH_ENABLED="$(grep -iE '^\s*auth-enabled\s*=\s*true' /etc/influxdb/influxdb.conf | grep -io 'true' | cat)" +else + AUTH_ENABLED="$(echo "$INFLUXDB_HTTP_AUTH_ENABLED" | grep -io 'true' | cat)" +fi + +INIT_USERS=$([ ! -z "$AUTH_ENABLED" ] && [ ! -z "$INFLUXDB_ADMIN_USER" ] && echo 1 || echo) + +# Check if an environment variable for where to put meta is set. +# If so, then use that directory, otherwise use the default. +if [ -z "$INFLUXDB_META_DIR" ]; then + META_DIR="/var/lib/influxdb/meta" +else + META_DIR="$INFLUXDB_META_DIR" +fi + +if ( [ ! -z "$INIT_USERS" ] || [ ! -z "$INFLUXDB_DB" ] || [ "$(ls -A /docker-entrypoint-initdb.d 2> /dev/null)" ] ) && [ ! "$(ls -d "$META_DIR" 2>/dev/null)" ]; then + + INIT_QUERY="" + CREATE_DB_QUERY="CREATE DATABASE $INFLUXDB_DB" + + if [ ! -z "$INIT_USERS" ]; then + + if [ -z "$INFLUXDB_ADMIN_PASSWORD" ]; then + INFLUXDB_ADMIN_PASSWORD="$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c32;echo;)" + echo "INFLUXDB_ADMIN_PASSWORD:$INFLUXDB_ADMIN_PASSWORD" + fi + + INIT_QUERY="CREATE USER \"$INFLUXDB_ADMIN_USER\" WITH PASSWORD '$INFLUXDB_ADMIN_PASSWORD' WITH ALL PRIVILEGES" + elif [ ! -z "$INFLUXDB_DB" ]; then + INIT_QUERY="$CREATE_DB_QUERY" + else + INIT_QUERY="SHOW DATABASES" + fi + + INFLUXDB_INIT_PORT="8086" + + INFLUXDB_HTTP_BIND_ADDRESS=127.0.0.1:$INFLUXDB_INIT_PORT INFLUXDB_HTTP_HTTPS_ENABLED=false influxd "$@" & + pid="$!" + + INFLUX_CMD="influx -host 127.0.0.1 -port $INFLUXDB_INIT_PORT -execute " + + for i in {30..0}; do + if $INFLUX_CMD "$INIT_QUERY" &> /dev/null; then + break + fi + echo 'influxdb init process in progress...' + sleep 1 + done + + if [ "$i" = 0 ]; then + echo >&2 'influxdb init process failed.' + exit 1 + fi + + if [ ! -z "$INIT_USERS" ]; then + + INFLUX_CMD="influx -host 127.0.0.1 -port $INFLUXDB_INIT_PORT -username ${INFLUXDB_ADMIN_USER} -password ${INFLUXDB_ADMIN_PASSWORD} -execute " + + if [ ! -z "$INFLUXDB_DB" ]; then + $INFLUX_CMD "$CREATE_DB_QUERY" + fi + + if [ ! -z "$INFLUXDB_USER" ] && [ -z "$INFLUXDB_USER_PASSWORD" ]; then + INFLUXDB_USER_PASSWORD="$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c32;echo;)" + echo "INFLUXDB_USER_PASSWORD:$INFLUXDB_USER_PASSWORD" + fi + + if [ ! -z "$INFLUXDB_USER" ]; then + $INFLUX_CMD "CREATE USER \"$INFLUXDB_USER\" WITH PASSWORD '$INFLUXDB_USER_PASSWORD'" + + $INFLUX_CMD "REVOKE ALL PRIVILEGES FROM \"$INFLUXDB_USER\"" + + if [ ! -z "$INFLUXDB_DB" ]; then + $INFLUX_CMD "GRANT ALL ON \"$INFLUXDB_DB\" TO \"$INFLUXDB_USER\"" + fi + fi + + if [ ! -z "$INFLUXDB_WRITE_USER" ] && [ -z "$INFLUXDB_WRITE_USER_PASSWORD" ]; then + INFLUXDB_WRITE_USER_PASSWORD="$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c32;echo;)" + echo "INFLUXDB_WRITE_USER_PASSWORD:$INFLUXDB_WRITE_USER_PASSWORD" + fi + + if [ ! -z "$INFLUXDB_WRITE_USER" ]; then + $INFLUX_CMD "CREATE USER \"$INFLUXDB_WRITE_USER\" WITH PASSWORD '$INFLUXDB_WRITE_USER_PASSWORD'" + $INFLUX_CMD "REVOKE ALL PRIVILEGES FROM \"$INFLUXDB_WRITE_USER\"" + + if [ ! -z "$INFLUXDB_DB" ]; then + $INFLUX_CMD "GRANT WRITE ON \"$INFLUXDB_DB\" TO \"$INFLUXDB_WRITE_USER\"" + fi + fi + + if [ ! -z "$INFLUXDB_READ_USER" ] && [ -z "$INFLUXDB_READ_USER_PASSWORD" ]; then + INFLUXDB_READ_USER_PASSWORD="$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c32;echo;)" + echo "INFLUXDB_READ_USER_PASSWORD:$INFLUXDB_READ_USER_PASSWORD" + fi + + if [ ! -z "$INFLUXDB_READ_USER" ]; then + $INFLUX_CMD "CREATE USER \"$INFLUXDB_READ_USER\" WITH PASSWORD '$INFLUXDB_READ_USER_PASSWORD'" + $INFLUX_CMD "REVOKE ALL PRIVILEGES FROM \"$INFLUXDB_READ_USER\"" + + if [ ! -z "$INFLUXDB_DB" ]; then + $INFLUX_CMD "GRANT READ ON \"$INFLUXDB_DB\" TO \"$INFLUXDB_READ_USER\"" + fi + fi + + fi + + for f in /docker-entrypoint-initdb.d/*; do + case "$f" in + *.sh) echo "$0: running $f"; . "$f" ;; + *.iql) echo "$0: running $f"; $INFLUX_CMD "$(cat ""$f"")"; echo ;; + *) echo "$0: ignoring $f" ;; + esac + echo + done + + if ! kill -s TERM "$pid" || ! wait "$pid"; then + echo >&2 'influxdb init process failed. (Could not stop influxdb)' + exit 1 + fi + +fi diff --git a/influxdb/1.12/data/Dockerfile b/influxdb/1.12/data/Dockerfile new file mode 100644 index 0000000..66c2db7 --- /dev/null +++ b/influxdb/1.12/data/Dockerfile @@ -0,0 +1,27 @@ +FROM buildpack-deps:bookworm-curl + +RUN set -ex && \ + mkdir ~/.gnupg; \ + echo "disable-ipv6" >> ~/.gnupg/dirmngr.conf; \ + for key in \ + 9D539D90D3328DC7D6C8D3B9D8FF8E1F7DF8B07E ; \ + do \ + gpg --keyserver hkp://keyserver.ubuntu.com --recv-keys "$key" ; \ + done + +ENV INFLUXDB_VERSION 1.12.0-c1.12.0 +RUN wget --no-verbose https://dl.influxdata.com/enterprise/releases/influxdb-data_${INFLUXDB_VERSION}-1_amd64.deb.asc && \ + wget --no-verbose https://dl.influxdata.com/enterprise/releases/influxdb-data_${INFLUXDB_VERSION}-1_amd64.deb && \ + gpg --batch --verify influxdb-data_${INFLUXDB_VERSION}-1_amd64.deb.asc influxdb-data_${INFLUXDB_VERSION}-1_amd64.deb && \ + dpkg -i influxdb-data_${INFLUXDB_VERSION}-1_amd64.deb && \ + rm -f influxdb-data_${INFLUXDB_VERSION}-1_amd64.deb* +COPY influxdb.conf /etc/influxdb/influxdb.conf + +EXPOSE 8086 + +VOLUME /var/lib/influxdb + +COPY entrypoint.sh /entrypoint.sh +COPY init-influxdb.sh /init-influxdb.sh +ENTRYPOINT ["/entrypoint.sh"] +CMD ["influxd"] diff --git a/influxdb/1.12/data/alpine/Dockerfile b/influxdb/1.12/data/alpine/Dockerfile new file mode 100644 index 0000000..366c910 --- /dev/null +++ b/influxdb/1.12/data/alpine/Dockerfile @@ -0,0 +1,35 @@ +FROM alpine:3.20 + +RUN echo 'hosts: files dns' >> /etc/nsswitch.conf +RUN apk add --no-cache tzdata bash ca-certificates && \ + update-ca-certificates + +ENV INFLUXDB_VERSION 1.12.0-c1.12.0 +RUN set -ex && \ + apk add --no-cache --virtual .build-deps wget gnupg tar && \ + for key in \ + 9D539D90D3328DC7D6C8D3B9D8FF8E1F7DF8B07E ; \ + do \ + gpg --keyserver hkp://keyserver.ubuntu.com --recv-keys "$key" ; \ + done && \ + wget --no-verbose https://dl.influxdata.com/enterprise/releases/influxdb-data-${INFLUXDB_VERSION}_linux_amd64.tar.gz.asc && \ + wget --no-verbose https://dl.influxdata.com/enterprise/releases/influxdb-data-${INFLUXDB_VERSION}_linux_amd64.tar.gz && \ + gpg --batch --verify influxdb-data-${INFLUXDB_VERSION}_linux_amd64.tar.gz.asc influxdb-data-${INFLUXDB_VERSION}_linux_amd64.tar.gz && \ + mkdir -p /usr/src && \ + tar -C /usr/src -xzf influxdb-data-${INFLUXDB_VERSION}_linux_amd64.tar.gz && \ + rm -f /usr/src/influxdb-*/influxdb.conf && \ + chmod +x /usr/src/influxdb-*/usr/bin/* && \ + cp -a /usr/src/influxdb-*/usr/bin/. /usr/bin/ && \ + gpgconf --kill all && \ + rm -rf *.tar.gz* /usr/src /root/.gnupg && \ + apk del .build-deps +COPY influxdb.conf /etc/influxdb/influxdb.conf + +EXPOSE 8086 + +VOLUME /var/lib/influxdb + +COPY entrypoint.sh /entrypoint.sh +COPY init-influxdb.sh /init-influxdb.sh +ENTRYPOINT ["/entrypoint.sh"] +CMD ["influxd"] diff --git a/influxdb/1.12/data/alpine/entrypoint.sh b/influxdb/1.12/data/alpine/entrypoint.sh new file mode 100755 index 0000000..83d12eb --- /dev/null +++ b/influxdb/1.12/data/alpine/entrypoint.sh @@ -0,0 +1,14 @@ +#!/bin/bash +set -e + +export INFLUXDB_HOSTNAME=${INFLUXDB_HOSTNAME:-$HOSTNAME} + +if [ "${1:0:1}" = '-' ]; then + set -- influxd "$@" +fi + +if [ "$1" = 'influxd' ]; then + /init-influxdb.sh "${@:2}" +fi + +exec "$@" diff --git a/influxdb/1.12/data/alpine/influxdb.conf b/influxdb/1.12/data/alpine/influxdb.conf new file mode 100644 index 0000000..f03c128 --- /dev/null +++ b/influxdb/1.12/data/alpine/influxdb.conf @@ -0,0 +1,10 @@ +[meta] + dir = "/var/lib/influxdb/meta" + +[data] + dir = "/var/lib/influxdb/data" + engine = "tsm1" + wal-dir = "/var/lib/influxdb/wal" + +[hinted-handoff] + dir = "/var/lib/influxdb/hh" diff --git a/influxdb/1.12/data/alpine/init-influxdb.sh b/influxdb/1.12/data/alpine/init-influxdb.sh new file mode 100755 index 0000000..3f7349a --- /dev/null +++ b/influxdb/1.12/data/alpine/init-influxdb.sh @@ -0,0 +1,128 @@ +#!/bin/bash +set -e + +AUTH_ENABLED="$INFLUXDB_HTTP_AUTH_ENABLED" + +if [ -z "$AUTH_ENABLED" ]; then + AUTH_ENABLED="$(grep -iE '^\s*auth-enabled\s*=\s*true' /etc/influxdb/influxdb.conf | grep -io 'true' | cat)" +else + AUTH_ENABLED="$(echo "$INFLUXDB_HTTP_AUTH_ENABLED" | grep -io 'true' | cat)" +fi + +INIT_USERS=$([ ! -z "$AUTH_ENABLED" ] && [ ! -z "$INFLUXDB_ADMIN_USER" ] && echo 1 || echo) + +# Check if an environment variable for where to put meta is set. +# If so, then use that directory, otherwise use the default. +if [ -z "$INFLUXDB_META_DIR" ]; then + META_DIR="/var/lib/influxdb/meta" +else + META_DIR="$INFLUXDB_META_DIR" +fi + +if ( [ ! -z "$INIT_USERS" ] || [ ! -z "$INFLUXDB_DB" ] || [ "$(ls -A /docker-entrypoint-initdb.d 2> /dev/null)" ] ) && [ ! "$(ls -d "$META_DIR" 2>/dev/null)" ]; then + + INIT_QUERY="" + CREATE_DB_QUERY="CREATE DATABASE $INFLUXDB_DB" + + if [ ! -z "$INIT_USERS" ]; then + + if [ -z "$INFLUXDB_ADMIN_PASSWORD" ]; then + INFLUXDB_ADMIN_PASSWORD="$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c32;echo;)" + echo "INFLUXDB_ADMIN_PASSWORD:$INFLUXDB_ADMIN_PASSWORD" + fi + + INIT_QUERY="CREATE USER \"$INFLUXDB_ADMIN_USER\" WITH PASSWORD '$INFLUXDB_ADMIN_PASSWORD' WITH ALL PRIVILEGES" + elif [ ! -z "$INFLUXDB_DB" ]; then + INIT_QUERY="$CREATE_DB_QUERY" + else + INIT_QUERY="SHOW DATABASES" + fi + + INFLUXDB_INIT_PORT="8086" + + INFLUXDB_HTTP_BIND_ADDRESS=127.0.0.1:$INFLUXDB_INIT_PORT INFLUXDB_HTTP_HTTPS_ENABLED=false influxd "$@" & + pid="$!" + + INFLUX_CMD="influx -host 127.0.0.1 -port $INFLUXDB_INIT_PORT -execute " + + for i in {30..0}; do + if $INFLUX_CMD "$INIT_QUERY" &> /dev/null; then + break + fi + echo 'influxdb init process in progress...' + sleep 1 + done + + if [ "$i" = 0 ]; then + echo >&2 'influxdb init process failed.' + exit 1 + fi + + if [ ! -z "$INIT_USERS" ]; then + + INFLUX_CMD="influx -host 127.0.0.1 -port $INFLUXDB_INIT_PORT -username ${INFLUXDB_ADMIN_USER} -password ${INFLUXDB_ADMIN_PASSWORD} -execute " + + if [ ! -z "$INFLUXDB_DB" ]; then + $INFLUX_CMD "$CREATE_DB_QUERY" + fi + + if [ ! -z "$INFLUXDB_USER" ] && [ -z "$INFLUXDB_USER_PASSWORD" ]; then + INFLUXDB_USER_PASSWORD="$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c32;echo;)" + echo "INFLUXDB_USER_PASSWORD:$INFLUXDB_USER_PASSWORD" + fi + + if [ ! -z "$INFLUXDB_USER" ]; then + $INFLUX_CMD "CREATE USER \"$INFLUXDB_USER\" WITH PASSWORD '$INFLUXDB_USER_PASSWORD'" + + $INFLUX_CMD "REVOKE ALL PRIVILEGES FROM \"$INFLUXDB_USER\"" + + if [ ! -z "$INFLUXDB_DB" ]; then + $INFLUX_CMD "GRANT ALL ON \"$INFLUXDB_DB\" TO \"$INFLUXDB_USER\"" + fi + fi + + if [ ! -z "$INFLUXDB_WRITE_USER" ] && [ -z "$INFLUXDB_WRITE_USER_PASSWORD" ]; then + INFLUXDB_WRITE_USER_PASSWORD="$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c32;echo;)" + echo "INFLUXDB_WRITE_USER_PASSWORD:$INFLUXDB_WRITE_USER_PASSWORD" + fi + + if [ ! -z "$INFLUXDB_WRITE_USER" ]; then + $INFLUX_CMD "CREATE USER \"$INFLUXDB_WRITE_USER\" WITH PASSWORD '$INFLUXDB_WRITE_USER_PASSWORD'" + $INFLUX_CMD "REVOKE ALL PRIVILEGES FROM \"$INFLUXDB_WRITE_USER\"" + + if [ ! -z "$INFLUXDB_DB" ]; then + $INFLUX_CMD "GRANT WRITE ON \"$INFLUXDB_DB\" TO \"$INFLUXDB_WRITE_USER\"" + fi + fi + + if [ ! -z "$INFLUXDB_READ_USER" ] && [ -z "$INFLUXDB_READ_USER_PASSWORD" ]; then + INFLUXDB_READ_USER_PASSWORD="$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c32;echo;)" + echo "INFLUXDB_READ_USER_PASSWORD:$INFLUXDB_READ_USER_PASSWORD" + fi + + if [ ! -z "$INFLUXDB_READ_USER" ]; then + $INFLUX_CMD "CREATE USER \"$INFLUXDB_READ_USER\" WITH PASSWORD '$INFLUXDB_READ_USER_PASSWORD'" + $INFLUX_CMD "REVOKE ALL PRIVILEGES FROM \"$INFLUXDB_READ_USER\"" + + if [ ! -z "$INFLUXDB_DB" ]; then + $INFLUX_CMD "GRANT READ ON \"$INFLUXDB_DB\" TO \"$INFLUXDB_READ_USER\"" + fi + fi + + fi + + for f in /docker-entrypoint-initdb.d/*; do + case "$f" in + *.sh) echo "$0: running $f"; . "$f" ;; + *.iql) echo "$0: running $f"; $INFLUX_CMD "$(cat ""$f"")"; echo ;; + *) echo "$0: ignoring $f" ;; + esac + echo + done + + if ! kill -s TERM "$pid" || ! wait "$pid"; then + echo >&2 'influxdb init process failed. (Could not stop influxdb)' + exit 1 + fi + +fi diff --git a/influxdb/1.12/data/entrypoint.sh b/influxdb/1.12/data/entrypoint.sh new file mode 100755 index 0000000..83d12eb --- /dev/null +++ b/influxdb/1.12/data/entrypoint.sh @@ -0,0 +1,14 @@ +#!/bin/bash +set -e + +export INFLUXDB_HOSTNAME=${INFLUXDB_HOSTNAME:-$HOSTNAME} + +if [ "${1:0:1}" = '-' ]; then + set -- influxd "$@" +fi + +if [ "$1" = 'influxd' ]; then + /init-influxdb.sh "${@:2}" +fi + +exec "$@" diff --git a/influxdb/1.12/data/influxdb.conf b/influxdb/1.12/data/influxdb.conf new file mode 100644 index 0000000..f03c128 --- /dev/null +++ b/influxdb/1.12/data/influxdb.conf @@ -0,0 +1,10 @@ +[meta] + dir = "/var/lib/influxdb/meta" + +[data] + dir = "/var/lib/influxdb/data" + engine = "tsm1" + wal-dir = "/var/lib/influxdb/wal" + +[hinted-handoff] + dir = "/var/lib/influxdb/hh" diff --git a/influxdb/1.12/data/init-influxdb.sh b/influxdb/1.12/data/init-influxdb.sh new file mode 100755 index 0000000..3f7349a --- /dev/null +++ b/influxdb/1.12/data/init-influxdb.sh @@ -0,0 +1,128 @@ +#!/bin/bash +set -e + +AUTH_ENABLED="$INFLUXDB_HTTP_AUTH_ENABLED" + +if [ -z "$AUTH_ENABLED" ]; then + AUTH_ENABLED="$(grep -iE '^\s*auth-enabled\s*=\s*true' /etc/influxdb/influxdb.conf | grep -io 'true' | cat)" +else + AUTH_ENABLED="$(echo "$INFLUXDB_HTTP_AUTH_ENABLED" | grep -io 'true' | cat)" +fi + +INIT_USERS=$([ ! -z "$AUTH_ENABLED" ] && [ ! -z "$INFLUXDB_ADMIN_USER" ] && echo 1 || echo) + +# Check if an environment variable for where to put meta is set. +# If so, then use that directory, otherwise use the default. +if [ -z "$INFLUXDB_META_DIR" ]; then + META_DIR="/var/lib/influxdb/meta" +else + META_DIR="$INFLUXDB_META_DIR" +fi + +if ( [ ! -z "$INIT_USERS" ] || [ ! -z "$INFLUXDB_DB" ] || [ "$(ls -A /docker-entrypoint-initdb.d 2> /dev/null)" ] ) && [ ! "$(ls -d "$META_DIR" 2>/dev/null)" ]; then + + INIT_QUERY="" + CREATE_DB_QUERY="CREATE DATABASE $INFLUXDB_DB" + + if [ ! -z "$INIT_USERS" ]; then + + if [ -z "$INFLUXDB_ADMIN_PASSWORD" ]; then + INFLUXDB_ADMIN_PASSWORD="$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c32;echo;)" + echo "INFLUXDB_ADMIN_PASSWORD:$INFLUXDB_ADMIN_PASSWORD" + fi + + INIT_QUERY="CREATE USER \"$INFLUXDB_ADMIN_USER\" WITH PASSWORD '$INFLUXDB_ADMIN_PASSWORD' WITH ALL PRIVILEGES" + elif [ ! -z "$INFLUXDB_DB" ]; then + INIT_QUERY="$CREATE_DB_QUERY" + else + INIT_QUERY="SHOW DATABASES" + fi + + INFLUXDB_INIT_PORT="8086" + + INFLUXDB_HTTP_BIND_ADDRESS=127.0.0.1:$INFLUXDB_INIT_PORT INFLUXDB_HTTP_HTTPS_ENABLED=false influxd "$@" & + pid="$!" + + INFLUX_CMD="influx -host 127.0.0.1 -port $INFLUXDB_INIT_PORT -execute " + + for i in {30..0}; do + if $INFLUX_CMD "$INIT_QUERY" &> /dev/null; then + break + fi + echo 'influxdb init process in progress...' + sleep 1 + done + + if [ "$i" = 0 ]; then + echo >&2 'influxdb init process failed.' + exit 1 + fi + + if [ ! -z "$INIT_USERS" ]; then + + INFLUX_CMD="influx -host 127.0.0.1 -port $INFLUXDB_INIT_PORT -username ${INFLUXDB_ADMIN_USER} -password ${INFLUXDB_ADMIN_PASSWORD} -execute " + + if [ ! -z "$INFLUXDB_DB" ]; then + $INFLUX_CMD "$CREATE_DB_QUERY" + fi + + if [ ! -z "$INFLUXDB_USER" ] && [ -z "$INFLUXDB_USER_PASSWORD" ]; then + INFLUXDB_USER_PASSWORD="$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c32;echo;)" + echo "INFLUXDB_USER_PASSWORD:$INFLUXDB_USER_PASSWORD" + fi + + if [ ! -z "$INFLUXDB_USER" ]; then + $INFLUX_CMD "CREATE USER \"$INFLUXDB_USER\" WITH PASSWORD '$INFLUXDB_USER_PASSWORD'" + + $INFLUX_CMD "REVOKE ALL PRIVILEGES FROM \"$INFLUXDB_USER\"" + + if [ ! -z "$INFLUXDB_DB" ]; then + $INFLUX_CMD "GRANT ALL ON \"$INFLUXDB_DB\" TO \"$INFLUXDB_USER\"" + fi + fi + + if [ ! -z "$INFLUXDB_WRITE_USER" ] && [ -z "$INFLUXDB_WRITE_USER_PASSWORD" ]; then + INFLUXDB_WRITE_USER_PASSWORD="$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c32;echo;)" + echo "INFLUXDB_WRITE_USER_PASSWORD:$INFLUXDB_WRITE_USER_PASSWORD" + fi + + if [ ! -z "$INFLUXDB_WRITE_USER" ]; then + $INFLUX_CMD "CREATE USER \"$INFLUXDB_WRITE_USER\" WITH PASSWORD '$INFLUXDB_WRITE_USER_PASSWORD'" + $INFLUX_CMD "REVOKE ALL PRIVILEGES FROM \"$INFLUXDB_WRITE_USER\"" + + if [ ! -z "$INFLUXDB_DB" ]; then + $INFLUX_CMD "GRANT WRITE ON \"$INFLUXDB_DB\" TO \"$INFLUXDB_WRITE_USER\"" + fi + fi + + if [ ! -z "$INFLUXDB_READ_USER" ] && [ -z "$INFLUXDB_READ_USER_PASSWORD" ]; then + INFLUXDB_READ_USER_PASSWORD="$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c32;echo;)" + echo "INFLUXDB_READ_USER_PASSWORD:$INFLUXDB_READ_USER_PASSWORD" + fi + + if [ ! -z "$INFLUXDB_READ_USER" ]; then + $INFLUX_CMD "CREATE USER \"$INFLUXDB_READ_USER\" WITH PASSWORD '$INFLUXDB_READ_USER_PASSWORD'" + $INFLUX_CMD "REVOKE ALL PRIVILEGES FROM \"$INFLUXDB_READ_USER\"" + + if [ ! -z "$INFLUXDB_DB" ]; then + $INFLUX_CMD "GRANT READ ON \"$INFLUXDB_DB\" TO \"$INFLUXDB_READ_USER\"" + fi + fi + + fi + + for f in /docker-entrypoint-initdb.d/*; do + case "$f" in + *.sh) echo "$0: running $f"; . "$f" ;; + *.iql) echo "$0: running $f"; $INFLUX_CMD "$(cat ""$f"")"; echo ;; + *) echo "$0: ignoring $f" ;; + esac + echo + done + + if ! kill -s TERM "$pid" || ! wait "$pid"; then + echo >&2 'influxdb init process failed. (Could not stop influxdb)' + exit 1 + fi + +fi diff --git a/influxdb/1.12/entrypoint.sh b/influxdb/1.12/entrypoint.sh new file mode 100755 index 0000000..832091c --- /dev/null +++ b/influxdb/1.12/entrypoint.sh @@ -0,0 +1,12 @@ +#!/bin/bash +set -e + +if [ "${1:0:1}" = '-' ]; then + set -- influxd "$@" +fi + +if [ "$1" = 'influxd' ]; then + /init-influxdb.sh "${@:2}" +fi + +exec "$@" diff --git a/influxdb/1.12/influxdb.conf b/influxdb/1.12/influxdb.conf new file mode 100644 index 0000000..986803a --- /dev/null +++ b/influxdb/1.12/influxdb.conf @@ -0,0 +1,7 @@ +[meta] + dir = "/var/lib/influxdb/meta" + +[data] + dir = "/var/lib/influxdb/data" + engine = "tsm1" + wal-dir = "/var/lib/influxdb/wal" diff --git a/influxdb/1.12/init-influxdb.sh b/influxdb/1.12/init-influxdb.sh new file mode 100755 index 0000000..3f7349a --- /dev/null +++ b/influxdb/1.12/init-influxdb.sh @@ -0,0 +1,128 @@ +#!/bin/bash +set -e + +AUTH_ENABLED="$INFLUXDB_HTTP_AUTH_ENABLED" + +if [ -z "$AUTH_ENABLED" ]; then + AUTH_ENABLED="$(grep -iE '^\s*auth-enabled\s*=\s*true' /etc/influxdb/influxdb.conf | grep -io 'true' | cat)" +else + AUTH_ENABLED="$(echo "$INFLUXDB_HTTP_AUTH_ENABLED" | grep -io 'true' | cat)" +fi + +INIT_USERS=$([ ! -z "$AUTH_ENABLED" ] && [ ! -z "$INFLUXDB_ADMIN_USER" ] && echo 1 || echo) + +# Check if an environment variable for where to put meta is set. +# If so, then use that directory, otherwise use the default. +if [ -z "$INFLUXDB_META_DIR" ]; then + META_DIR="/var/lib/influxdb/meta" +else + META_DIR="$INFLUXDB_META_DIR" +fi + +if ( [ ! -z "$INIT_USERS" ] || [ ! -z "$INFLUXDB_DB" ] || [ "$(ls -A /docker-entrypoint-initdb.d 2> /dev/null)" ] ) && [ ! "$(ls -d "$META_DIR" 2>/dev/null)" ]; then + + INIT_QUERY="" + CREATE_DB_QUERY="CREATE DATABASE $INFLUXDB_DB" + + if [ ! -z "$INIT_USERS" ]; then + + if [ -z "$INFLUXDB_ADMIN_PASSWORD" ]; then + INFLUXDB_ADMIN_PASSWORD="$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c32;echo;)" + echo "INFLUXDB_ADMIN_PASSWORD:$INFLUXDB_ADMIN_PASSWORD" + fi + + INIT_QUERY="CREATE USER \"$INFLUXDB_ADMIN_USER\" WITH PASSWORD '$INFLUXDB_ADMIN_PASSWORD' WITH ALL PRIVILEGES" + elif [ ! -z "$INFLUXDB_DB" ]; then + INIT_QUERY="$CREATE_DB_QUERY" + else + INIT_QUERY="SHOW DATABASES" + fi + + INFLUXDB_INIT_PORT="8086" + + INFLUXDB_HTTP_BIND_ADDRESS=127.0.0.1:$INFLUXDB_INIT_PORT INFLUXDB_HTTP_HTTPS_ENABLED=false influxd "$@" & + pid="$!" + + INFLUX_CMD="influx -host 127.0.0.1 -port $INFLUXDB_INIT_PORT -execute " + + for i in {30..0}; do + if $INFLUX_CMD "$INIT_QUERY" &> /dev/null; then + break + fi + echo 'influxdb init process in progress...' + sleep 1 + done + + if [ "$i" = 0 ]; then + echo >&2 'influxdb init process failed.' + exit 1 + fi + + if [ ! -z "$INIT_USERS" ]; then + + INFLUX_CMD="influx -host 127.0.0.1 -port $INFLUXDB_INIT_PORT -username ${INFLUXDB_ADMIN_USER} -password ${INFLUXDB_ADMIN_PASSWORD} -execute " + + if [ ! -z "$INFLUXDB_DB" ]; then + $INFLUX_CMD "$CREATE_DB_QUERY" + fi + + if [ ! -z "$INFLUXDB_USER" ] && [ -z "$INFLUXDB_USER_PASSWORD" ]; then + INFLUXDB_USER_PASSWORD="$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c32;echo;)" + echo "INFLUXDB_USER_PASSWORD:$INFLUXDB_USER_PASSWORD" + fi + + if [ ! -z "$INFLUXDB_USER" ]; then + $INFLUX_CMD "CREATE USER \"$INFLUXDB_USER\" WITH PASSWORD '$INFLUXDB_USER_PASSWORD'" + + $INFLUX_CMD "REVOKE ALL PRIVILEGES FROM \"$INFLUXDB_USER\"" + + if [ ! -z "$INFLUXDB_DB" ]; then + $INFLUX_CMD "GRANT ALL ON \"$INFLUXDB_DB\" TO \"$INFLUXDB_USER\"" + fi + fi + + if [ ! -z "$INFLUXDB_WRITE_USER" ] && [ -z "$INFLUXDB_WRITE_USER_PASSWORD" ]; then + INFLUXDB_WRITE_USER_PASSWORD="$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c32;echo;)" + echo "INFLUXDB_WRITE_USER_PASSWORD:$INFLUXDB_WRITE_USER_PASSWORD" + fi + + if [ ! -z "$INFLUXDB_WRITE_USER" ]; then + $INFLUX_CMD "CREATE USER \"$INFLUXDB_WRITE_USER\" WITH PASSWORD '$INFLUXDB_WRITE_USER_PASSWORD'" + $INFLUX_CMD "REVOKE ALL PRIVILEGES FROM \"$INFLUXDB_WRITE_USER\"" + + if [ ! -z "$INFLUXDB_DB" ]; then + $INFLUX_CMD "GRANT WRITE ON \"$INFLUXDB_DB\" TO \"$INFLUXDB_WRITE_USER\"" + fi + fi + + if [ ! -z "$INFLUXDB_READ_USER" ] && [ -z "$INFLUXDB_READ_USER_PASSWORD" ]; then + INFLUXDB_READ_USER_PASSWORD="$(< /dev/urandom tr -dc _A-Z-a-z-0-9 | head -c32;echo;)" + echo "INFLUXDB_READ_USER_PASSWORD:$INFLUXDB_READ_USER_PASSWORD" + fi + + if [ ! -z "$INFLUXDB_READ_USER" ]; then + $INFLUX_CMD "CREATE USER \"$INFLUXDB_READ_USER\" WITH PASSWORD '$INFLUXDB_READ_USER_PASSWORD'" + $INFLUX_CMD "REVOKE ALL PRIVILEGES FROM \"$INFLUXDB_READ_USER\"" + + if [ ! -z "$INFLUXDB_DB" ]; then + $INFLUX_CMD "GRANT READ ON \"$INFLUXDB_DB\" TO \"$INFLUXDB_READ_USER\"" + fi + fi + + fi + + for f in /docker-entrypoint-initdb.d/*; do + case "$f" in + *.sh) echo "$0: running $f"; . "$f" ;; + *.iql) echo "$0: running $f"; $INFLUX_CMD "$(cat ""$f"")"; echo ;; + *) echo "$0: ignoring $f" ;; + esac + echo + done + + if ! kill -s TERM "$pid" || ! wait "$pid"; then + echo >&2 'influxdb init process failed. (Could not stop influxdb)' + exit 1 + fi + +fi diff --git a/influxdb/1.12/meta/Dockerfile b/influxdb/1.12/meta/Dockerfile new file mode 100644 index 0000000..4d1e310 --- /dev/null +++ b/influxdb/1.12/meta/Dockerfile @@ -0,0 +1,26 @@ +FROM buildpack-deps:bookworm-curl + +RUN set -ex && \ + mkdir ~/.gnupg; \ + echo "disable-ipv6" >> ~/.gnupg/dirmngr.conf; \ + for key in \ + 9D539D90D3328DC7D6C8D3B9D8FF8E1F7DF8B07E ; \ + do \ + gpg --keyserver hkp://keyserver.ubuntu.com --recv-keys "$key" ; \ + done + +ENV INFLUXDB_VERSION 1.12.0-c1.12.0 +RUN wget --no-verbose https://dl.influxdata.com/enterprise/releases/influxdb-meta_${INFLUXDB_VERSION}-1_amd64.deb.asc && \ + wget --no-verbose https://dl.influxdata.com/enterprise/releases/influxdb-meta_${INFLUXDB_VERSION}-1_amd64.deb && \ + gpg --batch --verify influxdb-meta_${INFLUXDB_VERSION}-1_amd64.deb.asc influxdb-meta_${INFLUXDB_VERSION}-1_amd64.deb && \ + dpkg -i influxdb-meta_${INFLUXDB_VERSION}-1_amd64.deb && \ + rm -f influxdb-meta_${INFLUXDB_VERSION}-1_amd64.deb* +COPY influxdb-meta.conf /etc/influxdb/influxdb-meta.conf + +EXPOSE 8091 + +VOLUME /var/lib/influxdb + +COPY entrypoint.sh /entrypoint.sh +ENTRYPOINT ["/entrypoint.sh"] +CMD ["influxd-meta"] diff --git a/influxdb/1.12/meta/alpine/Dockerfile b/influxdb/1.12/meta/alpine/Dockerfile new file mode 100644 index 0000000..fb7866b --- /dev/null +++ b/influxdb/1.12/meta/alpine/Dockerfile @@ -0,0 +1,34 @@ +FROM alpine:3.20 + +RUN echo 'hosts: files dns' >> /etc/nsswitch.conf +RUN apk add --no-cache tzdata bash ca-certificates && \ + update-ca-certificates + +ENV INFLUXDB_VERSION 1.12.0-c1.12.0 +RUN set -ex && \ + apk add --no-cache --virtual .build-deps wget gnupg tar && \ + for key in \ + 9D539D90D3328DC7D6C8D3B9D8FF8E1F7DF8B07E ; \ + do \ + gpg --keyserver hkp://keyserver.ubuntu.com --recv-keys "$key" ; \ + done && \ + wget --no-verbose https://dl.influxdata.com/enterprise/releases/influxdb-meta-${INFLUXDB_VERSION}_linux_amd64.tar.gz.asc && \ + wget --no-verbose https://dl.influxdata.com/enterprise/releases/influxdb-meta-${INFLUXDB_VERSION}_linux_amd64.tar.gz && \ + gpg --batch --verify influxdb-meta-${INFLUXDB_VERSION}_linux_amd64.tar.gz.asc influxdb-meta-${INFLUXDB_VERSION}_linux_amd64.tar.gz && \ + mkdir -p /usr/src && \ + tar -C /usr/src -xzf influxdb-meta-${INFLUXDB_VERSION}_linux_amd64.tar.gz && \ + rm -f /usr/src/influxdb-*/influxdb-meta.conf && \ + chmod +x /usr/src/influxdb-*/usr/bin/* && \ + cp -a /usr/src/influxdb-*/usr/bin/. /usr/bin/ && \ + gpgconf --kill all && \ + rm -rf *.tar.gz* /usr/src /root/.gnupg && \ + apk del .build-deps +COPY influxdb-meta.conf /etc/influxdb/influxdb-meta.conf + +EXPOSE 8091 + +VOLUME /var/lib/influxdb + +COPY entrypoint.sh /entrypoint.sh +ENTRYPOINT ["/entrypoint.sh"] +CMD ["influxd-meta"] diff --git a/influxdb/1.12/meta/alpine/entrypoint.sh b/influxdb/1.12/meta/alpine/entrypoint.sh new file mode 100755 index 0000000..ae61bda --- /dev/null +++ b/influxdb/1.12/meta/alpine/entrypoint.sh @@ -0,0 +1,35 @@ +#!/bin/bash +set -e + +export INFLUXDB_HOSTNAME=${INFLUXDB_HOSTNAME:-$HOSTNAME} +export INFLUXDB_META_CONFIG_PATH=${INFLUXDB_META_CONFIG_PATH:-/etc/influxdb/influxdb-meta.conf} + +if [ "${1:0:1}" = '-' ]; then + set -- influxd-meta "$@" +fi + +if [ "$1" = 'influxd-meta' ]; then + shift + if [ $# -gt 0 ]; then + case $1 in + config) + shift + set -- influxd-meta config -config "${INFLUXDB_META_CONFIG_PATH}" "$@" + ;; + run) + shift + set -- influxd-meta run -config "${INFLUXDB_META_CONFIG_PATH}" "$@" + ;; + -*) + set -- influxd-meta -config "${INFLUXDB_META_CONFIG_PATH}" "$@" + ;; + *) + set -- influxd-meta "$@" + ;; + esac + else + set -- influxd-meta -config "${INFLUXDB_META_CONFIG_PATH}" + fi +fi + +exec "$@" diff --git a/influxdb/1.12/meta/alpine/influxdb-meta.conf b/influxdb/1.12/meta/alpine/influxdb-meta.conf new file mode 100644 index 0000000..6491d8a --- /dev/null +++ b/influxdb/1.12/meta/alpine/influxdb-meta.conf @@ -0,0 +1,2 @@ +[meta] + dir = "/var/lib/influxdb/meta" diff --git a/influxdb/1.12/meta/entrypoint.sh b/influxdb/1.12/meta/entrypoint.sh new file mode 100755 index 0000000..ae61bda --- /dev/null +++ b/influxdb/1.12/meta/entrypoint.sh @@ -0,0 +1,35 @@ +#!/bin/bash +set -e + +export INFLUXDB_HOSTNAME=${INFLUXDB_HOSTNAME:-$HOSTNAME} +export INFLUXDB_META_CONFIG_PATH=${INFLUXDB_META_CONFIG_PATH:-/etc/influxdb/influxdb-meta.conf} + +if [ "${1:0:1}" = '-' ]; then + set -- influxd-meta "$@" +fi + +if [ "$1" = 'influxd-meta' ]; then + shift + if [ $# -gt 0 ]; then + case $1 in + config) + shift + set -- influxd-meta config -config "${INFLUXDB_META_CONFIG_PATH}" "$@" + ;; + run) + shift + set -- influxd-meta run -config "${INFLUXDB_META_CONFIG_PATH}" "$@" + ;; + -*) + set -- influxd-meta -config "${INFLUXDB_META_CONFIG_PATH}" "$@" + ;; + *) + set -- influxd-meta "$@" + ;; + esac + else + set -- influxd-meta -config "${INFLUXDB_META_CONFIG_PATH}" + fi +fi + +exec "$@" diff --git a/influxdb/1.12/meta/influxdb-meta.conf b/influxdb/1.12/meta/influxdb-meta.conf new file mode 100644 index 0000000..6491d8a --- /dev/null +++ b/influxdb/1.12/meta/influxdb-meta.conf @@ -0,0 +1,2 @@ +[meta] + dir = "/var/lib/influxdb/meta" -- GitLab