What is DAPR?¶
Purpose¶
This "mini-blog" focuses in on DAPR. DAPR, which stands for Distriuted Application Runtime", is a CNCF Incubation Project. (dapr.io) DAPR was contributed by Microsoft.
Per the website, ... "Dapr provides integrated APIs for communication, state, and workflow. Dapr leverages industry best practices for security, resiliency, and observability, so you can focus on your code."
The goal is to answer the following questions here.
- What is "DAPR"? ( hint: "Distributed Application Runtime)
- What value does it provide?
- How does it work? .. especially in the context of Kubernetes.
- If I use this, what are the implications to my application?
- Why would I use DAPR?
Background¶
Before diving in, I thought it valuable to highlight some key observations that have come to light as I've been investigating DAPR.
- For those of you that have read through my Microservices blog posts on this site, you may notice, if you "squint" long enought my thoughts of a "Butler Service" to the role of DAPR. Take a look.
- In order to understand how DAPR works, it helps to understand Operators. I have a view that has been documented HERE, that MAY help. [ still needs some cleanup work.]
- Finally, in order to understand how DAPR works within a Kubernetes cluster, it is important to have a good understanding of how kubernetes works. Again, another point of reference.
Key Points relative to how it is used in Kubernetes¶
The Structure and relationship of the pieces¶
The following walks throught the major points in the picture below.
- First, DAPR is deployed within a Kubernetes (K8s) Cluster. This needs to/should be done before you start to provision your application into the cluster. The DAPR system pods ( it's all containerized ) run in there own namespace.
- Like all other services deployed in K8s, the DAPR services register themselves with the cluster and their state is managed in the etcd service. DAPR is an Operator driven service. Hence, the DAPR Operator monitors etcd for situations where applications indicate that they want to use utilize DAPR to enable communicate between microservices, and other services. The later will be discussed in the next section.
- When the Operator notices that the use of a DAPR sidecar is requested, it leverages a sidecar injector to add the container to the Pod registered to use it.
- Applications are made up of 1 to N MicroServices, and potentialy supporting services, working together.
- K8s knows about the application configuration using the Kubernetes Deployment and Service YAML files.
- In order to register interest to use DAPR, the Deployment.Yaml file needs to add a specific annotation that indicates interest in DAPR, and helps DAPR know what the MicroService is. This is registered within the etcd service and noticed by the DAPR Operator.
- It is important to note that for all this to work, you need to define names and paths for each MicroService.
- Simply naming things is not enough, DAPR does need to have an understanding of the App Microservices. Specifically the names you have assigned. Remember, it is going to be the "butler" ( per my earlier blogs ). In order to properly route work and help connect services, it needs to know the names, along with other important information. This is done in the YAML that configures the DAPR system in your K8s Cluster.
- When using DAPR, the MicroServices call each other via the sidecars running in the same pod. The request is directed to the sidecar using the name of the target Service. DAPR will faciliate this communication flow, passing the payload, via an HTTPS or GRPC connection. It also enforces certificate (TLS) based communication.
A Walkthrough of the flow: examples¶
Placeholder
Why should I use DAPR?¶
Some views on why DAPR is helpful:
- Provides a more configuratble and flexible approach to integrating microservices AND supporting services (e.g. "Components" )
- Founded on an application topology based approach.
- Can be used to reduce hard dependencies between microservices. How: they just reference a name of a microservice. DAPR does the rest.
- Is an enabler of security between microservices. i.e. the mTLS connections.
- Centered on enabling an event driven, microservices architecture.
- Fully declarative approach. ( YAML driven )
- Enables flexibility interacting with services within Kubernetes and services running outside of Kubernetes.
- can substitute implementation simply by changing configuration
- Sidecar architecture limits the embedding of libraries etc... [ Non-Invasive ]
What this means to applications?¶
If an application architect wants to leverage the use of DAPR there some implications relative to the application architecture. These include, but are not limited to....
- You are required to leverage a DAPR SDK in your app to enable access to DAPR Building Blocks
- The DAPR operator, and supporting services need to be running in your Kubernetes cluster.
- You need to layout a naming standard for your app so that your MicroServices can issue calls to other microservices using the app names
- It will probably help to create a component model view
- You will be adding additional resource consumers to your K8S cluster. ( DAPR system and sidecars )
Supporting Information¶
- https://dapr.io
- https://youtu.be/mBgQBMhboyU?si=j4GAi-2LJEgKdw8d
- https://www.techtarget.com/searchitoperations/tutorial/Use-Dapr-on-Kubernetes-to-build-microservices-in-production
- https://docs.dapr.io/operations/hosting/kubernetes/kubernetes-overview/
- https://github.com/dapr/quickstarts/blob/master/tutorials/hello-kubernetes/README.md
- https://github.com/dapr/quickstarts/blob/master/tutorials/hello-kubernetes/python/app.py
- https://sookocheff.com/post/dapr/running-a-dapr-application-on-kubernetes/
- https://docs.dapr.io/operations/components/
- https://docs.dapr.io/developing-applications/building-blocks/pubsub/howto-publish-subscribe/#step-3-publish-a-topic
- https://docs.dapr.io/developing-applications/building-blocks/pubsub/subscription-methods/
- https://www.diagrid.io/blog/k8s-dapr-top3
- https://docs.dapr.io/concepts/components-concept/
- https://itnext.io/simplifying-microservices-on-kubernetes-with-microsofts-dapr-distributed-application-runtime-9aece5723484
How does DAPR differ from a Service Mesh such as Istio¶
This content was provided by Google Gemini 2.0 and reviewed for accuracy
Relationship and Differences between DAPR and Istio
While both DAPR and Istio aim to simplify microservices development, they have distinct focuses and approaches:
DAPR (Distributed Application Runtime):
- Focus: Provides building blocks for distributed applications, including service-to-service invocation, state management, pub/sub, and more. It's designed to be application-centric, offering a set of APIs that developers can use to interact with these building blocks.
- Implementation: DAPR runs as a sidecar container alongside your application. It handles the underlying plumbing for interacting with the building blocks, abstracting away the complexity of the underlying infrastructure.
Istio:
- Focus: A service mesh primarily focused on traffic management, security, and observability for microservices. It intercepts and controls all network traffic between services.
- Implementation: Istio also uses sidecar proxies (Envoy) to intercept and control network traffic. However, its primary focus is on network-level concerns like routing, load balancing, and security.
Key Differences
- Scope: DAPR is broader, offering a wider range of building blocks beyond service-to-service communication. Istio is more specialized, focusing on network-level concerns.
- API Surface: DAPR provides APIs for developers to interact with its building blocks, whereas Istio primarily operates at the network level.
- Configuration: DAPR is typically configured through annotations or environment variables within the application. Istio uses its own configuration language and control plane.
DAPR is not a Service Mesh
While both use sidecars and address aspects of microservices communication, DAPR is not a service mesh in the traditional sense. It doesn't primarily focus on intercepting and managing network traffic like Istio. Instead, it provides a set of APIs and building blocks that can be used to build distributed applications.
Pros of using DAPR
- Developer Productivity: DAPR simplifies development by abstracting away the complexity of distributed systems. Developers can focus on application logic rather than infrastructure concerns.
- Portability: DAPR can run on various platforms (Kubernetes, VMs, etc.), making it easier to move applications between environments.
- Building Blocks: Provides a set of reusable building blocks that can be used across different applications.
- Community and Ecosystem: DAPR has a growing community and ecosystem of tools and integrations.
Cons of using DAPR
- Learning Curve: Developers need to learn the DAPR API and how to use its building blocks.
- Overhead: Introducing another sidecar container can add overhead to the application.
- Dependencies: Applications become dependent on the DAPR runtime.
In summary:
Both DAPR and Istio aim to simplify microservices development. However, they have different focuses and approaches. DAPR provides building blocks for distributed applications, while Istio focuses on network-level traffic management. The choice between them depends on the specific needs and priorities of your project.