- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我还在部署中Airflow
我已经觉得有必要合并 operator
一起。最常见的用例是将运算符与相应的 sensor
耦合。 .例如,可能想要将 EmrStepOperator
链接在一起。和 EmrStepSensor
.
我正在创建我的 DAG
小号 programmatically ,其中最大的一个包含 150 多个(相同的)分支,每个分支对不同的数据位(表)执行相同的一系列操作。因此将构成单个逻辑步骤的任务组合在一起在我的 DAG 中会有很大帮助。
以下是我的项目中的 2 个有争议的例子,为我的论点提供动力。
1、从S3路径中删除数据,然后写入新数据
此步骤包含 2 个运算符
DeleteS3PathOperator
: 扩展自 BaseOperator
& 使用 S3Hook
HadoopDistcpOperator
: 扩展自 SSHOperator
MSCK REPAIR
在 Hive
表
BranchPythonOperator
: 检查 Hive 表是否分区 MsckRepairOperator
: 扩展自 HiveOperator
并对(分区)表执行 MSCK REPAIR Dummy(Branch)Operator
: 构成到 MsckRepairOperator
的备用分支路径(对于非分区表)Dummy(Join)Operator
: 组成两个分支的连接步骤 Hook
sSubDagOperator
一个 risky和 controversial做事的方式;另外 SubDagOperator makes me frown 的命名约定.Python
功能而不是
Airflow
具体来说,值得指出的是,多重继承在组合运算符的功能时可以派上用场。
QuboleCheckOperator
,例如,已经使用它编写了。但是在过去,我尝试过这个东西来融合
EmrCreateJobFlowOperator
和
EmrJobFlowSensor
,但当时我遇到了
issues与
@apply_defaults
decorator并放弃了这个想法。
最佳答案
我结合了各种钩子(Hook)来根据我的需要创建一个单一的运算符。一个简单的例子是我在钩子(Hook)中加入 gcs 删除、复制、列表方法和 get_size 方法来创建一个名为 GcsDataValidationOperator
的操作符。 .经验法则是 幂等性 即,如果您多次运行它应该产生相同的结果。
Should operators be composed at all or is it better to have discrete steps?
Any pitfalls, improvements in above approaches?
PythonOperator
并使用带有
.execute
的内置 Hook 方法,但它仍然意味着 DAG 文件中有很多细节。因此,我仍然会采用新的运营商方法
Any other ways to combine operators together?
In taxonomy of Airflow, is the primary motive of Hooks same as above, or do they serve some other purposes too?
关于airflow - 将运算符融合在一起,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53308306/
Or 运算符 对两个表达式进行逻辑“或”运算。 result = expression1 Or expression2 参数 result 任意数值变量。 expression1 任意
Not 运算符 对表达式执行逻辑非运算。 result = Not expression 参数 result 任意数值变量。 expression 任意表达式。 说明 下表显示如何
Is 运算符 比较两个对象引用变量。 result = object1 Is object2 参数 result 任意数值变量。 object1 任意对象名。 object2 任意
\ 运算符 两个数相除并返回以整数形式表示的结果。 result = number1\number2 参数 result 任意数值变量。 number1 任意数值表达式。 numbe
And 运算符 对两个表达式进行逻辑“与”运算。 result = expression1 And expression2 参数 result 任意数值变量。 expression1
运算符(+) 计算两个数之和。 result = expression1 + expression2 参数 result 任意数值变量。 expression1 任意表达式。 exp
我对此感到困惑snippet : var n1 = 5-"4"; var n2 = 5+"4"; alert(n1); alert(n2); 我知道 n1 是 1。那是因为减号运算符会将字符串“4”转
我想我会得到 12,而不是 7。 w++,那么w就是4,也就是100,而w++, w 将是 8,1000;所以 w++|z++ 将是 100|1000 = 1100 将是 12。 我怎么了? int
Xor 运算符 对两个表达式进行逻辑“异或”运算。 result = expression1 Xor expression2 参数 result 任意数值变量。 expression1
Mod 运算符 两个数值相除并返回其余数。 result = number1 Mod number2 参数 result 任意数值变量。 number1 任意数值表达式。 numbe
Imp 运算符 对两个表达式进行逻辑蕴涵运算。 result = expression1 Imp expression2 参数 result 任意数值变量。 expression1 任
Eqv 运算符 执行两个表达式的逻辑等价运算。 result = expression1 Eqv expression2 参数 result 任意数值变量。 expression1 任
我有一个运算符重载的简单数学 vector 类。我想为我的运算符(operator)获取一些计时结果。我可以通过计时以下代码轻松计时我的 +=、-=、*= 和/=: Vector sum; for(s
我是用户定义比较运算符的新手。我正在读一本书,其中提到了以下示例: struct P { int x, y; bool operator、运算符<等),我们
在 SQL 的维基百科页面上,有一些关于 SQL 中 bool 逻辑的真值表。 [1] 维基百科页面似乎来源于 SQL:2003 标准。 等号运算符 (=) 的真值表与 SQL:2003 草案中的 I
我遇到了一个奇怪的 C++ 运算符。 http://www.terralib.org/html/v410/classoracle_1_1occi_1_1_number.html#a0f2780081f
我正在阅读关于 SO 和 answers 中的一个问题,它被提到为: If no unambiguous matching deallocation function can be found, pr
我偶然发现了这个解决方案,但我无法理解其中到底发生了什么。谁能解释一下! 据我了解,它试图通过计算一半的单元格然后将其加倍来计算 a*b 网格中的单元格数量。但是我无法理解递归调用。 请不要建议其他解
Go的基本类型 布尔类型bool 长度:1字节 取值:布尔类型的取值只能是true或者false,不能用数字来表示 整型 通用整型 int / uint(有符号 / 无符号,下面也类似) 长度:根据运
在本教程中,您将学习JavaScript中可用的不同运算符,以及在示例的帮助下如何使用它们。 什么是运算符? 在JavaScript中,运算符是一种特殊符号,用于对运算数(值和变量)执行操作。例如,
我是一名优秀的程序员,十分优秀!