Hacker Newsnew | past | comments | ask | show | jobs | submitlogin

Not really. You can't really reduce the blast radius of crashes or bad deployments. You need to have the discipline of a good CI/CD instead of siloed but decoupled workflows.

Just keeping things neat doesn't go nearly as far as a separate process on separate machines. Monolith might be better but I don't think it's a situation where you can have it all.



This argument always confuses me. It depends on what you’re doing but if you’re doing web services, as most here are, the crash is limited to the request being served.

The blast radius is a single request, right?

In every likelihood it _is_ a separate process on a separate machine.


They are talking about deployment.

With micro-services if you screw up a deployment the service is down and if your platform is well designed the system will be degraded but not down.

With a monolith the whole system is down.


> With micro-services if you screw up a deployment the service is down and if your platform is well designed the system will be degraded but not down.

In theory, but when the getUser service is down, your app is probably broken as well.


There are a lot of deployments options to mitigate that risk.


>With a monolith the whole system is down.

No, you are just at reduced capacity.

The moral of the story is not to roll out to 100% right away.


Monoliths go hand in hand with a centralised database.

Bit hard to do schema evolution with a staggered rollout.


If schema migrations take non-zero time and you want zero-downtime deployments, then the both service versions need to be compatible with either the new schema or the old schema, regardless of service size.


The software should be compatible with both the old and new schema until all of your database servers have moved over to the new schema. All rollouts are going to be somewhat staggered even if you go straight to 100%.


The same problem exists in microservoce land, only you now have a load of separate teams managing their own database, perhaps with different solutions.


Wait, micro-service and sharing same DB? Did I miss something?


I think you misunderstood what I said, which is you still have databases and ergo need to manage migrations and such, only that this now typically falls to the specific teams.

That said, loads of folks do microservices with a shared dB.


Even for a web service, imagine a small feature is causing the app to crash to OOM, or too many file handles or something that will take out the whole process and not just the one request.

If you have long running requests (something beside small rest calls like large data transfers) then any being served by that same process are taken down.


> You need to have the discipline of a good CI/CD

Good CD is even more important if there are more services to deploy




Consider applying for YC's Winter 2026 batch! Applications are open till Nov 10

Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: