PIP случайным образом завершается с ошибкой «Не удалось найти версию, которая удовлетворяет требованию» с теми же требованиями. - PullRequest
8 голосов
/ 14 июня 2019

В рамках нашего тестирования CI мы устанавливаем virtualenv с некоторыми пакетами pip из файла константы require.txt.

этот процесс установки время от времени происходит случайно, без видимой причины, так как файл require.txt не изменяется. И каждый раз это для другого случайного пакета.

CI находится на компьютере AWS, поэтому я не думаю, что это может быть проблема с интернетом

Ошибка выглядит примерно так (с ошибкой другого пакета):

Collecting django-rest-auth==0.9.3 (from -r requirements.txt (line 7))
Could not find a version that satisfies the requirement django-rest-auth==0.9.3 (from -r requirements.txt (line 7)) (from versions: )
No matching distribution found for django-rest-auth==0.9.3 (from -r requirements.txt (line 7))

Или

Collecting py>=1.5.0 (from pytest->-r requirements.txt (line 15))
Could not find a version that satisfies the requirement py>=1.5.0 (from pytest->-r requirements.txt (line 15)) (from versions: )
No matching distribution found for py>=1.5.0 (from pytest->-r requirements.txt (line 15))

РЕДАКТИРОВАТЬ: Попытка добавить --timeout 30 --retries 15, который, кажется, ничего не меняет

Ответы [ 4 ]

9 голосов
/ 14 июня 2019

У меня такая проблема, когда у меня сильная зависимость, поэтому я обновил тайм-аут для пункта и проблема решена. т.е. мой .pip / pip.conf имеет тайм-аут 30 секунд

[global]
timeout = 30
5 голосов
/ 01 июля 2019

(from versions: ) - большая подсказка.Он исходит из этой строки в исходном коде pip.Тот факт, что после versions: ничего не указывается, означает, что pip не смог найти ни одной версии djanto-rest-auth в индексе pypi.Не берите в голову версию, которую просит ваш requirements.txt.Эта проверка приходит позже.

Вот как это должно выглядеть versions: при попытке установить то, что не может быть найдено:

> pip install django-rest-auth==29.42  # ridiculous version that won't be found
Error: Could not find a version that satisfies the requirement django-rest-auth==29.42
(from versions: 0.9.4.macosx-10.14-intel, 0.1, 0.2, 0.2.1, 0.2.2, 0.2.3, 0.2.4, 
0.2.5, 0.3.0, 0.3.1, 0.3.2, 0.3.3, 0.3.4, 0.4.0, 0.5.0, 0.6.0, 0.7.0, 0.8.0,
0.8.1, 0.8.2, 0.9.0, 0.9.1, 0.9.2, 0.9.3, 0.9.5)

Единственный способ versions: можетбудет пустым, если подпрограмма find_all_candidates возвращает пустой список.find-all-candidates должен возвращать список с каждой версией пакета, выпущенного на pypi.org.

Я не знаю, почему эта подпрограмма случайным образом возвращает пустой список в вашем окне CI, но я догадываюсь, что он включает код , который очищает https://pypi.org/simple/django-rest-auth/ для ссылок.Возможно, он время от времени возвращает пустую HTML-страницу.

Вот несколько вещей, которые вы можете сделать для отладки

  • Запуск pip с флагом --verbose.Это активирует некоторую регистрацию URL и ссылок, которые могут быть полезны.
  • ssh на ваш CI сервер и найдите site-packages/pip/_internal/index.py.Отредактируйте его и добавьте дополнительные записи, чтобы помочь вам отладить.Я бы начал с регистрации содержимого HTML, которое он возвращает с pypi.org.
  • Если вам повезет и вы найдете способ повторить проблему, используйте pdb для отладки pip на вашем CI-сервере.

Вот пример дополнительной регистрации, которую вы получаете с --verbose.Действительно любопытно, как это выглядит, когда происходит твой глюк:

Collecting django-rest-auth==29.42
-------------------------------------------------------
  1 location(s) to search for versions of django-rest-auth:
  * https://pypi.org/simple/django-rest-auth/
  Getting page https://pypi.org/simple/django-rest-auth/
  Looking up "https://pypi.org/simple/django-rest-auth/" in the cache
  Request header has "max_age" as 0, cache bypassed
  Starting new HTTPS connection (1): pypi.org:443
  https://pypi.org:443 "GET /simple/django-rest-auth/ HTTP/1.1" 200 2467
  Updating cache with response from "https://pypi.org/simple/django-rest-auth/"
  Caching due to etag
  Analyzing links from page https://pypi.org/simple/django-rest-auth/
    Found link https://files.pythonhosted.org/packages/c8/ff/cffe8cb7961a1665f20115adb035d23a6b1cb08a2a6c1d6de802b13cdcc9/django-rest-auth-0.1.tar.gz#sha256=fcb9feced7f066c92a5f29f2930609316095a7abe3806e09c3d63c36c3607780 (from https://pypi.org/simple/django-rest-auth/), version: 0.1
    Found link https://files.pythonhosted.org/packages/af/d2/5d37d3f1c7055284b969e2de8eaf7d7dc16b51fba94f3325d92d053e12a8/django-rest-auth-0.2.tar.gz#sha256=04ae1a5d991692293ec95a10b517bdb26b41823a645400dc0b899d9f538013b9 (from https://pypi.org/simple/django-rest-auth/), version: 0.2
    Found link https://files.pythonhosted.org/packages/46/87/816fcc68a4552916cb82eef40dfd1bd752f831a329e927b96b7f9c6c0db7/django-rest-auth-0.2.1.tar.gz#sha256=3306e739bb8f34d47285c9e1616f75a9d8b4f6985102d68509d5aec5af62c760 (from https://pypi.org/simple/django-rest-auth/), version: 0.2.1
... about 20 more of these

Удачи.Извините, я не смог дать вам точное решение.

2 голосов
/ 27 июня 2019

Проблема: Возможно, это проблема с вашим питоном и другими версиями библиотек.Может быть, вашему колесу django требуется какая-то другая библиотека, которая установлена ​​в вашей среде anaconda, но не удовлетворяет версии.когда вы используете команду pip, он просто пытается загрузить колесо, не заботясь о версии, и если версия не совпадает, просто выдайте нам ошибку.

Попробуйте использовать команду conda, потому что команда conda обновит вашу версию в соответствии с требованиями.когда вы используете команду conda, она загрузит библиотеку для всех сред, которые вы используете в навигаторе anaconda.Но Pip будет устанавливать только библиотеку, из которой вызывается команда окружения.

Решение: попробуйте установить эту библиотеку, используя команду conda, например

conda install django-rest-auth==0.9.3

Эта команда поможетрешить ошибку версии.

1 голос
/ 01 июля 2019

Прежде всего, это не редкость, чтобы получить ошибку.Во-вторых, случайный модуль, который он устанавливает, находится в файле require.txt модуля в вашем файле needs.txt.

Решение: Во-первых, выполните поиск в модуле Google.Затем перейдите на сайт модуля и установите его.Это может занять много времени, но просто наберитесь терпения!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...