“Serverless architectures allow developers to focus on their applications, not the infrastructure. It frees you up to innovate faster.” - Werner Vogels, CTO of Amazon.
Is serverless architecture the future? To answer this question first we should understand a few things and as always, look to the past in order to understand the future.
Well before we get to that, what is a server and what did it do in the first place?
On a website when you type in a url or click a link, your device, or more specifically your browser, asks another computer somewhere for the website data to be sent back to you. That other computer is what we call a server because it serves you the data.
Traditionally a server would run all an applications business logic, data processing, database access, user authentication etc as well as sending the website data to you, the client.
Companies used to own these servers physically and store them on site. As the internet exploded in popularity people realised you needed to have multiple servers, backup servers, people to run them, people to maintain them and a place to store them.
In fact if you were a popular site you would have probably stored your servers in at least two locations in case one of them catches fire or gets struck by a meteorite. By this point in time, downtime on the servers could prevent a company from making a large percentage of their income.
It became clear that the software development industry needed people who were solely responsible for running the massive amount of servers we all collectively needed.
In the modern landscape companies like Amazon, Microsoft and Google offer servers as a service; the Cloud. You pay to use their service and in return they have an army of professionals and warehouses full of servers to make sure your site does not go down.
Well firstly, the name is misleading, serverless architecture involves many servers. The difference really lies in the structure of the application code.
Serverless architecture is the principal of using 3rd party services with proven solutions to common application requirements: database access, user authentication, serving application data etc. With the power available to frontend web developers in the modern era we can create almost an entire application by calling out to these services instead of to a server.
We may still need to run small amounts of backend code on a server but of course the main cloud providers have recognised that need and now offer running single functions as a service.
Developers can use this to facilitate the passing of credentials between services, process events from services or perform any other application specific work. This is especially important when you consider something like processing payments which will involve an exchange of secrets we cannot completely trust the client code to handle.
Serverless architecture has two main benefits:
Using proven solutions written and implemented by a 3rd party alleviates the need for developers to solve solved problems and concentrate on the code that makes your business your business. We can concentrate on building functionality rather than infrastructure.
Many popular services in the serverless architecture sphere offer generous free tiers and very reasonable ongoing costs for what is absolutely a premium service. It also lowers the cost to iterate on ideas, combined with the increased speed of development your company can go to market fast and find what works quickly.
Also by using services that are maintained and updated by a 3rd party you can minimise the software maintenance costs going forward, there is less code you own to maintain.
The developers concentrate on whats important to the business and the services we use work great! Why didn’t we just build the whole internet this way?
It used to be absolutely necessary for the server to send each page a user asked for over the wire. Now, using a framework, we can send a bundle of JavaScript that handles the applications UI, its navigation and its state. With this we can limit the interactions with the server, beyond sending the initial bundle, to when they send us data or request contextual data.
With JavaScript being the lingua franca of the web, developers are plentiful and the ecosystem to support these frameworks grew to be the largest in software development.
This essentially led to the infrastructure as a service that is serverless architecture, we can do so much more on the frontend now than we used to be able to.
There are immediate pitfalls to consider with a serverless architecture as well potential future problems you may face.
When you pick a 3rd party provider to use in your application you invest time and money into integrating with them. In an ideal world it would be easy to switch providers and in a toy application that might be the case but in reality it is absolutely not guaranteed.
If a provider raises their price they have you hostage until they exceed your redevelopment costs over the time that would take.
If you ask a provider to do work on their server they will do it and charge you for it. If a developer makes a mistake or a security vulnerability in your application lets a user do something malicious you still have to pay. Most good providers allow you to set spending limits, so make sure you set them if you are going this route.
Serverless architecture has many applications and as it’s an emerging architecture businesses and developers are finding uses for it.
I believe that serverless can solve many use cases and may be the right option for a great deal of businesses. Some 3rd party services offer a better quality solution than many businesses could obtain otherwise.
I also believe that offering over as much control to a 3rd party as you have to with a full serverless adoption is untenable for many businesses.
What would be best for your business will depend on the use case you have and the business needs you must fulfil. I hope I have given you some insight but would implore you to reach out to me, Rhona Kennedy or Paul Duffy at ClearSkyLogic for a quick chat about what’s really right for you.