<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Dapr Jobs .NET SDK on Dapr 文档库</title><link>https://v1-18.docs.dapr.io/zh-hans/developing-applications/sdks/dotnet/dotnet-jobs/</link><description>Recent content in Dapr Jobs .NET SDK on Dapr 文档库</description><generator>Hugo</generator><language>zh-hans</language><atom:link href="https://v1-18.docs.dapr.io/zh-hans/developing-applications/sdks/dotnet/dotnet-jobs/index.xml" rel="self" type="application/rss+xml"/><item><title>如何：在 .NET SDK 中编写和管理 Dapr 任务</title><link>https://v1-18.docs.dapr.io/zh-hans/developing-applications/sdks/dotnet/dotnet-jobs/dotnet-jobs-howto/</link><pubDate>Mon, 01 Jan 0001 00:00:00 +0000</pubDate><guid>https://v1-18.docs.dapr.io/zh-hans/developing-applications/sdks/dotnet/dotnet-jobs/dotnet-jobs-howto/</guid><description>&lt;p>我们来创建一个端点，该端点将在 Dapr 任务触发时被调用，然后在同一个应用中调度该任务。我们将使用&lt;a href="https://github.com/dapr/dotnet-sdk/tree/master/examples/Jobs">此处提供的简单示例&lt;/a>，进行以下演示，并通过它来解释如何使用间隔或 Cron 表达式自行调度一次性或重复性任务。在本指南中，您将：&lt;/p>
&lt;ul>
&lt;li>部署一个 .NET Web API 应用程序 (&lt;a href="https://github.com/dapr/dotnet-sdk/tree/master/examples/Jobs/JobsSample">JobsSample&lt;/a>)&lt;/li>
&lt;li>利用 Dapr .NET 任务 SDK 调度任务调用并设置被触发的端点&lt;/li>
&lt;/ul>
&lt;p>在 .NET 示例项目中：&lt;/p>
&lt;ul>
&lt;li>主要的 &lt;a href="https://github.com/dapr/dotnet-sdk/tree/master/examples/Jobs/JobsSample/Program.cs">&lt;code>Program.cs&lt;/code>&lt;/a> 文件是整个演示的核心。&lt;/li>
&lt;/ul>
&lt;h2 id="前提条件">前提条件&lt;/h2>
&lt;ul>
&lt;li>&lt;a href="https://docs.dapr.io/getting-started/install-dapr-cli/">Dapr CLI&lt;/a>&lt;/li>
&lt;li>&lt;a href="https://docs.dapr.io/getting-started/install-dapr-selfhost">初始化的 Dapr 环境&lt;/a>&lt;/li>
&lt;li>已安装 &lt;a href="https://dotnet.microsoft.com/download/dotnet/6.0">.NET 6&lt;/a>、&lt;a href="https://dotnet.microsoft.com/download/dotnet/8.0">.NET 8&lt;/a> 或 &lt;a href="https://dotnet.microsoft.com/download/dotnet/9.0">.NET 9&lt;/a>&lt;/li>
&lt;li>项目中已安装 &lt;a href="https://www.nuget.org/packages/Dapr.Jobs">Dapr.Jobs&lt;/a> NuGet 包&lt;/li>
&lt;/ul>


&lt;div class="alert alert-primary" role="alert">
&lt;h4 class="alert-heading">注意&lt;/h4>

 请注意，虽然 .NET 6 是 Dapr v1.15 中支持的最低版本，但从 v1.16 开始，Dapr 仅支持 .NET 8 和 .NET 9。

&lt;/div>

&lt;h2 id="设置环境">设置环境&lt;/h2>
&lt;p>克隆 &lt;a href="https://github.com/dapr/dotnet-sdk">.NET SDK 仓库&lt;/a>。&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" style="background-color:#f8f8f8;-moz-tab-size:4;-o-tab-size:4;tab-size:4;">&lt;code class="language-sh" data-lang="sh">&lt;span style="display:flex;">&lt;span>git clone https://github.com/dapr/dotnet-sdk.git
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>从 .NET SDK 根目录，导航到 Dapr 任务示例。&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" style="background-color:#f8f8f8;-moz-tab-size:4;-o-tab-size:4;tab-size:4;">&lt;code class="language-sh" data-lang="sh">&lt;span style="display:flex;">&lt;span>&lt;span style="color:#204a87">cd&lt;/span> examples/Jobs
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;h2 id="本地运行应用程序">本地运行应用程序&lt;/h2>
&lt;p>要运行 Dapr 应用程序，您需要启动 .NET 程序和一个 Dapr sidecar。导航到 &lt;code>JobsSample&lt;/code> 目录。&lt;/p></description></item><item><title>DaprJobsClient 使用指南</title><link>https://v1-18.docs.dapr.io/zh-hans/developing-applications/sdks/dotnet/dotnet-jobs/dotnet-jobsclient-usage/</link><pubDate>Mon, 01 Jan 0001 00:00:00 +0000</pubDate><guid>https://v1-18.docs.dapr.io/zh-hans/developing-applications/sdks/dotnet/dotnet-jobs/dotnet-jobsclient-usage/</guid><description>&lt;h2 id="生命周期管理">生命周期管理&lt;/h2>
&lt;p>&lt;code>DaprJobsClient&lt;/code> 是专门用于与 Dapr Jobs API 交互的 Dapr 客户端。它可以与 &lt;code>DaprClient&lt;/code> 和其他 Dapr 客户端一起注册而不会出现问题。&lt;/p>
&lt;p>它通过 TCP 套接字与 Dapr sidecar 通信，并实现了 &lt;code>IDisposable&lt;/code> 接口以便快速清理资源。&lt;/p>
&lt;p>为了获得最佳性能，建议创建一个长生命周期的 &lt;code>DaprJobsClient&lt;/code> 实例，并在整个应用程序中共享使用。&lt;code>DaprJobsClient&lt;/code> 实例是线程安全的，适合在多个线程中共享。&lt;/p>
&lt;p>可以通过依赖注入来实现这一点。注册方法支持以单例、作用域实例或瞬态方式注册，但也可以利用 &lt;code>IConfiguration&lt;/code> 或其他注入服务中的值进行注册，这样就不需要在每个类中重新创建客户端。&lt;/p>
&lt;p>避免为每个操作创建一个新的 &lt;code>DaprJobsClient&lt;/code> 并在操作完成后销毁它。&lt;/p>
&lt;h2 id="通过-daprjobsclientbuilder-配置-daprjobsclient">通过 DaprJobsClientBuilder 配置 DaprJobsClient&lt;/h2>
&lt;p>可以通过 &lt;code>DaprJobsClientBuilder&lt;/code> 类上的方法来配置 &lt;code>DaprJobsClient&lt;/code>，然后调用 &lt;code>.Build()&lt;/code> 来创建客户端。每个 &lt;code>DaprJobsClient&lt;/code> 的设置是独立的，调用 &lt;code>.Build()&lt;/code> 后无法更改。&lt;/p>
&lt;div class="highlight">&lt;pre tabindex="0" style="background-color:#f8f8f8;-moz-tab-size:4;-o-tab-size:4;tab-size:4;">&lt;code class="language-cs" data-lang="cs">&lt;span style="display:flex;">&lt;span>&lt;span style="color:#204a87;font-weight:bold">var&lt;/span> &lt;span style="color:#000">daprJobsClient&lt;/span> &lt;span style="color:#000;font-weight:bold">=&lt;/span> &lt;span style="color:#204a87;font-weight:bold">new&lt;/span> &lt;span style="color:#000">DaprJobsClientBuilder&lt;/span>&lt;span style="color:#000;font-weight:bold">()&lt;/span>
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#000;font-weight:bold">.&lt;/span>&lt;span style="color:#000">UseDaprApiToken&lt;/span>&lt;span style="color:#000;font-weight:bold">(&lt;/span>&lt;span style="color:#4e9a06">&amp;#34;abc123&amp;#34;&lt;/span>&lt;span style="color:#000;font-weight:bold">)&lt;/span> &lt;span style="color:#8f5902;font-style:italic">// 指定用于验证到其他 Dapr sidecar 的 API 令牌&lt;/span>
&lt;/span>&lt;/span>&lt;span style="display:flex;">&lt;span> &lt;span style="color:#000;font-weight:bold">.&lt;/span>&lt;span style="color:#000">Build&lt;/span>&lt;span style="color:#000;font-weight:bold">();&lt;/span>
&lt;/span>&lt;/span>&lt;/code>&lt;/pre>&lt;/div>&lt;p>&lt;code>DaprJobsClientBuilder&lt;/code> 包含以下设置：&lt;/p>
&lt;ul>
&lt;li>Dapr sidecar 的 HTTP 端点&lt;/li>
&lt;li>Dapr sidecar 的 gRPC 端点&lt;/li>
&lt;li>用于配置 JSON 序列化的 &lt;code>JsonSerializerOptions&lt;/code> 对象&lt;/li>
&lt;li>用于配置 gRPC 的 &lt;code>GrpcChannelOptions&lt;/code> 对象&lt;/li>
&lt;li>用于验证请求到 sidecar 的 API 令牌&lt;/li>
&lt;li>用于创建 SDK 使用的 &lt;code>HttpClient&lt;/code> 实例的工厂方法&lt;/li>
&lt;li>用于在向 sidecar 发出请求时使用的 &lt;code>HttpClient&lt;/code> 实例的超时&lt;/li>
&lt;/ul>
&lt;p>SDK 将读取以下环境变量来配置默认值：&lt;/p></description></item></channel></rss>