分布式任务调度框架(Temporal)介绍

Temporal是一款基于Golang的分布式任务调度框架,具备任务管理、集群管理、编程能力和Web界面管理功能。文章介绍了Temporal的基本能力,通过一个延时发送短信和邮件的示例展示了其工作流程,包括Workflow的编写、Workers的启动和TemplateServer的部署。Temporal旨在提供工作流编排和C/S架构支持,适合需要确保任务执行成功的场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

分布式任务调度框架基本能力:

  1. 任务管理能力(增删改查、执行、定时执行、延时执行、健康监控)
  2. 集群管理能力(扩展简单、效率高)
  3. 编程能力(运行代码)
  4. Web界面管理

目前市面上有很多可用于处理分布式任务的开源框架,比如Elastic-JobXXL-JobQuartz等等,它们或多或少都能满足以上列出的各项基本能力,然而,它们都是以Java系语言编写的,这不禁让人产生疑问,难道Go就没有自己的开源任务调度框架吗?

经过在网络上一番翻箱倒柜,找到了类似gocrongocraft/workrobfig/cron等一系列工具。然而它们或者年久失修;或者不足以称之为框架(顶多是个三方库);或者没有界面;等等问题不一而足。但是终于,还是发现了这款堪称满足对分布式调度框架所有幻想的开源项目: Temporal 。目前Star数还不是很多,但是不妨碍它成为一款golang编写的最佳分布式任务调度框架的潜质。不多废话,赶紧来介绍给大家看看。

在Temporal的眼中,对自己的定位是 microservice orchestration platform,提供工作流编排、C\S架构、状态查询等一系列功能。在我看来,它基本覆盖了以上列出的四点能力,我们以一个架构图开始它的介绍:

截屏2021-09-18 13.41.19.png

我们从左往右看,依次出现的几个角色是ActivityWorkflowWorkersTemporal ServerCLIWebSDK。我们列一张表对它们进行简单介绍:

角色 说明
Activity 一段可运行代码(function),可以包含任何逻辑。由于Temporal提供了各种语言的SDK(go、java、python、php等等)所以Activity是不限制语言的。
Workflow Activity的集合,多个Activity可以构成一个Workflow,也是调度的最小单位。
Workers 不同语言写的Workflow可以注册到对应语言的Worker中,Worker是代码的真正执行者
Temporal 管理注册到自己的Workers,向Workers下发任务,监听任务状态等等
CLI or SDK 任务的发起者、监控任务进度等
Web 负责任务的监控、查询等。

这个架构是不是有点类似生产者-消费者模型,CLI or SDK是生产者,负责启动某个Workflow;Temporal类似 kafka\RocktMQ ,负责把请求调度某个Worker;Workers是消费者,负责执行请求。但深入思考一下,我还是觉得跟消息队列有很大差别:

    1. 更关注任务的执行
        消息队列的核心是消息,生产者不关心这个消息被谁消费,消息队列关注的是消息是否送达。
        而 Temporal ,关注的是任务,关注任务执行进度和结果,是否需要重启等等。
    2. 需要提前设计好Workflow
        消息队列不需要关注消费者怎么消费消息的。而 Temporal ,你必须先把Workflow的逻辑
        写好。

所以这两个系统还是不太一样的,选择 Temporal,是因为我们想执行某个预定任务,并保证它执行成功。比如,交易系统每晚定时对账;注册系统过段时间自动向用户发送短信等。虽然用MQ也能实现,但可能要做很多错误处理等工作。

Temporal 示例

Talk is cheap, show me the code.

接下来用一个简单的示例展示下 Temporal的使用流程,场景是延时1小时向用户发送短信和邮件。

1. 先编写Activity的代码:
type MessageRequest struct {
   
   PhoneNum string
   Content  string
   Tags     []string
}

func SendMessage(ctx context.Context, mr MessageRequest
<think>好的,我需要帮助用户了解如何在Cadence Virtuoso中创建参数化单元(pCell)时,让参数的数值带有单位。首先,我得回忆一下Virtuoso中pCell的基本概念和操作流程。 用户的问题是关于参数数值带单位的设置,这可能涉及到参数定义时的属性设置。我记得在Virtuoso的pCell开发中,通常使用Skill语言来编写代码,定义参数和生成几何图形。这时候,参数的单位可能需要在参数声明时指定,或者在代码中处理单位转换。 首先,我需要确认在Virtuoso的pCell参数定义中是否有直接支持单位的选项。例如,在定义参数时,是否可以设置参数的类型为带有单位的数值,如长度、宽度等,这样用户在输入数值时自动附带单位。或者是否需要通过Skill代码在内部处理单位,比如将用户输入的值转换为数据库单位(DBU)。 接下来,考虑用户可能的使用场景。例如,用户希望创建一个电阻的pCell,参数包括长度和宽度,单位可能是微米(um)。用户希望在参数输入框中输入数值时,可以直接输入“10u”而不是单独输入数值10,然后选择单位。这时候,参数的定义需要能够解析带有单位的字符串,并将其转换为数据库单位。 然后,我需要查阅相关文档或示例代码,确认Skill语言中如何处理带单位的参数。例如,可能需要在参数定义中使用特定的类型,或者在代码中使用字符串处理函数来提取数值和单位,然后进行单位转换。比如,使用parseString函数来分割数值和单位,再根据单位转换为DBU。 另外,还要考虑单位的一致性。Virtuoso的默认数据库单位通常是微米,所以如果用户输入“10n”,即10纳米,就需要将10除以1000转换为微米。这需要在Skill代码中处理不同单位的转换,比如检查单位后缀(u, n, p等),并进行相应的数值缩放。 可能的步骤包括: 1. 在pCell的参数定义中,将参数类型设置为字符串,允许用户输入带有单位的数值。 2. 在Skill代码中解析这些字符串,提取数值部分和单位部分。 3. 根据单位进行数值转换,将用户输入的值转换为数据库单位(微米)。 4. 使用转换后的数值来生成几何图形。 例如,在参数定义时,可以有一个参数W,用户输入“5u”,代码解析出5和单位u,转换为5微米。如果用户输入“500n”,则转换为0.5微米。 同时,需要注意错误处理,比如用户输入了无效的单位或格式不正确的情况,这时候需要给出提示或者默认使用某种单位。 可能还需要参考Cadence官方文档或社区资源,确认是否有内置的函数或方法可以直接处理带单位的参数输入,避免重复造轮子。例如,是否有类似pcDefineParameter的函数,其中可以指定参数的单位类型,或者是否有现成的单位转换函数可用。 总结起来,解决方案的大致步骤可能如下: - 定义参数时允许字符串输入,提示用户输入数值和单位(如“10u”)。 - 在生成pCell的Skill代码中,解析每个参数字符串,分离数值和单位。 - 根据单位后缀(u, n, m等)进行单位转换,将数值转换为数据库单位(微米)。 - 使用转换后的数值进行几何图形的绘制。 此外,可能还需要提供示例代码,帮助用户更好地理解实现方法。例如,展示如何定义一个处理带单位参数的函数,并在pCell的代码中调用该函数进行转换。 最后,需要考虑用户的实际操作流程,确保步骤清晰,避免遗漏关键点,比如如何在Virtuoso的pCell编辑器中设置参数属性,或者在Skill代码中何处插入单位转换的逻辑。</think>在Cadence Virtuoso中创建参数化单元(pCell)时,若需要让参数的数值附带单位(如`1u`、`50n`),可通过以下步骤实现: --- ### **步骤1:定义参数时允许单位输入** 在pCell参数定义中,将参数类型设为**字符串(string)**,允许用户输入数值+单位组合(如`10u`、`0.5n`): ```skill pcDefinePCell( list(ddGetObj("lib") "resistor" "layout") ( (w "10u" "string") ; 宽度参数,默认值"10u" (l "20u" "string") ; 长度参数,默认值"20u" ) ; ... 后续代码 ) ``` --- ### **步骤2:解析参数中的单位** 在Skill代码中,编写函数解析字符串,提取数值和单位,并转换为数据库单位(DBU,默认微米): ```skill /* 单位转换函数 */ (defun ParseValueWithUnit (str @optional (defaultUnit "u")) (let (value unit scaledValue) ; 正则表达式提取数值和单位(如"5u" → 5和"u") (when (setq value (parseString str "[0-9.]+")) (setq unit (parseString str "[a-zA-Z]+")) (setq unit (if unit (lowerCase unit) defaultUnit)) ; 单位转换(按微米基准) (case unit ("u" (scaledValue = atof(value) * 1.0)) ; 微米 → 微米 ("n" (scaledValue = atof(value) * 0.001)) ; 纳米 → 微米 ("m" (scaledValue = atof(value) * 1000.0)) ; 毫米 → 微米 (t (scaledValue = atof(value))) ; 默认单位 ) scaledValue ) ) ) ``` --- ### **步骤3:在pCell代码中使用转换后的值** 在生成几何图形时,调用上述函数将带单位的字符串转换为纯数值(以微米为单位): ```skill (let (w l) ; 解析参数并转换为微米 (setq w (ParseValueWithUnit w)) (setq l (ParseValueWithUnit l)) ; 生成矩形(示例) (rodCreateRect( ?layer "M1" ?bBox list(0:0 w:l) )) ) ``` --- ### **关键点** 1. **参数类型**:必须使用`string`类型,允许用户输入数值+单位。 2. **单位兼容性**:确保代码支持常见单位(如`u`/`n`/`m`),并在转换时统一为数据库单位。 3. **错误处理**:可添加校验逻辑,若用户输入无效格式(如`5x`),则报错或使用默认值。 --- ### **示例用法** 用户输入参数时: - `w = "5u"` → 解析为5微米 - `l = "200n"` → 解析为0.2微米 通过此方法,pCell的参数输入将直观支持单位,同时代码自动完成单位转换,确保设计准确性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值