Настройка небезопасного реестра в демоне docker-in-docker image

Попытка добавить незащищенный реестр докеров в образ dind, который я запускаю в задаче concourse:

Я попытался начать свою задачу, запустив:

export DOCKER_OPTS="$DOCKER_OPTS --insecure-registry=${INSECURE_REG}"

и попытался запустить демона и составить:

docker daemon --insecure-registry=${INSECURE_REG} &
docker-compose up

Однако ошибка задачи: сервер дал HTTP-ответ https-клиенту, а такого изображения нет

Вся задача выглядит так (по сути, это shell-скрипт, выполняемый в контейнере dind, который заканчивается docker-compose):

# Connect to insecure docker registry:
export DOCKER_OPTS="$DOCKER_OPTS --insecure-registry=${INSECURE_REG}"

# Install docker-compose:
apk add --no-cache py-pip curl
pip install docker-compose

# Verify docker registry:
curl http://${INSECURE_REG}/v2/_catalog #curl does return the expected json

sanitize_cgroups() {
  mkdir -p /sys/fs/cgroup
  mountpoint -q /sys/fs/cgroup || \
    mount -t tmpfs -o uid=0,gid=0,mode=0755 cgroup /sys/fs/cgroup

  mount -o remount,rw /sys/fs/cgroup

  sed -e 1d /proc/cgroups | while read sys hierarchy num enabled; do
    if [ "$enabled" != "1" ]; then
      # subsystem disabled; skip
      continue
    fi

    grouping="$(cat /proc/self/cgroup | cut -d: -f2 | grep "\\<$sys\\>")"
    if [ -z "$grouping" ]; then
      # subsystem not mounted anywhere; mount it on its own
      grouping="$sys"
    fi

    mountpoint="/sys/fs/cgroup/$grouping"

    mkdir -p "$mountpoint"

    # clear out existing mount to make sure new one is read-write
    if mountpoint -q "$mountpoint"; then
      umount "$mountpoint"
    fi

    mount -n -t cgroup -o "$grouping" cgroup "$mountpoint"

    if [ "$grouping" != "$sys" ]; then
      if [ -L "/sys/fs/cgroup/$sys" ]; then
        rm "/sys/fs/cgroup/$sys"
      fi

      ln -s "$mountpoint" "/sys/fs/cgroup/$sys"
    fi
  done
}

# https://github.com/concourse/concourse/issues/324
sanitize_cgroups


# Spin up the stack as described in docker-compose:
docker daemon --insecure-registry=${INSECURE_REG} &
docker-compose up

person David Karlsson    schedule 30.11.2016    source источник


Ответы (1)


dockerd --insecure-registry=${INSECURE_REG}

Это правильный способ запуска демона Docker с незащищенным реестром, хотя он сообщил об ошибках, он получил образы и успешно их запустил.

person David Karlsson    schedule 02.12.2016