Ivan on the Server Side


Hello πŸ‘‹

Ivan's here with November's roundup of all things Linux, Containers, Kubernetes, and Server Side πŸ§™


What I was working on

This month was (extremely) development-heavy. Two-thirds of it went into the implementation of custom playground machinery and a new Kubernetes "Omni" playground, and in the last part, I was unexpectedly busy with expanding the platform's capacity and launching a new server in India πŸŽ‰

The latter became possible thanks to the support of all of you who got the premium membership during the Black Friday / Cyber Monday sale. I still cannot believe that iximiuz Labs has made over $25K in sales in just one week. As promised, I'm reinvesting all this money back into the platform's development - and the first $4K has already been spent on the new (pretty big) bare-metal server in Mumbai to improve the experience for my Asia-based users πŸš€

Speaking of sales, this is the last day - if you wanted to get iximiuz Labs Premium for 50% of its usual price, this is your last chance.

The offer is valid until tomorrow noon, Amsterdam time.

Custom Playgrounds on iximiuz Labs

I dedicated the mid-month newsletter issue to this shiny new capability of the platform, and here is a quick recap:

  • iximiuz Labs playgrounds have gotten the support of cloud-init-like provisioning script.
  • You can create your own playgrounds by adding custom scripts that install and/or configure additional software.
  • By default, custom playgrounds are visible only to you, but you can also share them publicly (or with a limited set of users).

The original goal was to make the dynamic provisioning possible (e.g., when you need to, say, apply a helm chart after boot) and also automate some tedious, repetitive setup steps if you often install the same tools to the off-the-shelf playground like Docker or K3s, but the actual implementation came out (much) more powerful, and enabled a few interesting playground use cases:

  • Demos - you can now create a sample setup and include it in your blog post or "take it with you" to a conference (and forget about the cranky demo gods).
  • Collaboration - illustrate your problem or a design idea to your colleagues and friends (with a shareable link).
  • Workshops - give all your students an identical starting point for a lesson or a home assignment (potentially restricting access to a limited number of users).

To give you some examples and food for thought, here are two public custom playgrounds I prepared in almost no time using the new feature:

Kubernetes "Omni" Playground

Using the custom playground machinery, I also prepared a new 6-in-1 Kubernetes playground, which you can use to practice all sorts of cluster ops and also to prepare for CKA/CKAD/CKS certification.

The multi-node cluster is bootstrapped with kubeadm and a few init scripts. Since the playground relies on the new custom playground magic, you can "clone" and "fork" it to prepare your own "flavor" of a Kubernetes cluster, possibly changing the container runtime or using a different networking plugin.

New Region - Asia πŸŽ‰

I'm super excited about this expansion. A great number of people who got the premium membership are based outside of the EU, but I only had the playground servers in this region. I have been surveying the latency numbers for a long time, and I know that some of you were more satisfied than others. So, I'm happy to present you with the new option - (preferred) Playground Region.

Given that the latency in the western direction from Europe seems to be less of a problem, I'm starting the expansion from the East. If you're located in the region and weren't fully satisfied with the terminal latency in the playground, there is a new knob on the dashboard page - give it a try!

Since this is an experimental deployment, I'm also testing another thing that has been on my radar for way too long - device mapper. Playgrounds spawned up in Asia have twice as much disk space, thanks to the copy-on-write magic of the new "storage driver" I implemented this weekend (but all sorts of bugs are expected - hence, the Experimental status).


What I was reading

​Wolfi Distroless Images - A helpful guide on using the Chainguard ecosystem for free β€” not some marketing fluff, but a hands-on technical post about composing Wolfi-based images manually.

​When is read-only not read-only? - A short note by Rory McCune on the intricacies of Kubernetes RBAC. Would you ever guess that the SPDY to WebSocket transition for kubectl exec (which happened in Kubernetes 1.31) could have changed the way some RBAC rules are interpreted? 🀯

​Security Is A Useless Controls Problem - The post is worth reading, not just for the vivid chimps-and-banana metaphor it uses in the opening but also for its broader insights. Question everything! This advice applies not only to cybersecurity but to software engineering in general.

​Quoting Simon Willison quoting Carson Gross (because I wouldn’t say it better and it perfectly matches my own approach) - β€œMy preferred approach in many projects is to do some unit testing, but not a ton, early on in the project and wait until the core APIs and concepts of a module have crystallized. At that point I then test the API exhaustively with integrations tests. In my experience, these integration tests are much more useful than unit tests, because they remain stable and useful even as you change the implementation around. They aren’t as tied to the current codebase, but rather express higher level invariants that survive refactors much more readily.” By the way, the original post is also worth reading - for the very least, to get a healthy dose of anti-dogmatism.

​The magic of keeping one level of abstraction per function - Since we’re talking about programming techniques (and tactics). A rare post on an unnamed technique I exercise myself. Even though the article uses React/JavaScript examples, the advice is not specific to frontend development. The resulting code tends to be much more readable and maintainable, so it’s surprising that this trick is not widely known.

​containerd v2.0, nerdctl v2.0, and Lima v1.0 by Akihiro Suda - This smells like a playground (and course) revamp for me. But progress is always good!


Wrapping up

That is it for November! It was the craziest and the most successful month for iximiuz Labs so far, but I believe it's just the beginning. To the new highs!

Kind reminder - it's the end of the year, and if you have a learning and development budget in your company, it's often "use it or lose it." If you like what we're doing here, there is always a way to support my work!

Cheers

Ivan

Ivan Velichko

Building labs.iximiuz.com - a place to help you learn Containers and Kubernetes the fun way πŸš€

Read more from Ivan Velichko

Hello, fellow server dweller πŸ‘‹ Ivan's here with the last Server Side roundup of the year! What I was working on Since my previous update about two weeks ago, when I announced twice bigger playgrounds and a declarative way to create custom playgrounds via labctl, I managed to ship one more (larger) feature and prepare a new batch of DevOps challenges, thanks to the GenAI holiday season πŸ™ˆ Tasks Dev Tools If you have tried authoring a challenge or tutorial or creating a custom playground on...

Diagram showing desired network policy configuration between frontend and backend pods

Hey, fellow server dweller πŸ‘‹ Ivan here with an exciting iximiuz Labs update! The month isn't over yet, so it's not quite time for the traditional monthly roundup. However, there have been so many updates on the platform in the past couple of weeks that they couldn't possibly fit into a single email. So, let's dive in πŸš€ Backend Revamp: Faster, Smarter, Stronger Over the past few weeks, I rolled out a significant backend rewrite at iximiuz Labs, and I couldn't be more excited to share the...

Hello, fellow server dweller πŸ‘‹ I've got two exciting announcements to make. Starting with the shorter one, this year, I decided to give Black Friday a try. This is an experiment - iximiuz Labs hasn't done sales before and won't have any in the foreseeable future, at least not until next November. So, if you wanted to get a premium membership but the price felt too high, this is your rare chance to get it with a 50% discount. The offer is limited to exactly one week. Now, to the second, much...