Level of infrastructure abstraction
You manage the setup and ongoing management of virtual machines, servers, and infrastructure, requiring a lot of effort and expertise. As an example, AWS alone has more than 240 services - and it might seem like an advantage, but in reality it requires years of experience to figure out which are required or relevant for you, and how to set up and maintain them…
The provider provisions and manages the core infrastructure: servers, scaling, and maintenance.
You can focus on your product and non-cloud related tools and applications.
← + Provider manages additional infrastructure, such as e.g. authentication, databases, file storage, caching, and job queues, by abstracting away the service-to-service communication and coordination behind a message-passing interface. So you get all the advantages, without having to learn and understand the tools.
You can focus solely on your product.
You can find a brief explanation of serverless
here, and of infraless
here.
Scaling is manual or requires pre-configured auto-scaling rules. You must anticipate demand to avoid over- or under-provisioning, which either hurts your wallet or your software's performance.
Automatic and instantaneous (zero cold-start) scaling based on demand without manual intervention, handled by the platform. Resources are dynamically allocated as needed.
Potential latency during high traffic, limited by capacity if you have under-provisioned resources or run into a manual scaling limitation.
Faster response times, via distributed requests and automatically adjustment to handle fluctuations in traffic, minimizing latency and performance bottlenecks, while also removing your risk of over-paying for unused resources.
← + optimized performance via AI/machine learning, and integrated caching and workflows.
Availability & redundancy
Requires you to configure and maintain backups, failover, and disaster recovery setups.
Redundancy is built-in the platform: Your code is automatically distributed across multiple physical locations, with disaster recovery managed by the platform.
Security setup is largely your responsibility, including patching, updates, and monitoring.
Many security responsibilities are handled by the provider (e.g., encryption, patching), but you still manage application-level security.
← + all security related to additionally abstracted infrastructure.
The provider offers tools, often requiring additional setup.
Integrated monitoring and logging solutions are included.
DevOps, but slightly lighter on the Ops-part.
Full on NoOps, setting developers free.
Developers are forced to split their time and attention between both product- and operations -related tasks and deadlines, resulting in reduced time-to-market.
Developers are free from cloud management and the related tools, so they can focus more on their product, but they still have to tediously setup and maintain all the usual non-cloud related infrastructure tools and apps.
Developers can focus their time and attention on their product, while the provider manages everything cloud-related and many other tools and apps in a documented, self-service enabled environment, drastically reducing time-to-market.
Developers have a high risk of burnout, particularly due to issues with prioritizing between development and operations.
Developers have less risk of burnout, as cloud operations are no longer a competing priority. Instead, their time and attention can be almost fully focused on their product.
Developers are set free from not only operations, but almost all of the tedious infrastructure tasks, which significantly reduces their cognitive load and allows for deeper focus, resulting in actual developer happiness.