#!/bin/bash # clickhouse-backup is a backup tool (backupbot pre/post-hooks: `clickhouse-backup create/restore`). # It is a 22 MB GitHub download (rate-limit / network), which can fail to download, and lead to crash loop and download throttling. # # to make the download smoother: # - cache the binary on the persistent clickhouse data volume (/var/lib/clickhouse) so it is fetched # at most once and reused on every container restart (no re-download amplification); # - retry with backoff to ride out transient GitHub failures set -e CLICKHOUSE_BACKUP_VERSION=2.4.2 ARCH=$(uname -m) if [[ $ARCH =~ "aarch64" ]]; then ARCH="arm64" elif [[ $ARCH =~ "armv5l" ]]; then ARCH="armv5" elif [[ $ARCH =~ "armv6l" ]]; then ARCH="armv6" elif [[ $ARCH =~ "armv7l" ]]; then ARCH="armv7" elif [[ $ARCH =~ "x86_64" ]]; then ARCH="amd64" fi CACHE_DIR=/var/lib/clickhouse/.ccci-bin CACHED="${CACHE_DIR}/clickhouse-backup" BIN=/usr/local/bin/clickhouse-backup URL="https://github.com/AlexAkulov/clickhouse-backup/releases/download/v${CLICKHOUSE_BACKUP_VERSION}/clickhouse-backup-linux-${ARCH}.tar.gz" install_clickhouse_backup() { mkdir -p "$CACHE_DIR" if [ -x "$CACHED" ]; then cp -f "$CACHED" "$BIN" echo "clickhouse-backup: restored from persistent cache ($CACHED)" return 0 fi for attempt in 1 2 3 4 5; do if wget --continue --output-document=/tmp/clickhouse-backup.tar.gz "$URL" \ && tar -xf /tmp/clickhouse-backup.tar.gz --directory=/usr/local/bin --strip-components=3; then cp -f "$BIN" "$CACHED" 2>/dev/null || true echo "clickhouse-backup: downloaded + cached (attempt ${attempt})" return 0 fi echo "clickhouse-backup: fetch attempt ${attempt} failed; backing off $((attempt * 10))s" >&2 sleep $((attempt * 10)) done echo "clickhouse-backup: fetch FAILED after all retries — aborting; clickhouse-server will NOT start (backup tool is required)" >&2 return 1 } #if the backup tool cannot be installed after retries, it aborts (set -e) so the deploy fails install_clickhouse_backup exec /entrypoint.sh