Initialize Dapr in your local environment

Fetch the Dapr sidecar binaries and install them locally using dapr init

Now that you’ve installed the Dapr CLI, use the CLI to initialize Dapr on your local machine.

Dapr runs as a sidecar alongside your application. In self-hosted mode, this means it is a process on your local machine. By initializing Dapr, you:

  • Fetch and install the Dapr sidecar binaries locally.
  • Create a development environment that streamlines application development with Dapr.

Dapr initialization includes:

  1. Running a Redis container instance to be used as a local state store and message broker.
  2. Running a Zipkin container instance for observability.
  3. Creating a default components folder with component definitions for the above.
  4. Running a Dapr placement service container instance for local actor support.

Docker

The recommended development environment requires Docker. While you can initialize Dapr without a dependency on Docker), the next steps in this guide assume the recommended Docker development environment.

You can also install Podman in place of Docker. Read more about initializing Dapr using Podman.

Step 1: Open an elevated terminal

You will need to use sudo for this quickstart if:

  • You run your Docker commands with sudo, or
  • The install path is /usr/local/bin (default install path).

Run Windows Terminal or command prompt as administrator.

  1. Right click on the Windows Terminal or command prompt icon.
  2. Select Run as administrator.

Step 2: Run the init CLI command

Install the latest Dapr runtime binaries:

  1. dapr init

Step 3: Verify Dapr version

  1. dapr --version

Output:

CLI version: 1.12.0
Runtime version: 1.12.0

Step 4: Verify containers are running

As mentioned earlier, the dapr init command launches several containers that will help you get started with Dapr. Verify you have container instances with daprio/dapr, openzipkin/zipkin, and redis images running:

  1. docker ps

Output:

Init Dapr locally - 图1

Step 5: Verify components directory has been initialized

On dapr init, the CLI also creates a default components folder that contains several YAML files with definitions for a state store, Pub/sub, and Zipkin. The Dapr sidecar will read these components and use:

  • The Redis container for state management and messaging.
  • The Zipkin container for collecting traces.

Verify by opening your components directory:

  1. ls $HOME/.dapr

Output:

bin components config.yaml

  1. explorer "%USERPROFILE%\.dapr\"

Result:

Init Dapr locally - 图2

Next step: Use the Dapr API >>

Last modified October 12, 2023: Update config.toml (#3826) (0ffc2e7)