我昨天写了一篇关于在微服务应用程序中采用Dapr的好处的文章《从服务之间的调用来看 我们为什么需要Dapr》[1], 在那篇文章中,我们专注于"服务调用"构建块 [2]。在这篇文章中,我想向你展现一个特别有用的功能,它是由"绑定"构建块[3]实现的。

Dapr 绑定

Dapr 中的"绑定"概念对于任何使用过 Azure Functions 的人来说都很熟悉,它们揭示了与各种第三方服务交互的简化方式,可以说微软的技术都是一脉相承的,Dapr 就是毫不夸张的来说就是微软技术的集大成者。

绑定可以是"输入"或"输出"。输入绑定(也称为"触发器")允许 Dapr 订阅外部系统中的事件,并在服务上调用终结点,以便您知道发生了什么。Azure 中的良好示例是订阅事件网格上的事件[4]或服务总线[5]上的消息。但是有许多受支持的绑定,包括Twitter之类的东西,因此每当有符合您的搜索条件的推文时,您都可以收到通知。

输出绑定允许您将数据发送到外部服务。在 Azure 中,这可能是将消息发布到队列将文档写入 Cosmos DB[6]。或者您可以使用它给Twilio发送短信[7]。

绑定的优点和缺点

绑定的一个优点是,它们可以大大简化应用程序代码,因为它们消除了连接到服务通常需要的许多繁琐的模板代码。

另一个优点是它们提供了一定程度的抽象。虽然由于某些绑定处理的数据具有特定于服务的性质,因此无法与其他替代项交换,但交换组件的功能在开发/测试环境中可能非常有用,因为在开发/测试环境中,你可能不希望或不需要与实际服务进行实际通信。

绑定的主要缺点是,它们通常只公开基础平台功能的相当有限的子集,按照二八原则,通常这个可以满足我们80%场景的需求了,从这个角度来看也不是什么缺点了,你同意我的看法吗?因此,如果您是高级用户,那么您可能更喜欢直接使用服务的SDK。当然,Dapr不会阻止你这样做 - 绑定是完全可选的功能。

Cron绑定

我想特别给你介绍的"cron"绑定[8]是一个特例。它不支持连接到外部系统,它却可以轻松设置计划任务。要进行此设置,您需要定义一个组件 YAML 文件。我这里用官方文档里的一个示例[8] 进行说明,您可以自定义 以满足您的需求。这支持常规的 cron 语法和一些简化的快捷方式,例如每十五分钟一次,如下所示。

apiVersion: dapr.io/v1alpha1

kind: Component

metadata:
   name: <NAME>
   namespace: <NAMESPACE>

spec:
   type: bindings.cron
   version: v1
   metadata:
   - name: schedule
     value: "@every 15m" # valid cron schedule

scopes:

- catalog

我所做的唯一"高级"操作是通过使用 scopes 属性[9]将此组件限制为仅应用于单个 Dapr 服务- 在此示例中为服务catalog ,现在,我们需要做的就是在与组件名称匹配的终结点上进行侦听。在此示例中,它称为scheduled .请注意,这将作为 HTTP POST请求发出,因此在下面的示例中,我将演示简单的 Node.js Express 应用程序如何在端点上接收调用并向控制台写入消息。

app.post('/scheduled', async function(req, res){
   console.log("scheduled endpoint called", req.body)
   res.status(200).send()

});

如果我们运行此命令,我们将看到 Dapr 边车每五分钟调用一次终结点/scheduled。 如果在你的项目中没有计划任务的解决方案,Dapr提供了如此简单易用的开箱即用选项真是太好了。

Dapr 的绑定还有很多功能,详细了解可以参考下面几篇文章:

相关链接

在 Dapr 中使用 Cron 绑定的计划任务的更多相关文章

  1. 通过Linux系统Cron执行OwnCloud计划任务

    通过Linux系统Cron执行OwnCloud计划任务 02/02/2013 CRON的确是一个非常有用的功能,它有效减少了系统的负载,在将WordPress和StatusNet的任务计划都转换到Cr ...

  2. Web项目中定时任务无法绑定SessionFactory的问题解决

    正常我们在web开发中,由于需要在页面上或者脱离事务时使用到懒加载对应的对象,一般都采用Open Session In View模式.   Open Session In View   OpenSes ...

  3. jQuery中的事件绑定方法

    在jQuery中,事件绑定方法大致有四种:bind(),live(), delegate(),和on(). 那么在工作中应该如何选择呢?首先要了解四种方法的区别和各自的特点. 在了解这些之前,首先要知 ...

  4. SpringMVC中使用Cron表达式的定时器

    SpringMVC中使用Cron表达式的定时器 cron(定时策略)简要说明 顺序: 秒 分 时 日 月 星期 年份 (7个参数,空格隔开各个参数,年份非必须参数) 通配符: , 如果分钟位置为* 1 ...

  5. MVC中Action参数绑定的过程

    一.题外话 上一篇:MVC中Action的执行过程 ControllerContext 封装有了与指定的 RouteBase 和 ControllerBase 实例匹配的 HTTP 请求的信息. 二. ...

  6. activity中实现Spinner绑定

    (1)须要一个基本的布局文件activity_main <RelativeLayout xmlns:android="http://schemas.android.com/apk/re ...

  7. Jquery中的事件绑定$(&quot;#btn&quot;).bind(&quot;click&quot;,function(){ })

    Jquery中的事件绑定:$("#btn").bind("click",function(){  }) 由于每次都这么调用太麻烦,所以jquery就用$(&qu ...

  8. Asp.net Mvc 中的模型绑定

    asp.net mvc中的模型绑定可以在提交http请求的时候,进行数据的映射. 1.没有模型绑定的时候 public ActionResult Example0() { ) { string id ...

  9. AngularJS中数据双向绑定(two-way data-binding)

    1.切换工作目录 git checkout step-4 #切换分支,切换到第4步 npm start #启动项目 2.代码 app/index.html Search: <input ng-m ...

随机推荐

  1. Jenkins+Sonar质量门禁【实践篇-maven版】

    Jenkins+Sonar质量门禁[实践篇-maven版] 配置文档百度挺多的,就不展开来了 首先很遗憾的告诉大家,maven版做不了质量门禁!只能扫描!!!     就我们公司项目里,jenkins ...

  2. 预训练模型时代:告别finetune, 拥抱adapter

    NLP论文解读 原创•作者 |FLIPPED 研究背景 随着计算算力的不断增加,以transformer为主要架构的预训练模型进入了百花齐放的时代.BERT.RoBERTa等模型的提出为NLP相关问题 ...

  3. 编写Java程序,创建一个父类交通工具类(Vehicles),以及两个子类,分别是轿车类(Car)和卡车类(Truck)。

    返回本章节 返回作业目录 需求说明: 创建一个父类交通工具类(Vehicles),以及两个子类,分别是轿车类(Car)和卡车类(Truck). 父类有属性品牌(brand)和颜色(color). 在父 ...

  4. mysql编译报错

    1.make报错现象 Warning: Bison executable not found in PATH 解决办法 yum -y install bison 2.make报错现象 ake Erro ...

  5. CSS过渡、CSS动画

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"/> <script s ...

  6. vue 在实现关键字远程搜索时出现数据不准确的原因

    实现通过输入关键字查询项目, 页面搜索规则框部分 js部分 之前通过在data中定义一个变量,然后在methods中filterFn方法获取当时输入的值去后台请求数据,然后把请求的数据存放在state ...

  7. MySQL提权之mof提权

    mof提权原理 关于 mof 提权的原理其实很简单,就是利用了 c:/windows/system32/wbem/mof/ 目录下的 nullevt.mof 文件,每分钟都会在一个特定的时间去执行一次 ...

  8. 日K蜡烛图

    股票价格涨跌趋势,常用蜡烛图技术中的K线图来表示,分为按日的日K线.按周的周K线.按月的月K线等.以日K线为例,每天股票价格从开盘到收盘走完一天,对应一根蜡烛小图,要表示四个价格:开盘价格Open(早 ...

  9. k8s的应用包管理工具helm的部署和使用

    1.概述 我们一般是在k8s里面部署一些简单的应用,比如用deployment,daemonset,statefuleset的方式来部署应用,但是如果要部署一些复杂的应用,那么整个配置的编写.部署的过 ...

  10. 《剑指offer》面试题18. 删除链表的节点

    问题描述 给定单向链表的头指针和一个要删除的节点的值,定义一个函数删除该节点. 返回删除后的链表的头节点. 注意:此题对比原题有改动 示例 1: 输入: head = [4,5,1,9], val = ...