Exploring the Developer Experience with Kubernetes - Part 1
July 22, 2020

Roopak Parikh
Platform9

To deliver products that meet customer expectations and keep organizations competitive in today's marketplace, developers are always looking for tools and strategies to give them an edge. One of today's popular platforms for streamlining deployment and upgrades is Kubernetes, the open-source container orchestration system.


But what are some of the common challenges developers face when utilizing Kubernetes for the first time?

What hurdles might even an experience containers pro run into?

And what tools exist to make it easier?

Let's take a look at some questions that surround Kubernetes to shed light on this powerful but sometimes misunderstood platform.

What is it like for a developer to use Kubernetes? If they're new to Kubernetes, what are the challenges that they're going to face?

A typical developer wants to solve his/her business problem which involves developing business logic. Typical development work is performed on their laptop or on a set of machines provided to them as part of a company's lab environment. In this new world where every component is a microservice, it's no longer possible for developers to run everything on their laptop.

Two development models have arisen from the microservices movement. One is where developers are able to run a sandbox of an application somewhere in the labs, and then developers use their laptops to develop and work on things that they want. The other one is where they have labs internally or in the cloud, depending upon the organization and their preferences. 

In either of these development environments, the problem that developers run into is, "I know how my code works. I know my Java.net, or the Go language, or Python language." Now add in containers and Kubernetes and it's a completely different world. They are in a lab setting somewhere. How do they access it?

For a DevOps team or an IT operations team that provides these types of labs to developers, they need to be able to onboard them quickly. So for example, if an organization is running a Kubernetes cluster, or somewhere on a VMware cluster, they need to make sure developers have access to it, but DevOps teams need to have access to it, too.

Who has access to what kind of resources?

How can developers have automatic access to it?

This is where the complexity can get cumbersome. From a DevOps perspective, a Kubernetes environment needs to be baked into operations.

Another challenge that I see developers struggling with in regards to containers and Kubernetes is immutable infrastructure. With immutable infrastructure, developers can no longer go and change configuration files inside a container and be confident it will work. They have to think about another way of configuring it, and this is where Kubernetes is very powerful.

Developers need to make sure that they're able to debut the application and debugging presents similar challenges. How do they know the performance of an application, because it's no longer sitting on their laptop or virtual machine?

There are ways in which it can be done, but they are not very scalable, specifically in this world where there could be hundreds of microservices running at any given time.

What are the challenges a developer experienced in Kubernetes might face?

A trend that is rising with local development environments is the need to organize them. The build system needs to have a good CI/CD pipeline for all these microservices within Kubernetes and should also have some kind of center repository, registry or a local registry to speed up development tasks.

For example, at one point in time, there was a customer of ours who was using AWS' registry. They had a lot of container builds based upon preventive machines, and their builds were very, very slow, and it affected developer productivity.

Recently, they moved to local registries or even local hardware registries, and they have seen a considerable improvement in the timing and the end-to-end productivity for developers.

Go to Exploring the Developer Experience with Kubernetes - Part 2, covering the benefits of Kubernetes.

Roopak Parikh is Co-Founder and CTO of Platform9
Share this

Industry News

August 05, 2020

Logz.io announced a partnership with HashiCorp, a provider in multi-cloud infrastructure automation software.

August 05, 2020

Digitate, a software venture of Tata Consultancy Services, announced the release of ignio™ AI.Assurance, an autonomous assurance product that enables enterprises to deliver better software faster, enhancing their business performance.

August 05, 2020

Harness acquired self-service Continuous Integration firm Drone.io, the creator of the open-source project Drone.

August 04, 2020

Aqua Security announced that its Cloud Native Security Platform is available through Red Hat® Marketplace, an open cloud marketplace that makes it easier to discover and access certified software for container-based environments across the hybrid cloud.

August 04, 2020

Threat Stack announced the availability of Threat Stack Container Security Monitoring for AWS Fargate.

August 04, 2020

OpenLogic by Perforce now provides an enterprise-class alternative to Oracle Java by offering OpenJDK distributions backed by OpenLogic support.

August 03, 2020

MuseDev launched on Github Marketplace the Early Access version of its code analysis platform, Muse, to help developers find and fix critical security, performance, and reliability bugs, efficiently, before they reach QA or production.

August 03, 2020

Styra announced Rego Policy Builder for the Styra Declarative Authorization Service (DAS).

August 03, 2020

Felicis Ventures has invested an additional $5M in Sourcegraph, bringing the total raised to over $46M, including a $23M Series B in March 2020 led by Craft Ventures.

July 30, 2020

New Relic delivered strategic updates to New Relic One.

July 30, 2020

IT Revolution announced the DevOps Enterprise Summit Las Vegas 2020 will be going virtual.

July 30, 2020

Adaptavist announced the acquisition of Go2Group, a US technology firm specializing in Agile and DevOps services and cloud solutions for the enterprise.

July 29, 2020

Panaya announced a new partnership with Worksoft providing SAP IT organizations with a best in class Change Intelligence solution that enables SAP ECC users to migrate or optimize their system risk-free.

July 29, 2020

Splice Machine launched the Splice Machine Kubernetes Ops Center, deployed with Helm Charts.

July 29, 2020

CirrusHQ, an Amazon Web Services (AWS) Advanced Consulting and Solution Provider partner, has achieved AWS DevOps Competency Status.