- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这几天一直在摸索Apache Flink,对Task Slot这个概念有些疑惑。虽然已经问了几个问题,但有一点我不明白。
我正在使用玩具应用程序进行测试,运行本地集群。我禁用了运算符链接
我从文档中了解到插槽允许内存隔离而不是 CPU 隔离。阅读文档,Task Slot 似乎是一个 Java 线程。
1) 当我使用 parallelism=1 部署我的应用程序时,所有运算符(operator)的子任务都部署在同一个槽中。但是,如果我从 AbstractStreamOperator
的 open()
方法打印当前线程 ID,我会看到不同子任务的不同 ID。那么,它们不是共享同一个线程(即插槽吗?)。
2) 如果我将并行度从 1 更改为 3,我需要 3 个插槽才能正确重新部署应用程序。文档确认插槽的数量限制了我可以拥有的并行度。但为什么我可以在同一个槽中有不同运算符(operator)的子任务,而不能在同一个槽中有相同运算符(operator)的子任务?
感谢任何解释!
最佳答案
槽的想法是将可用资源分割成更小的部分。可用的托管内存均匀分布在所有插槽中。 CPU 周期和 JVM 堆内存未正确隔离 wrt 插槽。
在每个插槽中,您可以部署一个或多个任务
。 Flink Task
由专用线程执行。因此,如果您部署了多个 Task
,则可以在同一个槽中运行多个线程。
Task
表示单个 Flink 运算符或多个运算符的并行实例(如果它们是可链接的)。链接并不总是可行或需要的,但如果应用它,它将融合运算符,以便它们由相同的 Task
线程执行。这通常效率更高,因为上下文切换更少,并且不会将记录移交给不同的线程。
为了提高资源利用率(特别是对于需要很少资源的Tasks
),并且为了更容易地推理出运行一个Flink程序需要多少slots,Flink支持slot sharing。插槽共享意味着不同算子的并行实例可以部署到同一个插槽。由于这个特性,Flink 会创建尽可能长的不同算子的管道,并将它们部署到同一个槽中。这也有很好的效果,您可以增加生产者与其各自消费者的共处。由于此功能,用户知道他们只需要提供与一个拓扑的所有运算符的最大并行度一样多的插槽。
但是,由于您仍然希望将一个算子的并行实例分布到所有可用的 TaskExecutors
中,因此 Flink 不支持将同一个算子的并行实例部署到同一个槽中。如果你想这样做,那么你应该简单地将相应运算符的并行度降低到 1
。
关于apache-flink - 在 Flink 中,我可以在同一个槽中有一个运算符(operator)的多个子任务吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55590809/
我在QPushButton的最后一列中插入了QTableview。使用该按钮,我将使用按钮释放信号和插槽handlebutton(int)删除该特定行。 cpp代码: MainWindow::Main
它编译正常,但这是我运行程序时的错误消息: QObject::connect: Cannot queue arguments of type 'QVector' (Make sure 'QVector
我在 PyQt 中使用 for 循环 连接多个信号/槽。代码如下: # Connect Scan Callbacks for button in ['phase', 'etalon', 'mirror
我正在使用 Qt 创建一个 UI,有两个元素可能存在也可能不存在。此外,他们的 parent 也是不同的元素。但是,一个会影响另一个。 我应该如何以最佳方式构造信号/槽(或者我什至不应该使用该模式)?
我正在为这事兜圈子。就是无法理解信号和插槽。 只是在寻找某种机制,当我的 C++ 中出现信号时可以自动更新我的 UI。 示例: 我在 Qml 中有两个带有文本的标签:返回值的 _app.method。
我有两条路线呈现相同的组件,但来自 API 的数据不同。 该组件有一个名为 的子组件有一个 v-if检查特定插槽是否有内容的指令(因为如果它没有内容,我不希望该插槽显示)。 但是,在同一个父组件上可
我只是问当我的 html 位于 java-script 变量而不是 DOM 本身时如何使用 .each。 如果我有这样的 html: deze this dies 我能做到
基本上,想象一个宽度为 9(从 0 开始)的基于位置的区域 ╔════╦════╦════╦════╦════╦════╦════╦════╦════╗ ║ 0 ║ 1 ║ 2 ║ 3 ║
我想做一些非常简单的事情。单击切换按钮并在 QT 中获取消息框。 cpp: _show_hide_password = new QPushButton( "abc" ); _show_hide_pas
我有一个关于信号和槽的问题。在我的应用程序中,我想将来自一个对象的信号连接到 textEdit在对话框窗口中。我的信号发出 QString ;如果我违反封装(通过将 UI 公开而不是私有(privat
你好我来自java阵营,正在尝试做一个c++程序 我有一个名为 Manifest 的数组,它接收乘客对象 for (int i = 0; i Manifest . 例如 #include #incl
似乎为 Signal 类和插槽中调用的内容提供安全跨线程信号的唯一实现是 QT。 (也许我错了?)。 但是我不能在我做的项目中使用QT。那么我怎样才能从不同的线程(例如使用 Boost::signal
我将直接从示例开始: 在游戏中,有一个袋子供玩家用来存放他们的元素(元素的大小不一),袋子的大小也是可变的。 在一个 8x15 插槽的袋子中,我需要插入一个占用 2x2 插槽的元素,我可以搜索空间来实
PyQt 按钮事件可以以正常方式连接到函数,以便函数接收默认信号参数(在本例中为按钮选中状态): def connections(self): my_button.clicked.connec
访问类槽时,而不是写入 (defmethod get-name ((somebody person) (slot-value somebody 'name)) 是否可以使用点符号(又名 C++),即
我正在使用 vee-validate v3.0 进行验证并且设置很顺利,但现在我正在尝试设置我的元素的样式,但我似乎无法让它工作。我遵循了关于样式的非常简短的文档并编辑了 vee-validate 配
我尝试使用来自 https://wiki.qt.io/QThreads_general_usage 的方法与 moveToThread。一切安好。但是,如果我尝试将参数添加到完成的信号中,则会出现以下
我刚刚使用 iAds 和 adMob 在我的应用程序中实现了 adWhirl。一切都编译正确,adMob 工作完美,但我的 iAd 大小不正确。广告看起来尺寸合适,但实际上似乎被剪掉了。大约 1/4
我正在使用 python 和 PySide 开发 GUI 应用程序。我需要在单独的线程中运行长时间的背景任务。对于线程,我决定根据“正确”的方法使用 QThread,而不是从 if 进行子类化(参见
在用于编写 GUI 代码的 Qt 的 QML 语言中,QML 元素(如果我理解正确的话)在它们变得可见之前不会被实际创建。 (编辑: 听起来这些元素是在 QML 引擎加载它们时创建的,但看起来信号/槽
我是一名优秀的程序员,十分优秀!