- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
如何确定 go channel 的哪一侧正在等待另一侧?
我想知道这一点,以便找出我的处理受限的地方,并通过分配更多资源来做出响应。
我想到的两种方法都需要对记录值进行移动平均,这样测量就不会太嘈杂,但这不是 big problem .
在单个消费者的情况下,我可以在从 channel 消费之前启动一个计时器,在我获得记录后停止计时器。我可以跟踪等待时间的百分比,并在每个获取周期内做出相应响应。
如果 channel 经常为 0,则意味着我们的消费速度比发送速度快。同样,如果缓冲区已满,我们发送的速度将比接收速度快。我们可以随时间检查 channel 的长度,以确定运行缓慢的原因。
出于性能原因或其他原因,是否有充分的理由更喜欢其中之一?这个问题有更简单的解决方案吗?
我有一项服务正在执行 N
个 HTTP 请求,以同时在最多 W
个 goroutine 中获取内容,并将所有内容发送到一个 channel processor
在单个 goroutine 中运行,然后将数据反馈给客户端。
每个工作任务都会导致 channel 上发送大量消息。每个 worker
的任务可能需要几分钟才能完成。
下图总结了 3 个并发工作器 (W=3
) 的数据流。
[worker: task 1] -
\
[worker: task 2] - | --- [ channel ] --- [ processor ] -> [ client ]
/
[worker: task 3] -
我想知道在请求期间我是应该运行更多的 worker(增加 W
)还是更少的 worker(减少 W
)。由于客户端在速度非常不同的连接上工作,因此每个请求可能会有很大差异。
最佳答案
实现目标的一种方法是使用“有界发送”和“有界接收”操作——如果您能够想出合理的轮询超时。
当您的任何一个工作人员试图通过 channel 发送完成的结果时,不要让它“永远”阻塞(直到 channel 缓冲区中有空间);相反,只允许它阻塞一些最长时间。如果在 channel 缓冲区中有空间之前发生超时,您可以对这种情况使用react:计算它发生的次数、调整 future 的截止日期、限制或减少工作人员数量,等等。
同样,对于从工作人员接收结果的“处理器”,您可以限制它阻塞的时间。如果在有可用值之前发生超时,则处理器处于饥饿状态。创建更多 worker 以更快地喂养它(假设 worker 将从这种并行性中受益)。
这种方法的缺点是 creating timers 中的开销对于每个 send或 receive operation .
绘制草图,每个 worker 都可以访问这些声明:
const minWorkers = 3
var workers uint32
在每个 worker goroutine 中:
atomic.AddUint32(&workers, 1)
for {
result, ok := produce()
if !ok {
break
}
// Detect when channel "p"'s buffer is full.
select {
case p <- result:
case <-time.After(500 * time.Millisecond):
// Hand over the pending result, no matter how long it takes.
p <- result
// Reduce worker count if above minimum.
if current := atomic.LoadUint32(&workers); current > minWorkers &&
atomic.CompareAndSwapUint32(&workers, current, current-1) {
return
}
// Consider whether to try decrementing the working count again
// if we're still above the minimum. It's possible another one
// of the workers also exited voluntarily, changing the count.
}
}
atomic.AddUint32(&workers, -1)
请注意,如上所述,您可以通过计时发送到 channel p
完成所需的时间,并对其花费太长时间使用react,而不是执行一个有界发送,然后是一个潜在的阻塞发送。但是,我是这样画的,因为我怀疑这样的代码会成熟到在超时到期时包含日志记录和检测计数器颠簸。
类似地,在您的处理器 goroutine 中,您可以限制阻止从 worker 接收值的时间量:
for {
select {
case result <- p:
consume(result)
case <-time.After(500 * time.Millisecond):
maybeStartAnotherWorker()
}
}
显然,您可以在这个装置上安装许多旋钮。您最终将生产者的调度耦合到消费者和生产者本身。引入一个不透明的“监听器”,生产者和消费者可以向其“提示”延迟,这样您就可以打破这种循环关系,并更轻松地改变管理您如何应对拥塞的策略。
关于performance - 如何判断 go channel 的哪一边正在等待?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41353508/
判断置顶文章 is_sticky() 函数用来判断一篇文章是否为置顶文章。 用法 ?
判断结构要求程序员指定一个或多个要评估或测试的条件,以及条件为真时要执行的语句(必需的)和条件为假时要执行的语句(可选的)。 下面是大多数编程语言中典型的判断结构的一般形式: 判断语句 C
我经常这样写: (if (nil? a-value) another-value a-value) 是否有更简单的功能可用,例如: (if-nil? a-value another-value) 最佳
MySQL IF 语句允许您根据表达式的某个条件或值结果来执行一组 SQL 语句。 要在 MySQL 中形成一个表达式,可以结合文字,变量,运算符,甚至函数来组合。表达式可以返回 TRUE,FA
也就是说,是否有一种工具可以自动显示给定语法的完整语言,包括突出歧义(如果有)? 最佳答案 BNF 风格的文法可能有一些特殊性,但总的来说,确定给定的上下文无关文法(例如 BNF)是否有歧义是不可能的
有没有办法确定像下面这样的 Axios 请求是否收到了答案并完成了? axios.get('/api') .then(response => this.data = response.data); 最
我想请大家禁用 Firebug 。如何确定自己安装了firebug?所以它是一个跨浏览器,并在 Chrome、Mozilla 和 IE8 + 中确定 最佳答案 两步: 如果 window.consol
我有一个看起来像这样的对象: var searchFilter = {_id: XXX, approved: true} 用于驱动 Meteor 集合搜索过滤器。然后,我有一对文本框,允许用户输入一系
我正在循环并向我的数据库中插入几百万条记录。性能是第一要务。 我想利用无状态 session ,但您可能知道它们不支持在更复杂的实体上级联对象。 是否有一种通用方法可以确定实体是否具有级联记录?如果是
我正在使用 pdfminer 解析一些 PDF 文件。图书馆。 我需要知道文档是否是扫描文档,扫描机将扫描图像放在顶部,将 OCR 提取的文本放在背景中。 有没有办法识别文本是否可见,因为 OCR 机
我正在寻找一种方法来找出当前为浏览器游戏 TribalWars 编写的脚本打开的页面。 URL 的设置非常相似,对于知道自己在做什么的人来说这应该很容易(我显然不知道)。 URL 如下所示: http
我在 C# 中使用包装的 C 库,需要将图像从该库转换为位图并返回,但没有复制像素缓冲区。 转换为位图很简单: Bitmap WrapAsBitmap(CImage image) { retu
有没有办法检查调用方法的Controller是否来自Area内的Controller? 例如,我有一个继承自 AuthorizeAttribute 的类,例如 public class CustomA
是否可以找到MySQL View 中某列所属的表名? 如果 View 构造为 CREATE VIEW alpha_view AS SELECT alpha.col1, alpha.col2,
如何判断 .Net 应用程序是作为桌面应用程序运行还是作为服务运行? 我们正在尝试使用 Fitnesse 测试我们的应用程序,它将应用程序作为服务加载,然后调用它。但是当一个模式错误框被按下时,它就会
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求提供代码的问题必须表现出对所解决问题的最低限度理解。包括尝试过的解决方案、为什么它们不起作用,以及
我试图计算出 iframe 内容的大小,以便调整 iframe 元素的大小以包含其内容。 如何确定 iFrame 是否已加载以及我是否可以可靠地测量它的内容尺寸。 注意:onload 事件不会执行,因
这个问题在这里已经有了答案: How to write portable code in c++? (12 个答案) 关闭 9 年前。 我正在尝试编写可以用任何现代版本的 g++ 编译的代码,但遇到
这个问题在这里已经有了答案: distinguish shared objects from position independent executables (2 个答案) 关闭 4 年前。 我有
我的目标是如果 dte 与当前时间相差不到 1 小时,则停止循环。是否有“ ruby 方式”来做到这一点? #THIS IS AN INFINITE LOOP, DONT RUN THIS dte=D
我是一名优秀的程序员,十分优秀!