I didn’t see this coming and I think it’s funny, so I decided to post it here.
I’m trying to understand how this is different than a concept I learned in computer science in the late 80s/early 90s called RPCs (remote procedure calls). My senior project in college used these. Yes I’m old and this was 35 years ago.
This is just distributed functions, right? This has been a thing for years. AWS Lambda, Azure Functions, GCP Cloud Functions, and so on. Not everything that uses these is built on a distributed functions model but a fuck ton of enterprises have been doing this for years.
someone at my work didn’t get the message.
2000+ line function with 3157 node packages.
is that nano enough?
Tech moved in cycles. We come back to the same half-baked ideas every so on, imagine we just discovered the idea and then build more and more technologies on top to try to fix the foundational problems with the concept until something else shiny comes along. A lot of tech work is “there was an old lady who swallowed a fly”.
I always keep saying " You cannot plan your way out of a system built on broken fundamentals." Microservices has it’s use case, but not every web app needs to be one. Too many buzzwords floating around in tech, that promise things that cannot be delivered.
Nano services are microservices after your company realizes monoliths are much easier to maintain and relabels their monoliths as microservices.
Unironically. I’d put a significant wager down on that being the source of this term.
This is just the Linux way but with… Rest? Seems slow.
quantum services
take your source code and put each character in its own docker container
this gives you the absolute peak of scalability and agility as every quantum of your application is decoupled from the others and can be deployed or scaled independently
implementing, operating and debugging this architecture is left as an exercise for the reader
that will be $250,000 kthx
implementing, operating and debugging this architecture is left as an exercise for the reader
Challenge accepted by a reader using AI, what could go wrong? xD
What’s next? Femtofunctions
You only need two of them, one for
1
and one for0
We already have nanoservices, they’re called functions. If you want a function run on another box, that’s called RPC.
I feel like this name addresses the problem of services claiming to be microservices when they’re not.
Does that even happen? cat is micro, sed is micro, systemd isn’t and doesn’t claim to be
This “article” was written by AI, wasn’t it? This is just throwing vague buzzwords around
Planck services
My services are so small that it is impossible to know just how fast they are running!
You know what they say: micro services, macro outages.
At least you can accurately point the finger at who’s responsible
Well during the never sev0 I’m sure the shareholders will be satisfied with that.
Metaservices.
Poe’s law strikes again!
I can’t agree more!
we’ve been using nano-services for the past 6 months or so. Two different reasons. A codebase we absorbed when a different team was dissolved had a bunch of them, all part of AWS AppSync functions. I hate it. It’s incredibly hard to parse and understand what is going on because every single thing is a single function and they all call each other in different ways. Very confusing.
But the second way we implemented ourselves and it’s going very well. We started using AWS Step Functions and it allows building very decoupled systems by piecing together much larger pieces. It’s honestly a joy to use and incredibly easy to debug. Hardest part is testing, but once it’s working it seems very stable. But sometimes you need to do something to transform data to piece together these larger systems. That’s where ‘nano-services’ come in. Essentially they’re just small ruby, python, js lambdas that are stuck into the middle of a step function flow in order to do more complex data transformation to pass it to the next node in the flow. When I say small I mean one of the functions we have is just this
def handler(event:, context:) if event['errorType'] clazz = Object.const_set event['errorType'], Class.new(StandardError) raise clazz.new.exception, event['errorMessage'] end event end
to map a service that doesn’t fail with a 4xx http code to one that does fail with a 4xx http code.
You could argue this is a complete waste of resources, but it allows us to keep using that other service without any modifications. All the other services that depend on that service that maps its own error types can keep working the way they want. And if we ever do update that service and all its dependencies, now ‘fixing’ the workflow is literally as simple as just deleting the node and the ‘nano-service’ to go along with it.
I should note that the article is about the first thing I discussed, the terrible codebase. Please don’t use nano-services like that, it’s literally one of the worst codebases I’ve ever touched and no joke, it’s less than 2 years old.
Sounds like a distributed monad
This looks like hell.
I’m a C/C++ developer though.
You can write your glue nano-service in c/c++ if you want, it’s just that: glue. It doesn’t matter as long as you don’t need to change the original services which also can be written in whatever you want. Ruby, Python, JS just work out of the box with aws lambda and you don’t really have to maintain them or any sort of build infra so it allows for very little maintenance or upkeep cost. You don’t really test these glue lambdas either.
Things won’t be simpler just because you cut everything up in tiny tiny pieces (I mean it will be easier because it solves some surface level problem right now, pushing the real problem down the road), it creates a complexity of its own.
I’m a C/C++ developer though.
Ya feel good about yourself, slugger? /s
Yeah, I kind of am. Just found a 33% time job so that I can gradually leave software engineering 😁