Ошибка обновления apt-get с ошибкой 404 в ранее работавшей сборке

Я запускаю сборку Travis, и она не работает при создании образа докера mysql: 5.7.27. Dockerfile запускается apt-get update, а затем я получаю сообщение об ошибке W: Failed to fetch http://deb.debian.org/debian/dists/jessie-updates/main/binary-amd64/Packages 404 Not Found.

Используя curl, я вижу, что он перенаправляется, но URL-адрес перенаправления приводит к ошибке 404. Кто-нибудь видел такое поведение и нашел средство от него? Это практически невозможно исправить, пока debian не внесет изменения?

➜  ms git:(develop) curl --head http://deb.debian.org/debian/dists/jessie-updates/main/binary-amd64/Packages
HTTP/1.1 302 Found
Date: Tue, 26 Mar 2019 16:03:04 GMT
Server: Apache
X-Content-Type-Options: nosniff
X-Frame-Options: sameorigin
Referrer-Policy: no-referrer
X-Xss-Protection: 1
Location: http://cdn-fastly.deb.debian.org/debian/dists/jessie-updates/main/binary-amd64/Packages
Content-Type: text/html; charset=iso-8859-1

➜  ms git:(develop) curl --head http://cdn-fastly.deb.debian.org/debian/dists/jessie-updates/main/binary-amd64/Packages
HTTP/1.1 404 Not Found
Server: Apache
X-Content-Type-Options: nosniff
X-Frame-Options: sameorigin
Referrer-Policy: no-referrer
X-Xss-Protection: 1
Content-Type: text/html; charset=iso-8859-1
Via: 1.1 varnish
Content-Length: 316
Accept-Ranges: bytes
Date: Tue, 26 Mar 2019 16:03:17 GMT
Via: 1.1 varnish
Age: 45
Connection: keep-alive
X-Served-By: cache-ams21028-AMS, cache-cdg20741-CDG
X-Cache: HIT, HIT
X-Cache-Hits: 6, 2
X-Timer: S1553616198.734091,VS0,VE0

person mort    schedule 26.03.2019    source источник
comment
Добро пожаловать, см. Этот пост на U&L: unix.stackexchange.com/questions/508724/   -  person GAD3R    schedule 27.03.2019


Ответы (1)


Это связано с тем, что

Поскольку Wheezy и Jessie были недавно интегрированы в структуру archive.debian.org, мы теперь удаляем все Wheezy и все не-LTS-архитектуры Jessie из зеркальной сети, начиная с сегодняшнего дня.

(Как вы можете прочитать здесь)

Решение (согласно https://github.com/debuerreotype/docker-debian-artifacts/issues/66#issuecomment-476616579) должен добавить эту строку:

RUN sed -i '/jessie-updates/d' /etc/apt/sources.list  # Now archived

в ваш Dockerfile перед вызовом any apt-get update при использовании debian: jessie. Это удалит репозиторий jessie-updates (который теперь вызывает ошибку 404) из sources.list.

Итак, пока следующее не работает:

FROM debian:jessie
RUN apt-get update
CMD /bin/sh

Это работает так:

FROM debian:jessie
RUN sed -i '/jessie-updates/d' /etc/apt/sources.list  # Now archived
RUN apt-get update
CMD /bin/sh
person codinghaus    schedule 26.03.2019
comment
Работает как шарм. Спасибо! - person MFrazier; 16.05.2019
comment
Как это произошло? Похоже, что тысячи людей сталкиваются с этой проблемой на других форумах и в трекерах проблем Git. У меня был очень безобидный Dockerfile, который просто перестал работать. Есть ли что-то, о чем мы должны были знать, чтобы предотвратить ошибку? Или люди Debian просто сознательно сломали у всех контейнеры, а затем надеялись, что они это поймут? - person Neil; 14.07.2019