Предполагая, что я получил учетные данные ecr от boto уже в объекте, называемом creds, когда я делаю:
client = from_env()
client.login(creds.username, password=creds.password, registry=creds.endpoint)
Я получаю:
{u'IdentityToken': u'', u'Status': u'Login Succeeded'}
Отлично!И я проверяю:
client.api.__dict__
Я получаю:
{'_auth_configs': {'auths': {'registry_i_just_logged_into': {'email': None,
'password': 'xxxxxxxxxxxxx',
'serveraddress': 'registry_i_just_logged_into',
'username': 'xxxxxxx'},
u'some_other_registry': {},
'credsStore': u'osxkeychain'}
.... (etc, etc)
Все еще так хорошо.Но когда я тогда делаю:
client.images.pull("registry_i_just_logged_into/some_repo", tag="latest")
Или когда я делаю (из командной строки):
docker pull registry_i_just_logged_into/some_repo:latest
Я всегда получаю:
Error response from daemon: pull access denied for some_repo, repository does not exist or may require 'docker login'
Несмотря наДело в том, что если я делаю (с тем же именем пользователя и паролем, которые я использовал для входа в систему):
client.images.pull("registry_i_just_logged_into/some_repo", tag="latest", auth_config={'username': creds.username, 'password': creds.password})
Работает без проблем.
Так что я предполагаю, что это проблема спорядок определения того, какой реестр использовать, но, похоже, докер sdk должен обработать это, если ключ уже существует в _auth_configs.
Что я делаю не так?
Спасибо!