Ответы:
Возможным решением может быть использование tsocks
приложения, которое может перенаправлять сетевой трафик через прокси-сервер socks. Установите tsocks
пакет, измените, /etc/tsocks.conf
чтобы установить адрес и номер порта вашего прокси-сервера socks, и запустите:
$ sudo -s
# tsocks apt-get update
# tsocks apt-get dist-upgrade
# exit
$
или
$ sudo -s
# . tsocks -on
# apt-get update
# apt-get dist-upgrade
# . tsocks -off # not really necessary, given the exit
# exit
$
Можно продумать ряд вариантов, упростить и автоматизировать его использование.
Не забывайте начальную точку, у Manpage есть больше подробностей по этому вопросу.
Изменить : более короткий способ использовать его:
$ sudo tsocks apt-get update
$ sudo tsocks apt-get dist-upgrade
tsocks
, установки, а затем использовать :)
apt-get something
!
Acquire::socks::Proxy "socks5h://hostname:port/";
делает свое дело. Http вовсе не - попробуйте с Tor и вы увидите стандартный ответ «Tor не является HTTP - прокси», поэтому http
идет заменен socks
- и это работает!
Acquire::http::proxy "socks5h://server:port";
Это работает для меня на Ubuntu 18.04. Как говорится на странице руководства, apt поддерживает socks5h, а не socks5, что означает прокси socks5 с возможностью разрешения DNS.
Acquire::https::proxy "socks5h://server:port";
в apt.conf.d
файл (вроде /etc/apt/apt.conf.d/12proxy
) работает просто отлично. Я бы предложил придерживаться https, если не требуется иное.
Acquire::http::proxy "socks5h://user:pass@server:port";
. Вышеуказанное правило отлично работает в Ubuntu 18.04. Здесь socks5h
применяется разрешение DNS на прокси-сервере.
Использование следующей строки конфигурации работает для меня:
Acquire::socks::proxy "socks5://server:port";
Чтобы сохранить apt.conf
чистоту и избежать проблем при обновлении Linux, я создал новый файл ( /etc/apt/apt.conf.d/12proxy
) и добавил к нему файл конфигурации.
Я не смог найти ничего о Acquire :: socks :: proxy в руководстве по apt.conf для Ubuntu Xenial. Это можно исправить, запустив локальный http-прокси-сервер, который поддерживает прокси-серверы верхнего уровня, например Polipo. Вам необходимо настроить Polipo следующим образом:
proxyAddress = "::1"
proxyPort = 8118
socksParentProxy = "sockshost:socksport"
socksProxyType = socks5
а затем установите http прокси в вашем файле apt.conf:
Acquire::http::proxy "http://127.0.0.1:8118/";
Acquire::https::proxy "https://127.0.0.1:8118/";
Или вы можете вставить в ваш /etc/apt/apt.conf что-то вроде этого:
Acquire::socks::proxy "socks://user:pass@host:port/";
Acquire::http::proxy "socks://user:pass@host:port/";
Acquire::socks
это для настройки прокси для URL, которые начинаются с socks://
. Так что средства вам не нужен прокси - сервер для доступа в Интернет, а также apt
не использует прокси - серверы для ftp://
, http://
или https://
.. apt
поддерживает только HTTP прокси, то есть Acquire::http::proxy "http://localhost:8118
.
В Debian вы можете прочитать man-страницу apt-transport-http(1)
и найти поддерживаемые схемы URI. Как ответили раньше, поставь
Acquire::http::proxy "socks5h://server:port";
в
/etc/apt/apt.conf.d/12proxy
Вы можете прочитать больше о APT-config в целом apt.conf(5)
и прочитать примеры, /usr/share/doc/apt/examples/configure-index.gz
упомянутые в конце руководства.
Это можно комбинировать с ssh -D <LOCAL PORT> <USER>@<HOST>
созданием прокси-сервера SOCKS в другой системе, чтобы apt мог затем использовать прокси-сервер так, как если бы все происходило <HOST>
.
Если вы используете ssh -D 0.0.0.0:<LOCAL PORT> <USER>@<HOST>
или ssh -D [::]:<LOCAL PORT> <USER>@<HOST>
(для IPv6), чтобы другие системы могли использовать прокси-сервер SOCKS на всех интерфейсах. Это может быть угрозой безопасности или нарушением (корпоративной) политики. Убедитесь, что вы знаете, что делаете.
sudo tsocks apt-get install tsocks
. Хахахахахаха ...