| ▲ | topspin 13 hours ago |
| "I keep seeing teams reach for K8s when they really just need to run a bunch of containers across a few machines" Since k8s is very effective at running a bunch of containers across a few machines, it would appear to be exactly the correct thing to reach for. At this point, running a small k8s operation, with k3s or similar, has become so easy that I can't find a rational reason to look elsewhere for container "orchestration". |
|
| ▲ | jabr 12 hours ago | parent | next [-] |
| I can only speak for myself, but I considered a few options, including "simple k8s" like [Skate](https://skateco.github.io/), and ultimately decided to build on uncloud. It was as much personal "taste" than anything, and I would describe the choice as similar to preferring JSON over XML. For whatever reason, kubernetes just irritates me. I find it unpleasant to use. And I don't think I'm unique in that regard. |
| |
| ▲ | 1dom 6 hours ago | parent | next [-] | | > For whatever reason, kubernetes just irritates me. I find it unpleasant to use. And I don't think I'm unique in that regard. I feel the same. I feel like it's a me problem. I was able to build and run massive systems at scale and never used kubernetes. Then, all of a sudden, around 2020, any time I wanted to build or run or do anything at scale, everywhere said I should just use kubernetes. And then when I wanted to do anything with docker in production, not even at scale, everywhere said I should just use kubernetes. Then there was a brief period around 2021 where everyone - even kubernetes fans - realised it was being used everywhere, even when it didn't need to be. "You don't need k8s" became a meme. And now, here we are, again, lots of people saying "just use k8s for everything". I've learned it enough to know how to use it and what I can do with it. I still prefer to use literally anything else apart from k8s when building, and the only time I've ever felt k8s has been really needed to solve a problem is when the business has said "we're using k8s, deal with it". It's like the Javascript or WordPress of the infrastructure engineering world - it became the lazy answer, IMO. Or the me problem angle: I'm just an aged engineer moaning at having to learn new solutions to old problems. | | |
| ▲ | hhh 18 minutes ago | parent [-] | | It’s a nice portable target, with very well defined interfaces. It’s easy to start with and pretty easy to manage if you don’t try to abuse it. |
| |
| ▲ | tw04 3 hours ago | parent | prev [-] | | How many flawless, painless major version upgrades have you had with literally any flavor of k8s? Because in my experience, that’s always a science experiment that results in such pain people end up just sticking at their original deployed version while praying they don’t hit any critical bugs or security vulnerabilities. | | |
| ▲ | mxey 3 hours ago | parent | next [-] | | I’ve run Kubernetes since 2018 and I can count on one hand the times there were major issues with an upgrade. Have sensible change management and read the release notes for breaking changes. The amount of breaking changes has also gone way down in recent years. | |
| ▲ | jauntywundrkind 2 hours ago | parent | prev [-] | | I applaud you for having a specific complaint. 'You might not need it' 'its complex' and 'for some reason it bothers me' are all these vibes based winges that are so abundant. But with nothing specific, nothing contestable. |
|
|
|
| ▲ | nullpoint420 13 hours ago | parent | prev | next [-] |
| 100%. I’m really not sure why K8S has become the complexity boogeyman. I’ve seen CDK apps or docker compose files that are way more difficult to understand than the equivalent K8S manifests. |
| |
| ▲ | this_user 8 hours ago | parent | next [-] | | Docker Compose is simple: You have a Compose file that just needs Docker (or Podman). With k8s you write a bunch of manifests that are 70% repetitive boilerplate. But actually, there is something you need that cannot be achieved with pure manifest, so you reach for Kustomize. But Kustomize actually doesn't do what you want, so you need to convert the entire thing to Helm. You also still need to spin up your k8s cluster, which itself consists of half a dozen pods just so you have something where you can run your service. Oh, you wanted your service to be accessible from outside the cluster? Well, you need to install an ingress controller in your cluster. Oh BTW, the nginx ingress controller is now deprecated, so you have to choose from a handful of alternatives, all of which have certain advantages and disadvantages, and none of which are ideal for all situations. Have fun choosing. | | |
| ▲ | stego-tech 3 hours ago | parent | next [-] | | Literally got it in one, here. I’m not knocking Kubernetes, mind, and I don’t think anyone here is, not even the project author. Rather, we’re saying that the excess of K8s can sometimes get in the way of simpler deployments. Even streamlined Kubernetes (microk8s, k3s, etc) still ultimately bring all of Kubernetes to the table, and that invites complexity when the goal is simplicity. That’s not bad, but I want to spend more time trying new things or enjoying the results of my efforts than maintaining the underlying substrates. For that purpose, K8s is consistently too complicated for my own ends - and Uncloud looks to do exactly what I want. | |
| ▲ | quectophoton 5 hours ago | parent | prev | next [-] | | > Docker Compose is simple: You have a Compose file that just needs Docker (or Podman). And if you want to use more than one machine then you run `docker swarm init`, and you can keep using the Compose file you already have, almost unchanged. It's not a K8s replacement, but I'm guessing for some people it would be enough and less effort than a full migration to Kubernetes (e.g. hobby projects). | |
| ▲ | 6 hours ago | parent | prev | next [-] | | [deleted] | |
| ▲ | horsawlarway 5 hours ago | parent | prev [-] | | This is some serious rose colored glasses happening here. If you have a service with a simple compose file, you can have a simple k8s manifest to do the same thing. Plenty of tools convert right between the two (incl kompose, which k8s literally hands you: https://kubernetes.io/docs/tasks/configure-pod-container/tra...) Frankly, you're messing up by including kustomize or helm at all in 80% of cases. Just write the (agreed on tedious boilerplate - the manifest format is not my cup of tea) yaml and be done with the problem. And no - you don't need an ingress. Just spin up a nodeport service, and you have the literal identical experience to exposing ports with compose - it's just a port on the machines running the cluster (any of them - magic!). You don't need to touch an ingress until you actually want external traffic using a specific hostname (and optionally tls), which is... the same as compose. And frankly - at that point you probably SHOULD be thinking about the actual tooling you're using to expose that, in the same way you would if you ran it manually in compose. And sure - arguably you could move to gateways now, but in no way is the ingress api deprecated. They very clearly state... > "The Ingress API is generally available, and is subject to the stability guarantees for generally available APIs. The Kubernetes project has no plans to remove Ingress from Kubernetes." https://kubernetes.io/docs/concepts/services-networking/ingr... --- Plenty of valid complaints for K8s (yaml config boilerplate being a solid pick) but most of the rest of your comment is basically just FUD. The complexity scale for K8s CAN get a lot higher than docker. Some organizations convince themselves it should and make it very complex (debatably for sane reasons). For personal needs... Just run k3s (or minikube, or microk8s, or k3ds, or etc...) and write some yaml. It's at exactly the same complexity as docker compose, with a slightly more verbose syntax. Honestly, it's not even as complex as configuring VMs in vsphere or citrix. | | |
| ▲ | KronisLV 2 hours ago | parent [-] | | > And no - you don't need an ingress. Just spin up a nodeport service, and you have the literal identical experience to exposing ports with compose - it's just a port on the machines running the cluster (any of them - magic!). https://kubernetes.io/docs/concepts/services-networking/serv... Might need to redefine the port range from 30000-32767. Actually, if you want to avoid the ingress abstraction and maybe want to run a regular web server container of your choice to act as it (maybe you just prefer a config file, maybe that's what your legacy software is built around, maybe you need/prefer Apache2, go figure), you'd probably want to be able to run it on 80 and 443. Or 3000 or 8080 for some other software, out of convenience and simplicity. Depending on what kind of K8s distro you use, thankfully not insanely hard to change though: https://docs.k3s.io/cli/server#networking But again, that's kind of going against the grain. |
|
| |
| ▲ | everforward 2 hours ago | parent | prev | next [-] | | It's not the manifests so much as the mountain of infra underlying it. k8s is an amazing abstraction over dynamic infra resources, but if your infra is fairly static then you're introducing a lot of infra complexity for not a ton of gain. The network is complicated by the overlay network, so "normal" troubleshooting tools aren't super helpful. Storage is complicated by k8s wanting to fling pods around so you need networked storage (or to pin the pods, which removes almost all of k8s' value). Databases are annoying on k8s without networked storage, so you usually run them outside the cluster and now you have to manage bare metal and k8s resources. The manifests are largely fine, outside of some of the more abnormal resources like setting up the nginx ingress with certs. | |
| ▲ | esseph 11 hours ago | parent | prev [-] | | Managing hundreds or thousands of containers across hundreds or thousands of k8s nodes has a lot of operational challenges. Especially in-house on bare metal. | | |
| ▲ | lnenad 10 hours ago | parent | next [-] | | But that's not what anyone is arguing here, nor what (to me it seems at least) uncloud is about. It's about simpler HA multinode setup with a single/low double digit containers. | |
| ▲ | Glemkloksdjf 8 hours ago | parent | prev | next [-] | | Which is fine because it absolutly matches the result. You would not be able to operate hundreds or thousand of any nodes without operation complexlity and k8s helps you here a lot. | |
| ▲ | nullpoint420 10 hours ago | parent | prev | next [-] | | Talos has made this super easy in my experience. | |
| ▲ | sceptic123 10 hours ago | parent | prev [-] | | I don't think that argument matches with they "just need to run a bunch of containers across a few machines" |
|
|
|
| ▲ | psviderski 13 hours ago | parent | prev | next [-] |
| That’s awesome if k3s works for you, nothing wrong with this. You’re simply not the target user then. |
|
| ▲ | PunchyHamster an hour ago | parent | prev | next [-] |
| k3s makes it easy to deploy, not to debug any problems with it. It's still essentially adding few hundred thousand lines of code into your infrastructure, and if it is a small app you need to deploy, also wasting a bit of ram |
|
| ▲ | matijsvzuijlen 12 hours ago | parent | prev | next [-] |
| If you already know k8s, this is probably true. If you don't it's hard to know what bits you need, and need to learn about, to get something simple set up. |
| |
| ▲ | epgui 9 hours ago | parent [-] | | you could say that about anything… | | |
| ▲ | morcus 9 hours ago | parent [-] | | I don't understand the point? You can say that about anything, and that's the whole reason why it's good that alternatives exist. The clear target of this project is a k8s-like experience for people who are already familiar with Docker and docker compose but don't want to spend the energy to learn a whole new thing for low stakes deployments. | | |
| ▲ | Glemkloksdjf 8 hours ago | parent [-] | | Uncloud is so far away from k8s, its not k8s like. A normal person wouldn't think 'hey lets use k8s for the low stakes deployment over here'. |
|
|
|
|
| ▲ | tevon 5 hours ago | parent | prev | next [-] |
| Perhaps it feels so easy given your familiarity with it. I have struggled to get things like this stood up and hit many footguns along the way |
|
| ▲ | _joel 12 hours ago | parent | prev [-] |
| Indeed, it seems a knee jerk response without justification. k3s is pretty damn minimal. |
| |