如何使用多应用运行模板文件

解压多应用运行模板文件及其属性

多应用运行模板文件是一个 YAML 文件,您可以使用它一次运行多个应用。在本指南中,您将学习如何:

  • 使用多应用运行模板
  • 查看已启动的应用
  • 停止多应用运行模板
  • 结构化多应用运行模板文件

使用多应用运行模板

您可以通过以下两种方式之一使用多应用运行模板文件:

通过提供目录路径执行

当您提供目录路径时,CLI 会在该目录中寻找名为 dapr.yaml 的多应用运行模板文件。如果找不到该文件,CLI 会返回错误。

执行以下 CLI 命令以读取默认名为 dapr.yaml 的多应用运行模板文件:


# 如果给定目录路径,模板文件需要默认命名为 `dapr.yaml`

dapr run -f <dir_path>

dapr run -f <dir_path> -k 

通过提供文件路径执行

如果多应用运行模板文件的名称不是 dapr.yaml,您可以将相对或绝对文件路径提供给命令:


dapr run -f ./path/to/<your-preferred-file-name>.yaml

dapr run -f ./path/to/<your-preferred-file-name>.yaml -k 

查看已启动的应用

一旦多应用模板正在运行,您可以使用以下命令查看已启动的应用:


dapr list

dapr list -k 

停止多应用运行模板

您可以随时使用以下任一命令停止多应用运行模板:


# 如果给定目录路径,模板文件需要默认命名为 `dapr.yaml`

dapr stop -f <dir_path>

或:

dapr stop -f ./path/to/<your-preferred-file-name>.yaml

# 如果给定目录路径,模板文件需要默认命名为 `dapr.yaml`

dapr stop -f <dir_path> -k

或:

dapr stop -f ./path/to/<your-preferred-file-name>.yaml -k 

模板文件结构

多应用运行模板文件可以包含以下属性。下面是一个示例模板,展示了两个应用及其配置的一些属性。


version: 1
common: # 可选部分,用于跨应用共享变量
  resourcesPath: ./app/components # 任何要跨应用共享的 dapr 资源
  env:  # 任何跨应用共享的环境变量
    DEBUG: true
apps:
  - appID: webapp # 可选
    appDirPath: .dapr/webapp/ # 必需
    resourcesPath: .dapr/resources # 已弃用
    resourcesPaths: .dapr/resources # 逗号分隔的资源路径。(可选)可以按约定保留为默认值。
    appChannelAddress: 127.0.0.1 # 应用监听的网络地址。(可选)可以按约定保留为默认值。
    configFilePath: .dapr/config.yaml # (可选)也可以按约定为默认值,如果未找到文件则忽略。
    appProtocol: http
    appPort: 8080
    appHealthCheckPath: "/healthz"
    command: ["python3", "app.py"]
    appLogDestination: file # (可选),可以是 file, console 或 fileAndConsole。默认是 fileAndConsole。
    daprdLogDestination: file # (可选),可以是 file, console 或 fileAndConsole。默认是 file。
  - appID: backend # 可选
    appDirPath: .dapr/backend/ # 必需
    appProtocol: grpc
    appPort: 3000
    unixDomainSocket: "/tmp/test-socket"
    env:
      DEBUG: false
    command: ["./backend"]

模板文件中所有路径适用以下规则:

  • 如果路径是绝对的,则按原样使用。
  • common 部分下的所有相对路径应相对于模板文件路径提供。
  • apps 部分下的 appDirPath 应相对于模板文件路径提供。
  • apps 部分下的所有其他相对路径应相对于 appDirPath 提供。

version: 1
common: # 可选部分,用于跨应用共享变量
  env:  # 任何跨应用共享的环境变量
    DEBUG: true
apps:
  - appID: webapp # 可选
    appDirPath: .dapr/webapp/ # 必需
    appChannelAddress: 127.0.0.1 # 应用监听的网络地址。(可选)可以按约定保留为默认值。
    appProtocol: http
    appPort: 8080
    appHealthCheckPath: "/healthz"
    appLogDestination: file # (可选),可以是 file, console 或 fileAndConsole。默认是 fileAndConsole。
    daprdLogDestination: file # (可选),可以是 file, console 或 fileAndConsole。默认是 file。
    containerImage: ghcr.io/dapr/samples/hello-k8s-node:latest # (可选)在 Kubernetes 开发/测试环境中部署时使用的容器镜像 URI。
    createService: true # (可选)在开发/测试环境中部署应用时创建 Kubernetes 服务。
  - appID: backend # 可选
    appDirPath: .dapr/backend/ # 必需
    appProtocol: grpc
    appPort: 3000
    unixDomainSocket: "/tmp/test-socket"
    env:
      DEBUG: false

模板文件中所有路径适用以下规则:

  • 如果路径是绝对的,则按原样使用。
  • apps 部分下的 appDirPath 应相对于模板文件路径提供。
  • app 部分下的所有相对路径应相对于 appDirPath 提供。

模板属性


多应用运行模板的属性与 dapr run CLI 标志对齐,在 CLI 参考文档中列出

属性必需详情示例
appDirPathY应用代码的路径./webapp/, ./backend/
appIDN应用的 app ID。如果未提供,将从 appDirPath 派生webapp, backend
resourcesPathN已弃用。Dapr 资源的路径。可以按约定为默认值./app/components, ./webapp/components
resourcesPathsN逗号分隔的 Dapr 资源路径。可以按约定为默认值./app/components, ./webapp/components
appChannelAddressN应用监听的网络地址。可以按约定保留为默认值。127.0.0.1
configFilePathN应用配置文件的路径./webapp/config.yaml
appProtocolNDapr 用于与应用通信的协议。http, grpc
appPortN应用监听的端口8080, 3000
daprHTTPPortNDapr HTTP 端口
daprGRPCPortNDapr GRPC 端口
daprInternalGRPCPortNDapr 内部 API 监听的 gRPC 端口;用于从本地 DNS 组件解析值时
metricsPortNDapr 发送其指标信息的端口
unixDomainSocketNUnix 域套接字目录挂载的路径。如果指定,与 Dapr 边车的通信使用 Unix 域套接字,与使用 TCP 端口相比,具有更低的延迟和更高的吞吐量。在 Windows 上不可用。/tmp/test-socket
profilePortN配置文件服务器监听的端口
enableProfilingN通过 HTTP 端点启用分析
apiListenAddressesNDapr API 监听地址
logLevelN日志详细程度。
appMaxConcurrencyN应用的并发级别;默认是无限制
placementHostAddressN
appSSLN启用 https,当 Dapr 调用应用时
daprHTTPMaxRequestSizeN请求体的最大大小(MB)。
daprHTTPReadBufferSizeNHTTP 读取缓冲区的最大大小(KB)。这也限制了 HTTP 头的最大大小。默认是 4 KB
enableAppHealthCheckN启用应用的健康检查true, false
appHealthCheckPathN健康检查文件的路径/healthz
appHealthProbeIntervalN应用健康探测的间隔(秒)
appHealthProbeTimeoutN应用健康探测的超时时间(毫秒)
appHealthThresholdN应用被认为不健康的连续失败次数
enableApiLoggingN启用从应用到 Dapr 的所有 API 调用的日志记录
runtimePathNDapr 运行时安装路径
envN环境变量的映射;每个应用应用的环境变量将覆盖跨应用共享的环境变量DEBUG, DAPR_HOST_ADD
appLogDestinationN输出应用日志的日志目标;其值可以是 file, console 或 fileAndConsole。默认是 fileAndConsolefile, console, fileAndConsole
daprdLogDestinationN输出 daprd 日志的日志目标;其值可以是 file, console 或 fileAndConsole。默认是 filefile, console, fileAndConsole

下一步

观看此视频以了解多应用运行的概述


多应用运行模板的属性与 dapr run -k CLI 标志对齐,在 CLI 参考文档中列出

属性必需详情示例
appDirPathY应用代码的路径./webapp/, ./backend/
appIDN应用的 app ID。如果未提供,将从 appDirPath 派生webapp, backend
appChannelAddressN应用监听的网络地址。可以按约定保留为默认值。127.0.0.1
appProtocolNDapr 用于与应用通信的协议。http, grpc
appPortN应用监听的端口8080, 3000
daprHTTPPortNDapr HTTP 端口
daprGRPCPortNDapr GRPC 端口
daprInternalGRPCPortNDapr 内部 API 监听的 gRPC 端口;用于从本地 DNS 组件解析值时
metricsPortNDapr 发送其指标信息的端口
unixDomainSocketNUnix 域套接字目录挂载的路径。如果指定,与 Dapr 边车的通信使用 Unix 域套接字,与使用 TCP 端口相比,具有更低的延迟和更高的吞吐量。在 Windows 上不可用。/tmp/test-socket
profilePortN配置文件服务器监听的端口
enableProfilingN通过 HTTP 端点启用分析
apiListenAddressesNDapr API 监听地址
logLevelN日志详细程度。
appMaxConcurrencyN应用的并发级别;默认是无限制
placementHostAddressN
appSSLN启用 https,当 Dapr 调用应用时
daprHTTPMaxRequestSizeN请求体的最大大小(MB)。
daprHTTPReadBufferSizeNHTTP 读取缓冲区的最大大小(KB)。这也限制了 HTTP 头的最大大小。默认是 4 KB
enableAppHealthCheckN启用应用的健康检查true, false
appHealthCheckPathN健康检查文件的路径/healthz
appHealthProbeIntervalN应用健康探测的间隔(秒)
appHealthProbeTimeoutN应用健康探测的超时时间(毫秒)
appHealthThresholdN应用被认为不健康的连续失败次数
enableApiLoggingN启用从应用到 Dapr 的所有 API 调用的日志记录
envN环境变量的映射;每个应用应用的环境变量将覆盖跨应用共享的环境变量DEBUG, DAPR_HOST_ADD
appLogDestinationN输出应用日志的日志目标;其值可以是 file, console 或 fileAndConsole。默认是 fileAndConsolefile, console, fileAndConsole
daprdLogDestinationN输出 daprd 日志的日志目标;其值可以是 file, console 或 fileAndConsole。默认是 filefile, console, fileAndConsole
containerImageN在 Kubernetes 开发/测试环境中部署时使用的容器镜像 URI。ghcr.io/dapr/samples/hello-k8s-python:latest
createServiceN在开发/测试环境中部署应用时创建 Kubernetes 服务。true, false

下一步

观看此视频以了解 Kubernetes 中多应用运行的概述