Загрузка...

Создание приватного докер-репозитория

  • Исходные данные: есть свой vds, установленный на нём docker, docker-compose и веб-сервер nginx
  • Задача: сборка приватного Docker-реестра на своём сервере
  • Цель: хранение собственных docker-образов в реестре, для последующего их развертывания на любом сервере

Предположим что домен example.com. Тогда делаем на поддомене registry.example.com. Получаем для него первые сертификаты, например Let'sEncrypt (например самой простой командой ./certbot-auto certonly --standalone --preferred-challenges http -d registry.example.com), так как это требование докер-реестра, чтобы он работал по ssl.

Заводим на него nginx-конфиг:

server {
    listen 443 ssl;
    server_name registry.example.com;

    # if your SSL is Let'sEncrypt:
    ssl_certificate /etc/letsencrypt/live/registry.example.com/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/registry.example.com/privkey.pem;
    ssl_trusted_certificate /etc/letsencrypt/live/registry.example.com/chain.pem;

    # Recommendations from https://raymii.org/s/tutorials/Strong_SSL_Security_On_nginx.html
    ssl_protocols TLSv1.1 TLSv1.2;
    ssl_ciphers 'EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH';
    ssl_prefer_server_ciphers on;
    # if you want option:
    #ssl_session_cache shared:SSL:10m;

    # disable any limits to avoid HTTP 413 for large image uploads
    client_max_body_size 0;

    # required to avoid HTTP 411: see Issue #1486 (https://github.com/moby/moby/issues/1486)
    chunked_transfer_encoding on;

    location /v2/ {
          # Do not allow connections from docker 1.5 and earlier
          # docker pre-1.6.0 did not properly set the user agent on ping, catch "Go *" user agents
          if ($http_user_agent ~ "^(docker\/1\.(3|4|5(?!\.[0-9]-dev))|Go ).*$" ) {
            return 404;
          }

          # To add basic authentication to v2 use auth_basic setting.
          auth_basic "Registry realm";
          auth_basic_user_file /etc/nginx/secret/nginx.htpasswd;

          ## If $docker_distribution_api_version is empty, the header is not added.
          ## See the map directive above where this variable is defined.
          # if you want option:
          #add_header 'Docker-Distribution-Api-Version' $docker_distribution_api_version always;

          proxy_pass                          http://localhost:5000;
          proxy_set_header  Host              $http_host;   # required for docker client's sake
          proxy_set_header  X-Real-IP         $remote_addr; # pass on real client's IP
          proxy_set_header  X-Forwarded-For   $proxy_add_x_forwarded_for;
          proxy_set_header  X-Forwarded-Proto $scheme;
          proxy_read_timeout                  900;
    }
}

Затем делаем базовую авторизацию, кладём пароль в /etc/nginx/secret/nginx.htpasswd, так как в конфиге мы указали данный путь:

sudo htpasswd -c /etc/nginx/secret/nginx.htpasswd your_login

Заводим в каком-нибудь, например, /var/www/registry.example.com файл docker-compose.yml и каталог registry:

version: '3'
services:
    registry:
        image: registry:2
        restart: always
        ports:
            - "5000:5000"
        volumes:
            - ./registry:/var/lib/registry
volumes:
    registry:

Перезапускаем веб-сервер, затем в терминале /var/www/registry.example.com поднимаем реестр:

docker-compose up

Проверяем что базовая авторизация включена, просто заходим на https://registry.example.com/v2, должно выдать окно с вводом логина и пароля.

Если всё нормально, то логинимся у себя на локалке, где вы строите цикл разработки и деплоя, основанный на докере, командой:

docker login -u your_login -p your_password registry.example.com

После успешной авторизации, должно выдать Login Succeeded, а ваш /home/user/.docker/config.json должен запомнить что-то вроде этого:

{
        "auths": {
                "registry.example.com": {
                        "auth": "HASH"
                }
        },
        "HttpHeaders": {
                "User-Agent": "Docker-Client/Your-System"
        }
}

Затем уже можно пушить готовые образы. Удачи!



Похожие заметки:

Настройка сервера

Услуги » Настройка веб-сервера

Регистрация, настройка с моей стороны VDS сервера в соответствии с выбраным вами тарифом

Открыть здесь

Да здравствует Ябунта!

Да, настал момент! Попиарю немного вот этого хостера, ибо есть за что. Переустановил ОС на VDS, поставил новенькую Ubuntu-16.04 c nginx + php-fpm (про прирост производительности можно не говорить, это факт)

Открыть здесь

Веб-разработка

Займусь вашим проектом, если вам нужен специалист в области веб-разработки

Открыть здесь


Перед тем как писать комментарии, рекомендую ознакомиться:

Markdown синтаксис »

Оформление кода »

Нужна аватарка »

Комментарии