Title. I looked at how to configure anything and found Caddy to be much easier to use. Aside from a lot of docker images integrating with it, why is everyone using it? Edit: I meant Traefik

  • fenndev@leminal.space
    link
    fedilink
    English
    arrow-up
    77
    ·
    6 months ago

    Tailscale is a VPN. Caddy is a reverse proxy. I’m not sure why you’re comparing the two, unless you meant Traefik?

  • Xanza@lemm.ee
    link
    fedilink
    English
    arrow-up
    23
    ·
    6 months ago

    A reverse proxy like Caddy or Nginx is like a bouncer for your web services. It sits out front, deciding who gets in and where they’re allowed to go. It’s great for stuff you want to expose to the internet – like a website or web app – because it hides your actual servers, can handle HTTPS for you, and lets you set up some basic access rules.

    A VPN is more like a secret underground tunnel between you and your server. Everything that goes through it is locked down to only members of the VPN. This is what you want when you’re dealing with private stuff you don’t want exposed to the open internet, like your home lab dashboard or some internal tools. The beauty of a VPN is that it works for everything–not just web traffic. SSH, file transfers, databases. All of it gets the same protection.

    • irmadlad@lemmy.world
      link
      fedilink
      English
      arrow-up
      4
      ·
      6 months ago

      works for everything–not just web traffic. SSH, file transfers, databases.

      Yup. I use it for sftp, ssh. I’ve never used in relation to a database. Is that for remote db? I am working on routeing mail through tailscale to a relay, since my host, for whatever reason, blocks mail ports and charges to have them turned on. I just wanted alert emails from a couple apps.

      • Xanza@lemm.ee
        link
        fedilink
        English
        arrow-up
        3
        ·
        edit-2
        6 months ago

        I am working on routeing mail through tailscale to a relay, since my host, for whatever reason, blocks mail ports and charges to have them turned on.

        Should work fine. Your provider can’t stop you from opening ports unless its a shared environment and you don’t have permission/the port is already in use. Generally what they do is just block connections via a router/firewall. So if you use a VPN you’re sidestepping that issue. With the VPN in place, and the server online and running you should be able to connect via {VPN_IP}:995, etc.

  • korn@feddit.org
    link
    fedilink
    English
    arrow-up
    19
    arrow-down
    1
    ·
    edit-2
    6 months ago

    First of all: not everyone can publish port 80/443 or even has a public IP.

  • Onomatopoeia@lemmy.cafe
    link
    fedilink
    English
    arrow-up
    13
    ·
    edit-2
    6 months ago

    Because I don’t need a reverse proxy?

    Also, as for ease of setup, with Tailscale I install an app and login. Done.

  • Cousin Mose@lemmy.hogru.ch
    link
    fedilink
    English
    arrow-up
    13
    ·
    edit-2
    6 months ago

    I prefer nginx to Caddy myself for reverse proxies. As far as VPN technologies go, Tailscale and WireGuard are where it’s at.

    Not sure why we’re comparing Caddy to Tailscale though.

    • branch@lemmy.worldOP
      link
      fedilink
      English
      arrow-up
      1
      ·
      6 months ago

      I meant Traefik, sorry.

      Also, why Nginx over Caddy? How does a minimal reverese proxy setup look like with Nginx?

      • Cousin Mose@lemmy.hogru.ch
        link
        fedilink
        English
        arrow-up
        2
        ·
        6 months ago

        It’s mostly about performance. Caddy’s Go-based garbage collector starts to negatively impact performance at high load. It looks something like:

        server {
            listen 443 ssl http2;
            server_name example.com;
        
            ssl_certificate     /etc/nginx/ssl/fullchain.pem;
            ssl_certificate_key /etc/nginx/ssl/privkey.pem;
        
            location / {
                proxy_pass http://localhost:3000/;
        
                proxy_set_header Host $host;
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                proxy_set_header X-Forwarded-Proto $scheme;
            }
        }
        
        • branch@lemmy.worldOP
          link
          fedilink
          English
          arrow-up
          2
          ·
          5 months ago

          How do you know which headers to set? I couldn’t find any documentation when I last tried (but that was some years ago now).

          • Cousin Mose@lemmy.hogru.ch
            link
            fedilink
            English
            arrow-up
            1
            ·
            5 months ago

            It can be specific to the web application but generally speaking you’d want to pass the protocol, client IP address, etc.

  • Jason2357@lemmy.ca
    link
    fedilink
    English
    arrow-up
    7
    ·
    6 months ago

    I use both. Caddy on a VPS that reaches into my Tailscale network and proxies services hosted on a computer in my basement.

      • Onomatopoeia@lemmy.cafe
        link
        fedilink
        English
        arrow-up
        2
        ·
        6 months ago

        Using a mesh network like Wireguard/Tailscale enables you to have a public interface that’s not on your home router, but the VPS instead.

      • Jason2357@lemmy.ca
        link
        fedilink
        English
        arrow-up
        2
        ·
        6 months ago

        The VPS is a $2 instance and very under powered, however it has a dedicated static IP and some Ddos protection. The basement computer is powerfully and capable of providing various services, but I don’t want any trouble with my home IP address. Tailscale let’s the VPS see the home computer securely.

          • Jason2357@lemmy.ca
            link
            fedilink
            English
            arrow-up
            1
            ·
            6 months ago

            Thanks, I like it. The downside is that the VPS can see the content of my services, so it’s no good if you don’t trust the VPS provider, or if the content is too sensitive to allow that. I think it’s a good trade-off for my usage though. Performs well. One of the services I proxy is a rpi serving images downloaded from weather satellites. Connecting directly to the pi is super slow, but the proxy caching makes it 100% faster.

  • Domi@lemmy.secnd.me
    link
    fedilink
    English
    arrow-up
    5
    arrow-down
    1
    ·
    6 months ago

    If Caddy works for you, no reason to change it.

    I use Traefik because I like how tightly integrated it is with Docker. If the container with the config labels on it starts/stops the corresponding router in Traefik also starts/stops.

    Since my services are mostly running in Docker, it’s the perfect workflow for me.

  • q7mJI7tk1@lemmy.world
    link
    fedilink
    English
    arrow-up
    4
    ·
    edit-2
    6 months ago

    I’ll admit I’ve not tried Traefik yet, but I see Caddy as being to web servers (and reverse proxies), what WireGuard is to VPNs.

    It does what it needs to well, with a minimal config file. And if I learn and get comfortable with Caddy, then I know it can do anything I will ever need of a web server down the line with no need for me to ever change setup.

  • vampatori@feddit.uk
    link
    fedilink
    English
    arrow-up
    3
    ·
    6 months ago

    I switched to Traefik as it has auto-configuring for containers for effortless deployment to any of your environments (dev, test, staging, production, etc.) either manually or straight from CI/CD.

    The way it works is that you put any configuration in your compose file which is then picked-up by Traefik when its deployed - it reads the config, re-configures itself accordingly, and you’re done! So all your reverse-proxy config, cert config, etc. is all with the project so aren’t going to get out-of-sync.

    Just keeps things really clean and simple. Plus it’s a great reverse proxy of course with tons of features, nice admin dashboard, logging, etc.

  • hempster@lemm.ee
    link
    fedilink
    English
    arrow-up
    2
    ·
    6 months ago

    I spin a new service, add a few human understandable labels and traefik makes the connection automatically.

  • irmadlad@lemmy.world
    link
    fedilink
    English
    arrow-up
    2
    ·
    6 months ago

    I have not tried Traefik, tho looking at what it does, it’s pretty amazing. Caddy seems to fit what I do, and as OP stated, Caddy is pretty easy to master, even tho it took me an embarrassingly long time to get it through my dim brain. Traefik does seem like a very polished app tho and is very integrated in with docker.

  • kayzeekayzee@lemmy.blahaj.zone
    link
    fedilink
    English
    arrow-up
    1
    ·
    edit-2
    6 months ago

    I use both, since they do different stuff. I actually remote into my servers with wireguard, but I like to install tailscale as well as a backup. Since each device gets a unique tailnet ip, I can usually still connect even if I’ve fucked up some network config that breaks wireguard. ((If this is a security risk, someone let me know because I have no clue what I’m doing tbh.))

    Plus tailscale lets you easily see what devices are connected to the internet at a given time.

  • Lem453@lemmy.ca
    link
    fedilink
    English
    arrow-up
    1
    ·
    6 months ago

    Others have already mentioned the question makes no sense but for others that are curious.

    Headscale is a self hosted tailacale alternative and for a small number of devices plain wireguard is as well. I use plain wireguard on my router to allow LAN access from my mobile devices.

    I want rock solid stability and simplicity since I use this for to debug issues if they crop up while I’m away.