Upgrade to Pro — share decks privately, control downloads, hide ads and more …

Developer Experience with Java on Kubernetes (J...

Developer Experience with Java on Kubernetes (JBCNConf 2022)

In the cloud-native world, being a developer might be challenging. The number of technologies and patterns to know can be overwhelming. This session presents an approach based on open-source technologies and focused on improving the inner development loop and continuous delivery on Kubernetes. The end goal is delivering value continuously, quickly, and reliably.

First, I’ll present several techniques for working locally in an effective and productive way. Should you run Kubernetes in your development environment? I’ll cover a few different options. Using Java and Spring Boot, we’ll build a cloud native application following the principles of test-driven development. The inner development loop will be enhanced with Cloud Native Buildpacks, Skaffold, and Telepresence.

Continuous integration is a crucial practice for continuous delivery. We’ll check in code regularly, triggering an automated process to build, test, and package the application. Do you use pull requests? Relying on ArgoCD and Knative, I’ll show you how to work with temporary environments created dynamically when a new pull request is opened. Next, further acceptance tests will be carried on in a production-like environment to ensure the mainline is always in a releasable state. Finally, we’ll deploy and release the new changes to production following the GitOps principles.

Thomas Vitale

July 18, 2022
Tweet

More Decks by Thomas Vitale

Other Decks in Technology

Transcript

  1. Systematic • Software Architect at Systematic, Denmark. • Author of

    “Cloud Native Spring in Action” (Manning). • Spring Security and Spring Cloud contributor. Thomas Vitale thomasvitale.com @vitalethomas
  2. #jbcn22 @vitalethomas Developer Experience “Fast feedback loops” "Easiness of doing

    one’s job” “How quick I can be productive with a tool” “Happy developers create exceptional software in the log term” “It’s reduced time to find things, tools downtime” “Means to be flexible for new paradigms and be able to integrate many frameworks and tools” Your answers
  3. Developer Experience “…developer experience could be defined as a means

    for capturing how developers think and feel about their activities within their working environments, #jbcn22 @vitalethomas with the assumption that an improvement of the developer experience has positive impacts on characteristics such as sustained team and project performance.” (F. Fagerholm, J. Münch) Developer Experience: Concept and De fi nition (F. Fagerholm, J. Münch)
  4. #jbcn22 @vitalethomas Developer Experience: Concept and De fi nition (F.

    Fagerholm, J. Münch) Developer Experience Conceptual Framework
  5. #jbcn22 @vitalethomas Development Workflow Inner Loop and Outer Loop Inner

    Loop ‣Code ‣Build ‣Deploy ‣Debug Outer Loop ‣CI/CD ‣Compliance, security ‣Con fi guration, monitoring ‣Production deployment git push
  6. #jbcn22 @vitalethomas Inner Development Loop Code, build, test E ffi

    cient Inner Development Loops for Cloud Native Applications https://www.getambassador.io/resources/inner-dev-loop/
  7. Goals #jbcn22 @vitalethomas 2 Reduced cognitive load 3 Clear path

    to production 1 Rapid and continuous feedback loop
  8. #jbcn22 @vitalethomas From Traditional to Cloud Native Application Server, Embedded

    Server Runtime (JVM) Middleware (Application Server) Application (WAR/EAR) Runtime (JVM) Application (JAR)
  9. #jbcn22 @vitalethomas Moving to Containers Application Server, Embedded Server, Container

    Runtime (JVM) Middleware (Application Server) Application (WAR/EAR) Runtime (JVM) Application (JAR) Runtime (OCI) Application (Container)
  10. #jbcn22 @vitalethomas Moving to Kubernetes Application Server, Embedded Server, Container,

    Kubernetes Runtime (JVM) Middleware (Application Server) Application (WAR/EAR) Runtime (JVM) Application (JAR) Runtime (OCI) Application (Container) Runtime (OCI) Middleware (Kubernetes) Application (Container)
  11. Serverless Architectures Developers focus on code Focus on business logic

    Developer Platform Infrastructure Provisioning Workload Management Dynamic Scaling #jbcn22 @vitalethomas
  12. Knative Serving Serverless Experience on Kubernetes Developer-friendly abstractions From image

    to URL Autoscaling Scaling to zero Progressive Rollouts Request-driven Event-driven Cloud agnostic #jbcn22 @vitalethomas
  13. Example: Minimal Path Source -> Image -> URL Deploy to

    Kubernetes Package as container image Checkout source code
  14. Delivering Value From code to production Developer App Repo Production

    Application Operator Security Expert Platform Engineer
  15. Resources Source code • Presentation source code • The developer

    experience and the inner dev loop • Docker fi les vs. Cloud Native Buildpacks • Knative and Spring: Bringing back the func • Developer Work fl ow • Software Supply Chain Choreography #jbcn22 @vitalethomas
  16. Discount codes Manning • 35% discount code, valid for all

    products in all format • ctwjbcn22 • manning.com thomasvitale.com @vitalethomas