I use Crafty Controller for Minecraft. I have a server running at 192.168.50.16:25540. I want it to resolve to minecraft.example.com. I have Nginx Proxy Manager setup for my domain and can access it from inside my network, but it’d be nice to be able to use a domain instead.

NPM only has options for http and https, so is this even possible using NPM?

EDIT: this is for only internal access I have external access via tailscale.

  • Possibly linux@lemmy.zip
    link
    fedilink
    English
    arrow-up
    11
    ·
    3 months ago

    No

    Reverse proxies like you are talking about are only for http connections. For more information look at the OSI model. (The proxy is operating on the application layer while Minecraft is on the transport layer)

    Instead use DNS to resolve the domain name to an IP. Better yet, just set a static IP.

    • redxef@feddit.org
      link
      fedilink
      English
      arrow-up
      6
      ·
      3 months ago

      There are minecraft reverse proxies, so, yes, a http proxy will not work, but the general idea is still viable and doable with very little effort.

      Set up a few domains all resolving to one IP. Run itzg/minecraft-router and use that to proxy the traffic to different servers based on the domain.

      Also, they don’t even need a reverse proxy, but just resolve the domain name to the IP (in the simple case of one domain name per I0). That can be accomplished by hosting their own dns server, editing the hosts file or just pointing a public dns record at the private ip address, which will only work in their network,l.

  • edb_fyr@lemmy.world
    link
    fedilink
    English
    arrow-up
    7
    ·
    3 months ago

    If you were using the default port 25565, you could simply have a DNS A record pointing to the server IP. But since that is not the case, you have to additionally set up a SRV record in your DNS. NOIP describes what this is and how to set it up on their service here, but it will of course differ for your DNS provider.

    This still requires that the Minecraft server port is directly accessible from the other clients, but it sounds like that is not the problem

    • Possibly linux@lemmy.zip
      link
      fedilink
      English
      arrow-up
      4
      ·
      3 months ago

      Technically they could use a Nginx stream to forward traffic but I wouldn’t recommend that as it adds latency and overhead.

  • Björn Tantau@swg-empire.de
    link
    fedilink
    English
    arrow-up
    2
    arrow-down
    1
    ·
    3 months ago

    NPM won’t help you here. As you said, it’s only for http. You will have to set up port forwarding in your router. But as far as I recall Minecraft changes its port with every game. So you could either change that in your router every time you start another game.

    But it would be better (for security as well) to set up a VPN. Many routers actually have that built in.

    That is, if your goal is to have your Minecraft server reachable through the internet.

    For DNS you will need a Dynamic DNS service to let the name always point to your public IP. For this as well many routers have built-in functionality. Maybe even a preferred service.

    • Dust0741@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      1
      ·
      3 months ago

      With Crafty you can bind a specific port.

      I use tailscale for public access, and have set it up so tailscale users can access the domain.

      I guess what I’m asking for is NPM but for tcp.

  • zelifcam@lemmy.world
    link
    fedilink
    English
    arrow-up
    1
    ·
    3 months ago

    it’d be nice to be able to use a domain instead.

    If your looking to access it outside your LAN, you’re gonna want to open up the correct ports on your router’s firewall.

    • Dust0741@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      1
      ·
      edit-2
      3 months ago

      No I’m not.

      I have tailscale setup for external access. (I have dns records already in my domain provider pointing to a tailscale ip, so a device on my tailnet can access my domain. ie an authorized tailscale device can access nginx.example.com)

      I want to know what I have to do to get minecraft.example.com to resolve interenally.

      • zelifcam@lemmy.world
        link
        fedilink
        English
        arrow-up
        2
        ·
        edit-2
        3 months ago

        I have to admit, I’m a bit confused.

        I have dns records already in my domain provider pointing to a tailscale ip

        I want to know what I have to do to get minecraft.example.com to resolve interenally.

        Since your domain resolves to an internal private Tailscale IP and your question is how to access using the domain, locally…. I feel like there’s an error in your architecture here. Wouldn’t any device that is on your Tailscale private network already have access using the domain name? If by “resolve internally” you mean hosts on your LAN, not connected to Tailscale scale? How would that be possible if it resolves to a Tailscale IP. If you have control of your DNS on your LAN, you could simply add an override and point it to the LAN address of the Minecraft server.