Привет, всех с Новым Годом! Праздники праздниками, но пора уже входить в рабочий поток и разгрести локальный техдолг. На этот раз решаем задачку с тремя известными: Windows + WSL + VirtualBox.
Суть такая. Понадобилось мне вхреначить на локальную машину VirtualBox с убунтой, для тестирования фичи, которую писал в этом посте. Фича не хотела заводиться на виртуальных серверах Селектела, хотя и должна была. Потребовалось убедиться, что дело не в моих кривых руках. Ладно, лирика…
Короче цепануться к убунте из wsl по ssh к VirtualBox из коробки не получилось. Да и понятно, подсети разные. Пришлось временно воспользоваться powershell и через ssh проверить гипотезу с cgroup. Винда видит подсеть виртуалки и с этим проблем нет. Проверил, забыл.
Но вопрос остался открытым: как блять/дь малой кровью из WSL (с ubuntu 22.04) подключиться напрямую к виртуалке c ubuntu 22.04 по ssh? И не задрачиваться с таблицами роутинга? Рассказываю!
Чтобы не лезть в маршрутизацию, пришлось воспользоваться стандартным функционалом проброса портов в самом VirtualBox. Жопа конечно знатно сгорела, но желаемого добился.
В общем, пиздуем в настройки VirtualBox: Сеть, Адаптер1. В нем по умолчанию включен NAT. Открываем пункт - Дополнительно, видим кнопку: Проброс портов. Заходим и начинаем заниматьсяочередной хуитой магией.
Сначала роутим на виндовую машину:
Так, теперь в powershell я могу цепануться к виртуалке так:
Оно и ежу понятно, теперь усложняем задачу:
Этой хернёй разрешаем подключение из powershell по такому принципу:
Ага, айпишник
Ну и теперь финальный штрих, прикручиваем WSL:
Айпишник
То есть цепляемся в виндовой/хостовой машине на 22 порт, который уже проброшен. Закидываем public ключи, делаем алиасы для быстрого коннекта. Всё! Дело в шляпе! Мы подключились из WSL (ubuntu) по ssh к виртуальной машине в VirtualBox.
Есть нюанс, у меня дополнительно поднят VPN через wireguard, там еще один фактор с подсетью. Поэтому я добавил еще мусора:
Теперь при активации VPN, подключение к VirtualBox через WSL будет выглядеть так:
Логично, адрес виндовой/хостовой машины меняется с
Я себе сделал 2 алиаса в wsl ~/.zshrc:
Алиасы подключения без ВПН и с ВПН. Ну ты и так про это знаешь. Картинки с настройками залил сюда (открываются нативно в телеграфе), заскриншотил свои поделки. Визуальнее всегда понятнее. Но у меня там дэцл хосты и айпишники по другому обзываются. Не обессудь.
Если знаешь более красивое решение этой задачи с пробросом, сердечно ждем в комментариях.
Ладно, самое время включить режим «День-Тюлень». Еще раз всех с НГ. Увидимся!
tags: #linux #wsl #windows #network
—
💩 @bashdays
Суть такая. Понадобилось мне вхреначить на локальную машину VirtualBox с убунтой, для тестирования фичи, которую писал в этом посте. Фича не хотела заводиться на виртуальных серверах Селектела, хотя и должна была. Потребовалось убедиться, что дело не в моих кривых руках. Ладно, лирика…
Короче цепануться к убунте из wsl по ssh к VirtualBox из коробки не получилось. Да и понятно, подсети разные. Пришлось временно воспользоваться powershell и через ssh проверить гипотезу с cgroup. Винда видит подсеть виртуалки и с этим проблем нет. Проверил, забыл.
Но вопрос остался открытым: как блять/дь малой кровью из WSL (с ubuntu 22.04) подключиться напрямую к виртуалке c ubuntu 22.04 по ssh? И не задрачиваться с таблицами роутинга? Рассказываю!
Чтобы не лезть в маршрутизацию, пришлось воспользоваться стандартным функционалом проброса портов в самом VirtualBox. Жопа конечно знатно сгорела, но желаемого добился.
В общем, пиздуем в настройки VirtualBox: Сеть, Адаптер1. В нем по умолчанию включен NAT. Открываем пункт - Дополнительно, видим кнопку: Проброс портов. Заходим и начинаем заниматься
Сначала роутим на виндовую машину:
Имя: ssh_win
Протокол: tcp
Адрес хоста: 127.0.0.1
Порт хоста: 2222
Адрес гостя: пусто
Порт гостя: 22
Так, теперь в powershell я могу цепануться к виртуалке так:
ssh -p2222 user@127.0.0.1
Оно и ежу понятно, теперь усложняем задачу:
Имя: ssh_win_host
Протокол: tcp
Адрес хоста: 192.168.31.100
Порт хоста: 22
Адрес гостя: пусто
Порт гостя: 22
Этой хернёй разрешаем подключение из powershell по такому принципу:
ssh user@192.168.31.100
Ага, айпишник
192.168.31.100 это адрес, который выдал роутер моей виндовой машине. Как видим уже используется 22 порт. Посмотреть айпишник можно командой ipconfig в терминале powershell. Да простят меня адепты линукса.Ну и теперь финальный штрих, прикручиваем WSL:
Имя: ssh_wsl
Протокол: tcp
Адрес хоста: 172.21.20.123
Порт хоста: 2222
Адрес гостя: пусто
Порт гостя: 22
Айпишник
172.21.20.123 выдан убунте в WSL, смотрим его через ifconfig. А дальше заходим в сам WSL и подключаемся к VirtualBox как к обычному серверу:ssh user@192.168.31.100
То есть цепляемся в виндовой/хостовой машине на 22 порт, который уже проброшен. Закидываем public ключи, делаем алиасы для быстрого коннекта. Всё! Дело в шляпе! Мы подключились из WSL (ubuntu) по ssh к виртуальной машине в VirtualBox.
Есть нюанс, у меня дополнительно поднят VPN через wireguard, там еще один фактор с подсетью. Поэтому я добавил еще мусора:
Имя: ssh_vpn
Протокол: tcp
Адрес хоста: 10.66.64.55
Порт хоста: 22
Адрес гостя: пусто
Порт гостя: 22
Теперь при активации VPN, подключение к VirtualBox через WSL будет выглядеть так:
ssh user@10.66.64.55
Логично, адрес виндовой/хостовой машины меняется с
192.168.31.100 на 10.66.64.55. Но это детали. Еще есть тема, что при включении/выключении VPN вся это тягомотина с пробросом портов подхватывается не сразу. Имей это ввиду.Я себе сделал 2 алиаса в wsl ~/.zshrc:
alias box1="ssh user@192.168.31.100"
alias box2="ssh user@10.66.64.55"
Алиасы подключения без ВПН и с ВПН. Ну ты и так про это знаешь. Картинки с настройками залил сюда (открываются нативно в телеграфе), заскриншотил свои поделки. Визуальнее всегда понятнее. Но у меня там дэцл хосты и айпишники по другому обзываются. Не обессудь.
Если знаешь более красивое решение этой задачи с пробросом, сердечно ждем в комментариях.
Ладно, самое время включить режим «День-Тюлень». Еще раз всех с НГ. Увидимся!
tags: #linux #wsl #windows #network
—
Please open Telegram to view this post
VIEW IN TELEGRAM
Хозяйство вести — не мудями трясти!
ㅤ
Ну дак вот, чтобы твой любимый линукс в
В винде, в папке
Затем перезапустить wsl2 в повершеле:
И после этого твой линукс получит тот же самый айпишник что и хостовая машина (
Ну а там дальше пробрасывай порты и развлекайся как твоей душе угодно.
Раньше жили пиздатее, можно было сделать так:
Где и как можно применить:
- Ты хочешь из винды обратиться к серверу поднятому внутри wsl, без
- Проблемы с випиэн (часто бывает, что при включённом випиэн wsl теряет интернет или не видит другие хосты).
- Когда надо изнутри wsl видеть локальную сеть хоста и взаимодействовать, как обычное приложение винды.
- При разработке серверных приложений, если нужно, чтобы всё вело себя как на обычной машине, а не в изолированной виртуалке.
Ну ты понял. Бери на вооружение, хуйня полезная если правильно применить.
🛠 #linux #networks #windows #wsl
—
✅ @bashdays / @linuxfactory / @blog
ㅤ
Ну дак вот, чтобы твой любимый линукс в
wsl имел такой же айпишник как и хостовая машина, нужно сделать так:В винде, в папке
C:\Users\<user>\ создать файл с названием .wslconfig и запихать в него:[wsl2]
networkingMode=mirrored
Затем перезапустить wsl2 в повершеле:
wsl --shutdown
И после этого твой линукс получит тот же самый айпишник что и хостовая машина (
192.168.0.100), а не виртуальные (172.31.124.159, 10.255.255.254).Ну а там дальше пробрасывай порты и развлекайся как твоей душе угодно.
Режим mirrored включает зеркальный режим сети, при котором wsl использует сетевой стек хоста, а не собственную виртуализированную NAT-сеть.
— wsl и винда имеют один и тот же IP-адрес
— Порты, открытые в wsl, становятся видимыми как будто они открыты на самой винде.
— Локальные сервисы винды и wsl могут легче видеть друг друга без специальных настроек.
— Повышенная совместимость с випиэн, файрволами и корпоративными прокси.
Раньше жили пиздатее, можно было сделать так:
networkingMode=bridge и виртуалка в wsl получала айпишник прям по DHCP. Но в новых версиях винды эту штуку выпилили, видимо на это были свои причины.Где и как можно применить:
- Ты хочешь из винды обратиться к серверу поднятому внутри wsl, без
localhost:port-forward и прочих долбаёбских танцев.- Проблемы с випиэн (часто бывает, что при включённом випиэн wsl теряет интернет или не видит другие хосты).
- Когда надо изнутри wsl видеть локальную сеть хоста и взаимодействовать, как обычное приложение винды.
- При разработке серверных приложений, если нужно, чтобы всё вело себя как на обычной машине, а не в изолированной виртуалке.
Ну ты понял. Бери на вооружение, хуйня полезная если правильно применить.
—
Please open Telegram to view this post
VIEW IN TELEGRAM
3 81
Продолжаем с WSL2
ㅤ
По умолчанию wsl запускается с какими-то своими дефолтными параметрами, будь то память, проц, свап и т.п.
Но все эти параметры можно без труда зареврайтить. Всё это делается через тот же самый файл
Пример:
Здесь я выделил виртуальной машине 2 ядра из 16ти доступных. По умолчанию wsl сразу выгребает 16 ядер и половину памяти.
Хочешь подключить swap? Без проблем! Хочешь указать кастомное ядро? Хуйня! Есть и такой параметр! Про всё остальное почитаешь сам.
Всё это удобно собрано в этой доке, причем на русском языке. Садишься, пробегаешься глазками, вникаешь, закрываешь свои базовые потребности. Удобно!
В общем имей в виду, что даже wsl поддаётся конфигурации.
Пользуйтесь!
🛠 #linux #networks #windows #wsl
—
✅ @bashdays / @linuxfactory / @blog
ㅤ
По умолчанию wsl запускается с какими-то своими дефолтными параметрами, будь то память, проц, свап и т.п.
Но все эти параметры можно без труда зареврайтить. Всё это делается через тот же самый файл
C:\Users\<user>\.wslconfig.Пример:
[wsl2]
processors=2
Здесь я выделил виртуальной машине 2 ядра из 16ти доступных. По умолчанию wsl сразу выгребает 16 ядер и половину памяти.
Таких параметров для тонкой настройки — жопой ешь, под любые твои хотелки и потребности.
Хочешь подключить swap? Без проблем! Хочешь указать кастомное ядро? Хуйня! Есть и такой параметр! Про всё остальное почитаешь сам.
Всё это удобно собрано в этой доке, причем на русском языке. Садишься, пробегаешься глазками, вникаешь, закрываешь свои базовые потребности. Удобно!
В общем имей в виду, что даже wsl поддаётся конфигурации.
Хотя у меня никогда не возникало потребностей что-то менять, дефолтные параметры вполне вменяемые, линуксы не тормозят, всё работает из коробки. Но позадротить иногда хочется и благо для этого есть всё необходимое.
Пользуйтесь!
—
Please open Telegram to view this post
VIEW IN TELEGRAM