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

Inner Development Loop with Java on Kubernetes

Inner Development Loop with Java on Kubernetes

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 to deliver 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, Tilt, Knative, 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 the GitOps principles, I’ll show you how to work with temporary environments created dynamically when a new pull request is opened.

Finally, we'll use Cartographer to glue together all these different tools and design a golden path to production on Kubernetes, providing a clear separation of concerns and letting developers focus on the business logic.

Thomas Vitale

October 06, 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). • OSS contributor (Java, Spring, Cloud Native Technologies) Thomas Vitale thomasvitale.com @vitalethomas
  2. Developer Experience “…developer experience could be defined as a means

    for capturing how developers think and feel about their activities within their working environments, 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) #GOTOcph @vitalethomas
  3. Developer Experience: Concept and De fi nition (F. Fagerholm, J.

    Münch) Developer Experience Conceptual Framework #GOTOcph @vitalethomas
  4. Development Workflow Inner Loop and Outer Loop Inner Loop ‣Code

    ‣Run ‣Test ‣Debug Outer Loop ‣CI/CD ‣Compliance, security ‣Con fi guration, monitoring ‣Production deployment git push #GOTOcph @vitalethomas
  5. Inner Development Loop Code, build, test E ffi cient Inner

    Development Loops for Cloud Native Applications https://www.getambassador.io/resources/inner-dev-loop/ #GOTOcph @vitalethomas
  6. Goals 2 Reduced cognitive load 3 Clear path to production

    1 Rapid and continuous feedback loop #GOTOcph @vitalethomas
  7. From Traditional to Cloud Native Application Server, Embedded Server Runtime

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

    Application (Container) #GOTOcph @vitalethomas Runtime (JVM) Middleware (Application Server) Application (WAR/EAR) Runtime (JVM) Application (JAR)
  9. Image pack build Cloud Native Buildpacks From source code to

    container image #GOTOcph @vitalethomas
  10. Moving to Kubernetes Application Server, Embedded Server, Container, Kubernetes Runtime

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

    Developer Platform Infrastructure Provisioning Workload Management Dynamic Scaling #GOTOcph @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 #GOTOcph @vitalethomas
  13. Goals 2 Reduced cognitive load 3 Clear path to production

    1 Rapid and continuous feedback loop #GOTOcph @vitalethomas
  14. Delivering Value From code to production Developer App Repo Production

    Application Operator Security Expert Platform Engineer
  15. Goals 2 Reduced cognitive load 3 Clear path to production

    1 Rapid and continuous feedback loop #GOTOcph @vitalethomas
  16. Resources Source code • Presentation source code • Kadras: Application

    Platform Toolkit • 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 #GOTOcph @vitalethomas
  17. Discount codes Manning • 35% discount code, valid for all

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