nginx-cluster VS caddy-l4

Compare nginx-cluster vs caddy-l4 and see what are their differences.

nginx-cluster

A horizontally scalable NGINX caching cluster (by fly-apps)

caddy-l4

Layer 4 (TCP/UDP) app for Caddy (by mholt)
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
nginx-cluster caddy-l4
1 21
106 782
- -
1.1 7.0
over 2 years ago 12 days ago
Shell Go
- Apache License 2.0
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

nginx-cluster

Posts with mentions or reviews of nginx-cluster. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2022-08-23.
  • The Future of Nginx: Getting Back to Our Open Source Roots
    12 projects | news.ycombinator.com | 23 Aug 2022
    This article came at an interesting timing for me, since I recently started to explore building my own CDN node on top of NGINX open source inspired by this article from Fly: https://fly.io/blog/the-5-hour-content-delivery-network/

    I've worked with nginx in the past, and didn't have a great experience, so I was apprehensive diving in, but this time was very different. I think njs (their custom JS scripting environment) was a game changer. Support is built in to nginx core, and available by default in their docker containers, so it's much easier to get started with than Lua scripting. Their JS feature support has some quirks (no optional chaining, array destructuring, console.log's don't show up in logs, are some examples of things that threw me off) but overall nothing that blocked me from implementing the functionality I needed, and the integration points within the nginx config felt fairly natural.

    I did run into a number of things that were locked behind their commercial offering that made me a bit uncomfortable betting on it for the long term compared to purely open source alternatives. Off the top of my head:

    - DNS discovery. There's a thread on the Fly example repo accompanying the blog post that describes the use case and proposes some workarounds: https://github.com/fly-apps/nginx-cluster/issues/2. Life would be a lot simpler if DNS discovery from the commercial offering was just available (i.e. we can outright delete a brittle bash script that makes DNS queries and reloads nginx on a 5 second interval). This was mentioned in the article as something they're planning to open source.

    - Access to some kind of shared key-value store for custom caching logic in njs scripts. With Lua we could just connect to Redis, but njs can't seem to establish persistent network connections for now, so that's off the table. This wasn't mentioned in the article, but they did mention in this Github issue that they're planning on open sourcing their keyval module for this use case: https://github.com/nginx/njs/issues/437. I have some use cases where being able to connect to Redis would be ideal, since syncing keyval across a cluster seems to be eventually consistent (https://docs.nginx.com/nginx/admin-guide/high-availability/z...), but for most of my caching use cases it should be sufficient.

    So this article, along with their overall willingness to work with the community to identify and bring commercial features into open source (at least from what I've observed across their responses to Github issues) does a lot to alleviate those concerns.

    Though at the end of the day, I don't necessarily need every nginx feature to be in open source. I have no problems with paying for great software like nginx to support its development. But as a small bootstrapped founder, their current pricing structure (from what I could gather on the internet is ~ 2k-5k per running instance), is completely prohibitive. It'd probably require a revamp to the way they sell the software (i.e. self-serve onboarding and automatic license provisioning for smaller customers instead of having customers of all sizes go through expensive sales people), but I'd love to see a more progressive pricing structure with a lower barrier to entry for their commercial product.

caddy-l4

Posts with mentions or reviews of caddy-l4. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-05-05.
  • Take a look at traefik, even if you don't use containers
    13 projects | news.ycombinator.com | 5 May 2024
  • Caddylike solution for SSH/SFTP
    2 projects | /r/selfhosted | 18 May 2023
    https://github.com/mholt/caddy-l4 and https://github.com/kadeessh/kadeessh can do SSH forwarding.
  • Minecraft server with VPS as a proxy
    2 projects | /r/selfhosted | 8 Mar 2023
    3) Use a L4 TCP/UDP plugin for caddy. https://github.com/mholt/caddy-l4
  • Nginx Reverse Proxy game hosting
    2 projects | /r/selfhosted | 9 Jan 2023
    Wireguard gives my service servers their own internal IP for the gateway to reference (nothing fancy done with it, no iptables modifications like you may see on other guides), and I use NGINX for the game server proxying, specifically linuxserver's nginx container. I love Caddy, but even with caddy-l4 I couldn't get it working right for Valheim (and thus UDP), but NGINX worked real quick.
  • Help routing packets from a static public ip to tailscale device
    1 project | /r/Tailscale | 17 Nov 2022
  • Accessing an IP camera stream through caddy
    2 projects | /r/selfhosted | 20 Oct 2022
    This may help: https://github.com/mholt/caddy-l4
  • The Future of Nginx: Getting Back to Our Open Source Roots
    12 projects | news.ycombinator.com | 23 Aug 2022
    Well, that's a bit off-topic from the parent comment, which was more about the Caddyfile supporting complex config (versus the underlying JSON config) and not really "complex usecases".

    But that said, from a quick Google search... was this an RTMP stream? If so, I suppose you'd want to use https://github.com/mholt/caddy-l4 which is a plugin for Caddy that lets you do TCP-layer things. Caddy's standard distribution just ships an HTTP server (plus TLS and PKI, etc), which is layer-7

    You might be able to use caddy-l4's "tee" handler to pipe into multiple "proxy" handlers. But I'm not sure anyone's tried this yet, I had no idea people did this sort of thing. I'd be interested to hear if it does work though.

  • Brand new to this, have a few questions about DDNS, reverse proxies, etc
    2 projects | /r/selfhosted | 18 Jun 2022
    If you are only having your services accessible via LAN, HTTPS isn't totally necessary, but I would still recommend it. I think a reverse proxy will be easier than your described method. Just set it to listen to 443 and have all of your other services on random ports being proxied from the reverse proxy. If you want HTTPS from your reverse proxy to your services, most reverse proxies will have this kind of feature. Here is the caddy L4 raw TCP stream module: https://github.com/mholt/caddy-l4
  • Alternative to SRV record?
    3 projects | /r/selfhosted | 23 May 2022
    I had a similar problem a while back and found this project (Caddy-L4). It had no releases or examples on how to build it so I forked it and added some Docker stuff.
  • Show HN: Caddy v2.5.0
    13 projects | news.ycombinator.com | 26 Apr 2022
    "Caddy L4" aka "Project Conncept" might be what you're looking for:

    https://github.com/mholt/caddy-l4

    "Project Conncept is an experimental layer 4 app for Caddy. It facilitates composable handling of raw TCP/UDP connections based on properties of the connection or the beginning of the stream."

What are some alternatives?

When comparing nginx-cluster and caddy-l4 you can also consider the following projects:

server-side-tls - Server side TLS Tools

gateway-api - Repository for the next iteration of composite service (e.g. Ingress) and load balancing APIs.

replace-response - Caddy module that performs replacements in response bodies

authelia - The Single Sign-On Multi-Factor portal for web apps

njs - An official read-only mirror of http://hg.nginx.org/njs/ which is updated hourly.

ingress - WIP Caddy 2 ingress controller for Kubernetes

cache-handler - Distributed HTTP caching module for Caddy

nginx-proxy - Automated nginx proxy for Docker containers using docker-gen

lua-nginx-module - Embed the Power of Lua into NGINX HTTP servers

caddy-docker-proxy - Caddy as a reverse proxy for Docker

caddy-ratelimit - HTTP rate limiting module for Caddy 2

caddy-ssh - Caddy-SSH is a general-purpose, extensible, modular, memory-safe SSH server built in Go [Moved to: https://github.com/kadeessh/kadeessh]