-
-
Notifications
You must be signed in to change notification settings - Fork 87
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Datachannel connection failing when server running in docker #245
Comments
I guess you are missing to expose the port of the nodejs server? |
Is there something obviously wrong with the configuration I posted (in the spoiler)? |
Yes, you have to expose the tcp port of the singnaling server. Default is 9208. |
I used |
Maybe you can't just copy the files from node:16-slim to gcr.io/distroless/nodejs as the binaries are uncompatible? Try the same image for both steps, maybe 16-bullseye? |
Will try 👍 |
I tried, it didn't change anything :/ |
I tried disabling multiplexing and adding STUN/TURN servers, to no avail. |
I have just dockerized the simple-chat-app. Maybe it helps: |
Actually, it is getting the same error 😵 |
I'm using Windows and WSL, maybe if we deploy it, it will work? |
Yes, I made the simple-chat-app-example work with these steps: server:
local:
|
Hmm i had tried a deploying it via kubernetes on my Linux vps and it had the same problem |
Do you have the entire 1025-65535/udp range open? |
No, just like when running with docker locally, I specified a single port in the server port range and only opened that one. Afaik you cannot open a range in kubernetes 🤔 although I am a novice in kubernetes and might be wrong |
You don't have to open all these ports in k8s, but on the server k8s in running on. I believe. My docker example exposes only 3000/tcp and 10000-10007/udp. But to successfully make a connection (eg with the iceServers) I had to open all udp ports from 1025-65535. |
I don't have any firewall installed on the server (it's not a production server), and it's a managed VPS, so I'd assume all ports are correctly exposed by default |
Unfortunately, I'm out of ideas :/ |
You might want to check out some of the comments about docker and After some digging, the author responded:
and commenter closed the issue with:
I suspect this is not at all an issue with |
At this point I must admit I underestimated how hard it'd be to make geckos work in docker 😅 It not Just Working™ out-of-the-box is sadly a deal breaker for me, as I want users of my game to be able to just launch the server's docker container and be done with it... There may be a way to make it work but I am not competent enough in Docker and WebRTC to reach that point, so I'll just downgrade to using WebSockets 😓 |
Have you checked out Stunner ecosystem for deploying WebRTC apps with k8s? Edit: This is not 100% relevant to the above issue, just thought it was worth flagging. |
Update: This is a bizarre issue, I am now able to reproduce the issue locally, but only on some platforms:
|
Update, after updating Docker for Mac on my M1 from
Before (working)After (not working anymore) |
Note re "using network host mode" to resolve this (i.e: running with Kubernetes host netwrok mode might be worth trying - I think that works on all platforms unlike the docker one. |
Just in case anyone missed it, reverting to Docker Desktop 4.1.1 (MacOS) allowed us to get local dev working again. Tested with Chrome, macOS Big Sur, Docker Desktop 4.1.1, Intel-based MacBook Pro.
(Multiplexing on 9209) |
I'm just wondering if there is any update on this. Oddly I had geckosio working fine with a limited port range around July last year but when revisiting the project I'm running into the same issues as above when deploying as a docker container. |
@dpcartwright just checking:
|
OS: Ubuntu 22.04 LTS / Server At a guess I've gone from Docker version 20.x > 23.x So far I've tried:
None have made any difference. I suspect you might be on to something regarding the Docker version but obviously I'm not keen on permanently reverting to an old version. I think for now I've spent far too much time on what was meant to be a quick resurrection of an old project where I learned how to use phaser and multiplayer :) I really appreciate all the work Yandeu has put into these projects though, so I hope a fix does appear at some point. |
If you're on host networking mode already I'd suggest it's probably something at a higher layer → are other UDP applications working? Do you have ICE/STUN set up? Is the remote client you're connecting from behind a Strict NAT network? Is the host? etc. |
Just to add to this, I don't believe the "docker-example" repo that's available works either, failing for the same exact reason, as far as I can tell. Fresh install of it, docker build, run, and check url: doesn't establish connection. |
The dockerized simple-chat-app-example works, but not on Windows. Not using WSL nor without. |
Just saw this video, but haven't tried it yet. |
Oh, this would make a lot of sense |
I tried it but have the same issue as here microsoft/WSL#10495. wsl: Hyper-V firewall is not supported
wsl: Mirrored networking mode is not supported, falling back to NAT networking |
I think you need the window 11 insider build for it to work - personally, I'm still on windows 10, haven't had the time to upgrade the system and my workflows. |
I'd just like to add to the discussion - I'm running my geckos game in k8s using https://github.com/l7mp/stunner. Works very well. |
Nice one - thanks @bananu7 will check it out. re: kubernetes -> agones.dev was very easy to setup with geckos. Decided on ECS/Fargate in the end for cost, but for a larger project/team would recommend looking into that |
Ok, I thought I was going crazy. It's still not working August 2024. Running a stand-alone geckos server in docker container. Have all the TCP/UDP required ports onpened on the docker run line. Any attempted to connect gets an error connection refused. Any progress on this? |
AFAIK its not so much a geckos.io issue as a webrtc ICE resolution issue 💁♀️ |
I tried out running my app in docker, and while the signaling server works fine (a log from the
authorization
method is printed), the data channel seems to never open (log inonConnection
never printed).I've been careful to only use one port and publish it in docker
Port configuration
My Dockerfile:My geckos port range:
My command to start the container:
docker run --rm -p 6969:6969 -p 9696:9696/udp arthuro5555/thnk-relay
Running it with node directly works. I am guessing this must be a misunderstanding/misconfiguration on my side, but I report this as a bug just in case.
I am getting this issue both on my windows machine with docker desktop as on my linux server (running through k3s)
The text was updated successfully, but these errors were encountered: