Blog

Hi DevOps Software Developer !

Cover Image for Hi DevOps Software Developer !
Vicens Fayos

Introduction

From working with my last client, I was involved in many daily DevOps tasks that I would like to share with you.

What I liked most was how software developers had to engage in daily DevOps duties and how elegantly these duties were divided.

The Set Up

The client was relying heavily in AWS for the Cloud and also K8S for distributing the apps The client was heavily reliant on the Cloud for the cloud and also on Kubernetes (K8S) for distributing the apps smoothly among environments, from the Development Computer to Production.

So, given this setup, how does it affect our Software Developer day-to-day?

Kubernetes is not only a container orchestrator; it is also an infrastructure abstraction because:

- Clusters and Nodes were what were previously virtual machines and clusters of them.

- Pods and Containers are abstractions of the application and how it is split into modules to make it more resilient (for example, you can think of splitting an MVC Web App into FE, BE, and DB pods).

Note: I assume you have some familiarity with Kubernetes concepts!

Therefore, developers will be busy managing the containers and pods while the DevOps engineer will take care of what is exclusively infrastructure.

Essentially, the DevOps will prepare the entire infrastructure so the developer can deploy his pods as required.

Going Deeper as A Developer - Deployment

Following this explanation and connecting these two concepts, we find:

Containers and Pods are related to the `Dockerfile` and `k8s deployment file deployment.yml`.

Now we uncover the concept of Deployment.

But... Isn't it a DevOps duty to deploy the application the Software Developer is working with?

YES and NO. The DevOps ensures that everything is in place to deploy the application successfully. The cloud is in place, as well as the CI/CD automations, etc.

But HOW to deploy the application is also a responsibility of the SW Engineer.

Indeed, the deployment descriptor is a file that has to be supervised by DevOps teams, but it is also clear it is something intrinsically related to the Application, because the application deploys on its own in its own Node.

Therefore, the Developer also has a say in it. For example, which constraints to apply to the deployment or how many replicas to have (remember, we are busy with Kubernetes!).

So, given a simplified workflow, these would be the responsibilities of a SW Engineer (the yellow ones).

what the SW enginner is busy with

I have become technology agnostic by now, relying only on Docker & K8S for infrastructure abstraction.

However, it is worth noting that the cloud could easily be AWS EKS, for example. The artifact repository could be Docker Hub, to name the most popular one, and the CI/CD could be GitHub Actions.

I mentioned these technologies because I am preparing some other posts and videos to demystify DevOps for a Software Engineer. So, stay tuned!

Wrapping up

DevOps is not just about some people busy with the cloud and IaC terms; it also embodies a broader philosophy of work and best practices to deliver highly scalable and available applications with reduced time to market.

For this, Software Engineers must align with DevOps concepts and concerns and work collaboratively.


Más historias

Cover Image for D4D - You Build it You Run it - Add Database Support

D4D - You Build it You Run it - Add Database Support

Integrating database support into your Next.js app with Kubernetes is simpler than you think!

Vicens Fayos
Cover Image for You build it, you run it

You build it, you run it

After being tasked with modernizing our CI/CD process, we developed a straightforward approach that significantly improved efficiency. Using a simple "Hello World" Next.js app as a reference, I realized this method could be applied across multiple technologies

Vicens Fayos