Одноразовый вариант
Открываем туннель между вашим внешним серваком, который будет запросы со своего 6666 порта направлять к вам на localhost:3000
ssh root@server.ru -R6666:localhost:3000
Вас запустит на сервак и пока будет активно ваше ssh соединение, туннель будет работать. Затем надо подкорректировать nginx конфиг на внешнем серваке.
server {
listen 443 ssl;
server_name server.ru;
location / {
proxy_pass http://localhost:6666;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-Forwarded-Host $http_host;
}
}
Более основательный подход для создания туннеля.
# https://stackoverflow.com/a/15198031
% ssh -M -S expose.socket -fnNT -R 6666:localhost:3000 root@server.ru
% ssh -S expose.socket -O check root@server.ru
Master running (pid=71660)
% ssh -S expose.socket -O exit root@server.ru