Важно! |
---|
Описываемая ниже ветка netstack не совместима с Yggdrasil v. 0.5 и разработчики не планируют дальнейшую её поддержку. Скрин переписки в чате Yggdrasil от 21.05.2023: Альтернатива: отдельный проект yggstack (работает аналогично). |
Разработчикам Yggdrasil в чате периодически задают вопрос о возможности запуска Yggdrasil без создания tun-интерфейса. В качестве аргумента за такой подход приводят значительное упрощение встраивания Yggdrasil в другие проекты, например, в браузер или даже в web-приложение…
И вот, в качестве эксперимента, один из разработчиков Yggdrasil (neilalexander) создал ветку проекта, в которой не используется tun-интерфейс и реализован стек сетевых протоколов, который позволяет использовать Yggdrasil в качестве socks5-прокси.
Отличительные особенности такого подхода:
Кроме описанного выше, в ветке netstack реализована встроенная система DNS. C помощью этой системы можно получить доступ к ресурсам по доменному имени вида <публичный ключ>.pk.ygg
.
Для примера, адрес этой wiki будет выглядеть так: http://000000002ae375e65f5470ee29eb563a0ada764c7a3f1efaa5f5a4af91dad1cb.pk.ygg/ (доступно через socks-прокси ветки netstack).
Готовых бинарников нет, приложение собирается из исходников.
Примечание: для сборки необходим go-lang. Читайте об его установке: Установка Go.
Непосредственно сборка:
git fetch origin netstack && git checkout netstack go build -o yggstack cmd/yggstack/main.go
Параметры socks-прокси и расшаривания/проброса TCP-портов задаются в командной строке.
Пример:
./yggstack -useconffile=/etc/yggdrasil.conf -socks :1080 -exposetcp 80:127.0.0.1:8080
Socks-прокси будет ожидать соединение на порту 1080 (указывается в браузере); из вне становится доступным порт 80, который пробрасывается на порт 8080 localhost (предполагается, на localhost:8080 будет работать web-сервер).
Ветка netstack (EN): https://github.com/yggdrasil-network/yggdrasil-go/tree/netstack
Канал telegram Popura (RU): https://t.me/PopuraChan/137
Обсуждение
Опыта особо нет с прокси, как лучше сделать чтобы интернет и yggdrasil работали через браузер?
По сути нужна маска :443 или *.*.*.* но такое не поддерживается, пока работает только *.com
https://www-archive.mozilla.org/quality/networking/docs/aboutno_proxy_for
Можно погуглить расширение для браузера, которое так же, в зависимости от адреса, будет пускать либо через прокси, либо напрямую.
Либо погуглите, как на узле Yggdrasil (который socks) настроить маршрутизацию 6to4 для универсального доступа в интернет.
По идее оно фильтрует до резольва, отсюда заминка. Только хостнейм :/
получается нет особого смысла в yggstack кроме как отсутствие рута или ограничения виртуализации