首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >构建一个prefect管道以永久运行任务

构建一个prefect管道以永久运行任务
EN

Stack Overflow用户
提问于 2022-02-22 16:28:17
回答 1查看 471关注 0票数 1

我在建造一条完善的管道时遇到了困难。假设我有一个文件,称之为streamA.py和streamB.py。这两个文件的目的是连续24/7地流数据,并每500条记录流一次就将数据推入红流。

我创建了另一个名为redis_to_postgres.py的文件,它异步地获取redis流中的所有数据,并将数据推送到postgresql,并从我最近推送ids的redis流中清除内存。这是通过异步完成的。我希望在前一条管道启动后每15分钟计时一次。

这样做最实际的方法是什么?在这种情况下,我会创建3条独立的管道吗?一个用于streamA,一个用于streamB,第三个用于从redis读取并推送到postgresql并最终清理数据?或者,我会创建一个管道来以并行的方式流数据,而另一个管道只是读取并推送到postgres?谢谢

EN

回答 1

Stack Overflow用户

发布于 2022-02-23 04:22:38

有趣的用例!你是问≤1.0长官还是猎户座?对于Orion,有一个博客帖子更详细地讨论了这个问题,并显示了示例流程。

但我假设您要求的是Prefect≤1.0。

为了读取Redis中的数据并将其加载到Postgres,例如每10秒,您可以在Prefect任务中使用一个循环:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
for iteration in range(1, 7):
  logger.info("iteration nr %s", iteration)
  read_from_redis_and_load_to_postgres() # your logic here
  if iteration < 6:
      logger.info("Sleeping for 10 seconds...")
      time.sleep(10)

这个流程可以每分钟运行一次。这将为您提供重试、可观察性和所有Prefect功能,并且每10秒将数据加载到Postgres不应该淹没您的数据库。

但是对于获取实时数据并将其连续加载到Redis流的部分,您可以将其作为单独的服务运行,而不是作为Prefect流运行,因为Prefect 1.0流更适合批处理,并且希望在某个时候结束,以便判断流运行是否成功。如果你想让它成为一个永无止境的完美流,它可能会失去心跳,并被僵尸杀手程序杀死。因此,运行此部分可能更容易,例如,作为一个单独的容器化服务运行24/7,您可以将其部署为单独的Kubernetes部署或ECS服务。

这也取决于许多因素,包括。这段代码所做的是什么,这个API有多可靠(从它提取数据的源系统有一些速率限制吗?为什么是500张唱片?这500张唱片被填写的频率是多少?你写到Redis的频率有多高?)。

尽管如此,我还是想看看您是否可以在猎户座中实现它,类似于blog post示例所做的工作。我们目前正在收集关于Orion的流用例的反馈,所以如果您在Orion中实现这一点,我们将有兴趣听取您对此的反馈。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71229984

复制
相关文章
构造函数隐式转换_构造函数实例化对象
http://blog.csdn.net/thefutureisour/article/details/7705771
全栈程序员站长
2022/11/10
4040
构造函数的选择:直接实例化 vs 明确构造
在编程领域,创建对象是最基本也是最常见的操作之一。然而,在创建单个类型的对象时,我们是否应该使用构造函数,还是可以直接创建对象,这是一个值得讨论的问题。在本文中,我们将探讨这两种方法的优缺点,并尝试为开发者提供一些实用的建议。
运维开发王义杰
2023/10/10
1680
构造函数的选择:直接实例化 vs 明确构造
Kotlin构造函数与实例化
Kotlin作为面向对象的编程语言,也支持为类型声明构造函数。不过Kotlin声明构造函数的方式相比Java有所变化,下面这个示例演示了在Kotlin中声明构造函数的方式。
博文视点Broadview
2020/06/11
2.4K0
【Kotlin】Kotlin 构造函数 ( 主构造函数 | 主构造函数声明属性 | init 初始化代码块 | 次构造函数 | 构造函数委托 | 调用构造函数创建实例对象 )
1 . 构造函数个数 : Kotlin 类定义时需要指定主构造函数 , 还可以指定 0 ~ 多个次构造函数 ;
韩曙亮
2023/03/27
4.2K0
构造函数没有返回值是怎么赋值的?
众所周知,在java里是不能给构造函数写返回值的,如果在低版本的编译器定义一个构造器写上返回值可能会报错,高版本里面他就是一个普通的方法。可是如果构造函数没有返回值,那么比如Test t = new Test()我们new一个对象的时候是怎么赋值的呢?
帅地
2020/09/28
1.7K0
构造函数没有返回值是怎么赋值的?
构造函数没有返回值是怎么赋值的?
众所周知,在java里是不能给构造函数写返回值的,如果在低版本的编译器定义一个构造器写上返回值可能会报错,高版本里面他就是一个普通的方法。可是如果构造函数没有返回值,那么比如Test t = new Test()我们new一个对象的时候是怎么赋值的呢?
好好学java
2020/12/09
1.7K0
构造函数没有返回值是怎么赋值的?
js 中的构造函数,构造函数作用,构造函数和普通函数的区别
函数的定义方式: 1.声明式函数定义: function 函数名 (){};这种定义方式,会将函数声明提升到该函数所在作用域的最开头,也是就无论你在这个函数的最小作用域的那儿使用这种方式声明的函数,在这个作用域内,你都可以调用这个函数为你所用。 2.函数表达式:let fun = function(){}; 此方式定义的函数,只能在该作用域中,这段赋值代码执行之后才能通过fun()调用函数,否则,由于变量声明提升,fun === undefined。 3.new Function 形式: var fun1 = new Function (arg1 , arg2 ,arg3 ,…, argN , body );Function构造函数所有的参数都是字符串类型。除了最后一个参数, 其余的参数都作为生成函数的参数即形参。这里可以没有参数。最后一个参数, 表示的是要创建函数的函数体。
全栈程序员站长
2022/10/04
3.5K0
JavaScript手写new实现构造函数实例化
😇 思路 在调用new操作符的时候会发生以下四件事 首先创建一个空对象 设置原型,将对象的__proto__纸箱构造函数的protype对象 让函数的this指向这个对象,执行构造函数的代码(为这个新对象添加属性) 判断函数的返回值类型,如果是值类型,返回创建的对象。如果是引用型对象,则返回这个引用类型的对象 😎 代码实现 function objectFactory(){ let object=null; //shift() 方法移除数组的第一项,并返回该值 //在这里是获得接收到的第一个参数 l
henu_Newxc03
2022/05/05
4450
Java构造函数没有返回值,是怎么赋值的?
众所周知,在java里是不能给构造函数写返回值的,如果在低版本的编译器定义一个构造器写上返回值可能会报错,高版本里面他就是一个普通的方法。可是如果构造函数没有返回值,那么比如Test t = new Test()我们new一个对象的时候是怎么赋值的呢?
程序员小猿
2021/01/20
2.1K0
Java构造函数没有返回值,是怎么赋值的?
C++构造函数 | 构造函数
C++在建立一个对象时,常常需要作某些初始化,如果一个数据成员未被赋值,则它的值是不可预知的,因为在系统为它分配内存时,保留了这些存储单元的原状,这就成为了这些数据成员的初始值,在C++中,对象是一个实体,它反映了客观事物的属性,是应该有确定的值的。
小林C语言
2021/01/26
2.2K0
C++构造函数 | 构造函数
Java里的构造函数(构造方法)
本文转载之https://www.cnblogs.com/livterjava/p/4709561.html
用户7886150
2021/01/31
2.5K0
创造特殊的构造函数——寄生构造函数模式
当我们需要构造一个特殊的数据,我们可以通过寄生构造函数来实现。比如我们要格式化一个Array(简单举例),将其变成一个有“|”组成的字符串,我们可以这么做:
就只是小茗
2018/12/07
9590
一个以前没有注意的问题:java构造函数的执行顺序
昨天在改一处代码时发现执行的过程和预想的不一样,仔细探究才发现是构造器执行顺序问题.(汗自己一下,基础不够扎实) 特地做了一些尝试然后把java构造器的执行顺序整理出来. 首先是我测试的代码:
哲洛不闹
2018/09/19
1K0
一个以前没有注意的问题:java构造函数的执行顺序
一个以前没有注意的问题:java构造函数的执行顺序
昨天在改一处代码时发现执行的过程和预想的不一样,仔细探究才发现是构造器执行顺序问题.(汗自己一下,基础不够扎实) 特地做了一些尝试然后把java构造器的执行顺序整理出来. 首先是我测试的代码:
哲洛不闹
2018/09/19
6930
一个以前没有注意的问题:java构造函数的执行顺序
【C++】构造函数调用规则 ( 默认构造函数 | 默认无参构造函数 | 默认拷贝构造函数 | 构造函数调用规则说明 )
如果 C++ 类中 没有定义构造函数 , C++ 编译器会自动为该类提供一个 " 默认的无参构造函数 " , 函数体为空 , 不做任何操作 ;
韩曙亮
2023/10/15
1.3K0
【C++】构造函数调用规则 ( 默认构造函数 | 默认无参构造函数 | 默认拷贝构造函数 | 构造函数调用规则说明 )
java构造函数调用另一个构造函数_java中的构造函数
* 构造方法是专门用来创建对象的方法,当我们通过关键字new来创建对象时,其实就是在调用构造方法
用户7886150
2021/04/29
4.5K0
JavaScript的构造函数
在Java语言中,我们使用构造函数是实例化对象的过程,在JavaScript语言中我们可以使用构造函数的方式创建对象,如:
伯爵
2019/10/09
1K0
JavaScript的构造函数
js的构造函数
//构造函数 //使自己的对象多次复制,同时实例根据设置的访问等级可以访问其内部的属性和方法 //当对象被实例化后,构造函数会立即执行它所包含的任何代码 function myObject(msg){ //特权属性(公有属性) this.myMsg = msg; //只在被实例化后的实例中可调用 this.address = '上海'; //私有属性 var name = '豪情'; var age = 29; var that = this; //私有方法 function
山河木马
2019/03/05
2.7K0
js的构造函数
一个以前没有注意的问题:java构造函数的执行顺序
昨天在改一处代码时发现执行的过程和预想的不一样,仔细探究才发现是构造器执行顺序问题.(汗自己一下,基础不够扎实) 特地做了一些尝试然后把java构造器的执行顺序整理出来. 首先是我测试的代码:
哲洛不闹
2018/09/14
9590
一个以前没有注意的问题:java构造函数的执行顺序
点击加载更多

相似问题

如何使触屏启动/触屏事件禁用按钮?

20

jQuery和jQuery移动:点击与触屏、触屏、触屏和点击?

24

ipad上的动态JS触屏/触屏混淆

14

触屏悬停

11

检测触屏/触屏是否取消了滚动(动量滚动)

13
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文