Вопрос apt-get застрял в 0 [Подключение к us.archive.ubuntu.com]


Когда я обновляюсь, он застрял здесь:

user@plato:~# sudo apt-get upgrade
Reading package lists... Done
Building dependency tree       
Reading state information... Done
Calculating upgrade... Done
The following packages will be upgraded:
  bind9-host coreutils cpio curl dnsutils libbind9-90 libc-bin libc-dev-bin
  libc6 libc6-dev libcgmanager0 libcurl3 libcurl3-gnutls libdns100
  libdrm-intel1 libdrm-nouveau2 libdrm-radeon1 libdrm2 libisc95 libisccc90
  libisccfg90 libjasper1 liblwres90 libplymouth2 libsepol1 libssl-dev
  libssl-doc libssl1.0.0 linux-libc-dev mime-support multiarch-support ntp
  ntpdate openssl plymouth plymouth-theme-ubuntu-text python3-distupgrade
  ubuntu-release-upgrader-core unzip
39 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.
Need to get 16.0 MB of archives.
After this operation, 12.3 kB of additional disk space will be used.
Do you want to continue? [Y/n] y
0% [Connecting to us.archive.ubuntu.com (2001:67c:1562::15)] ░

Когда я обновляюсь, он застрял здесь:

user@plato:~# apt-get update
0% [Connecting to us.archive.ubuntu.com (2001:67c:1562::14)] [Connecting to sec░

Я могу ping us.archive.ubuntu.com просто отлично:

user@plato:~# ping us.archive.ubuntu.com
PING us.archive.ubuntu.com (91.189.91.23) 56(84) bytes of data.
64 bytes from economy.canonical.com (91.189.91.23): icmp_seq=1 ttl=54 time=81.5 ms
64 bytes from economy.canonical.com (91.189.91.23): icmp_seq=2 ttl=54 time=81.5 ms
64 bytes from economy.canonical.com (91.189.91.23): icmp_seq=3 ttl=54 time=81.5 ms
64 bytes from economy.canonical.com (91.189.91.23): icmp_seq=4 ttl=54 time=81.4 ms
^C
--- us.archive.ubuntu.com ping statistics ---
4 packets transmitted, 4 received, 0% packet loss, time 3004ms
rtt min/avg/max/mdev = 81.425/81.528/81.582/0.355 ms

Что я могу сделать, чтобы исправить это?


То, что я пробовал до сих пор.

Я пробовал следующие направления в этом блоге: http://nickescobedo.com/719/ubuntu-apt-get-hangs-at-0

Чтобы заставить apt-get использовать IPv4 исключительно

  • Создайте файл в /etc/apt/apt.conf.d/99force-ipv4
  • Добавьте эту строку во вновь созданный файл Acquire::ForceIPv4 false;
  • Теперь Apt-get будет использовать только IPv4

149
2018-01-16 23:04


происхождения


Ни один из ответов не работал для меня: моя проблема заключалась в моем хосте Windows брандмауэр блокируя мой гостевой Ubuntu, работающий в Virtualbox. - drodsou
Ни один из этих ответов не работал для меня. Я перезапустил свою виртуальную машину, и теперь она работает. - kilojoules


ответы:


Я понял, как получить apt-получить работу снова.

редактировать gai.conf:

sudo vim /etc/gai.conf

изменить строку ~ 54, чтобы раскомментировать следующее:

precedence ::ffff:0:0/96  100

написать и выйти:

:wq

ВНИМАНИЕ

Посмотрите линию 50, которая выглядит почти идентично:

precedence ::ffff:0:0/96  10

Это неправильная линия. Пойдите ~ 4 линии вниз, и вы найдете правильную линию для раскола, потому что она заканчивается 100 вместо 10


261
2018-01-18 17:23



Благодарим вас за отправку решения. У меня была такая же проблема, и это было исправлено. - bradym
Как на Земле вы это поняли? Это внезапно началось со мной на одном из моих серверов, и это исправило это. - Brian Neal
Что здесь происходит? Позаботьтесь о том, почему это исправление работает? - four43
Проблема: Интернет-провайдеры начинают настраивать внутреннюю сеть IPv6, готовясь к подключению к Интернету IPv6. В результате серверы в этой сети теперь пытаются подключиться к * .ubuntu.com через свой IPv6-адрес по умолчанию при запуске apt-get. Решение: раскомментировав precedence ::ffff:0:0/96 100 позволяет запросить предпочтение IPv4 - Arian Faurtosh
ИСПРАВЛЕНО! Это, безусловно, правильное решение этой проблемы. Но для тех, кто сталкивается с этим исправлением, убедитесь, что вы НЕ делаете то, что я сделал. Я раскопан precedence ::ffff:0:0/96 10 и мне пришлось вернуться к файлу и снова прокомментировать эту строку, а затем раскомментировать правильную строку, которая precedence ::ffff:0:0/96 100 - dtigue


Лучше отключить IPV6 перед обновлением и обновлением.

  1. Открытый терминал

  2. Войти sudo -H gedit /etc/sysctl.conf и откройте файл конфигурации и добавьте следующие строки в конце

    net.ipv6.conf.all.disable_ipv6 = 1
    net.ipv6.conf.default.disable_ipv6 = 1 
    net.ipv6.conf.lo.disable_ipv6 = 1 
    
  3. После этого

    cat /proc/sys/net/ipv6/conf/all/disable_ipv6 
    

    Если сообщение «1» означает, что вы отключили IPV6.

    Если он сообщает «0», пожалуйста, выполните шаги 4 и 5.

  4. Команда типа sudo sysctl -p, Вы увидите это в терминале.

    net.ipv6.conf.all.disable_ipv6 = 1 
    net.ipv6.conf.default.disable_ipv6 = 1 
    net.ipv6.conf.lo.disable_ipv6 = 1 
    
  5. Повторите выше «Шаг 3», и теперь он сообщит 1.


9
2018-05-06 07:52



Этот шаг сработал, спасибо :-) - Aritra Chatterjee


Ни один из исправлений IPv6 не работал для меня. Возможно, у меня такой же симптом с другой причиной. Моим обходным путем было перейти на другой архив, выполнив поиск и заменив в sources.list, например:

sudo vim /etc/apt/sources.list

А потом:

:%s/us\.archive/de\.archive/g
:wq

Это, по крайней мере, позволяет мне вернуться к работе, пока не выясню реальную проблему.


4
2018-01-13 11:30





Что для меня работало, так это переключить настройки моей VirtualBox Network для моего гостевого Ubuntu на «NAT» из «Мостового адаптера».


0
2018-02-10 20:20



Да, это обязательно сработает. Но почему он не работает над «Bridged Adapter». Я могу сделать все с помощью «Мостового адаптера», кроме apt-get update, - soufrk