- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这很奇怪,我不确定真正的罪魁祸首是谁。
我正在 FreeBSD (6.2) 上编写一些脚本?它广泛使用了以下 ***bash***ism:
do_something <(mysql --skip-column-names -B -e 'select ... from ... where ...;')
... 其中“do_something 是一个有点笨拙的实用程序(在 Perl 中),它不会从管道中读取。如果我使用常规文件,它工作正常。我的 bash 脚本使用诸如exec 4< <(...)
这些类型的查询(后面是 while read x y z <&4; do ...
形式的循环似乎从来没有任何问题。
但是,Perl (5.8.x) 似乎会周期性地阻塞(显然是永远)。我尝试更改 chomp(my $data = <MYDATA>);
与一个使用 sysread 的例程一起,我用 Python 编写了一些测试用例以进行比较。这些似乎比惯用的 Perl 代码阻塞的频率要低得多,但它们有时仍然会阻塞。 (使用 f.read()
或 os.read(f.fileno()...)
的 Python 代码在这个问题上似乎表现得差不多)。
我尝试使用 ... <(cat ...)
重现问题(我正在 cat 常规文件)并且似乎永远不会重现那个停顿。
我浏览了一些ktrace/kdump 数据...但我更熟悉 Linux strace 甚至 Solaris truss ...所以我也还没弄清楚接下来会发生什么。
我想我们基本上可以排除 Perl,因为我已经使用 Python 重现了同样的问题......我不明白 bash 怎么会在这里做错任何事情(它只是创建/var/tmp/sh-np-xxx 中的一个命名管道,并将进程连接到它)。
mysql shell/utility 正在做什么可能会导致这种情况?我不认为我从其他任何东西(例如 cat 或 dd)看到它。我没有在 Linux 下测试过这种情况……但我使用了 <(...)
(进程替换)在 Linux 下使用多年,不记得曾经见过这个。
这是 FreeBSD 的问题吗?
当然我可以使用临时文件来解决这个问题......但我肯定更愿意理解它为什么这样做(并避免临时文件带来的一些竞争和清理困惑)。
有什么建议吗?
最佳答案
对 mysql 的输出进行操作和直接对文件进行操作之间的最大区别在于时间。当 perl 进程停止时,最大的问题是:“为什么它没有向前推进”?您可以使用 ps 的“l”选项来查看 perl 进程的等待 channel ;这样你就可以看到它是否在读取时被阻塞,或者是否发生了其他事情。如果它真的被管道输入阻塞,我希望 perl 的 MWCHAN 条目是“piperd”。
对于 mysql 进程,同样的信息会很有趣。
您的 Python 测试代码是什么样的?
另一种避免 bashism 的写法是这样的;这将允许你排除 bash:
mysql --skip-column-names -B -e 'select ... from ... where ...;' | do_something /dev/stdin
其他有趣的问题:
mysql 的 --unbuffered 选项会改变什么吗?
通过 dd 管道传输 mysql 输出会改变什么吗? (例如,“perlscript <(mysql ... | dd)
总结:需要更多信息。
关于mysql - FreeBSD、MySQL、Perl、bash : intermittent blocking on named pipes?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1653455/
我有管道输出 command_a | command_b | ... | command_n 输出是一个数字序列 4.2 -1 ... 0.2 我可以使用 gnuplot 绘制这些数字吗? (将 gn
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 6 年前。 Improv
我目前正在尝试连接父项和子项之间的管道。子级正在执行 sort 并对从父级接收到的输入进行排序。然后 children 写入一个单独的管道。每个进程有两个管道。一个这样 parent 可以将输入发送给
最近我正在研究 Python 中的并行编程工具。这是 os.pipe 和 multiprocessing.Pipe 之间的两个主要区别。(尽管它们被使用的场合) os.pipe是单向,multipro
我的站点上运行着 Yahoo Pipe,Romneyomics它使用来自 Delicious 和 Topsy 的饲料。Delicious 提要不提供“描述”字段,但 Topsy 提供,并且不仅仅是一个
我有一些使用管道的 Haskell 代码: module Main(main) where import Pipes a :: Producer Int IO () a = each [1..10]
所以标题几乎解释了我的问题。 stdout=subprocess.PIPE 和 stdout=PIPE 有什么区别?两者都来自 subprocess 模块,但为什么要使用一个而不是另一个呢?你如何使用
我有一个名为“myPipe”的自定义管道。我得到: The pipe 'myPipe' could not be found error 在我的单元测试中请建议在我的 .spec.ts 中导入和声明什
我有一个非常简单的 Python 3 脚本: f1 = open('a.txt', 'r') print(f1.readlines()) f2 = open('b.txt', 'r') print(f
我正在使用管道和 Python 的多处理模块在进程之间发送简单的对象。文档指出,如果管道已关闭,则调用 pipe.recv() 应该引发 EOFError。相反,我的程序只是阻塞在 recv() 上,
我在 perl 中见过这两种形式的管道 open。 一种是简单的管道打开 open FH,'| command'; 其他是安全管道打开 open FH,'|-','command'; 现在,第二个中的
我正在尝试对我的组件进行单元测试,但它立即生成一个错误: 类型错误:this.store$.pipe 不是函数 根据我的理解, createSpyObj 应该模拟状态。我有不同的选项选项,但没有一个起
我在这里看到这个帖子很多次了;但未能从命令中捕获故意错误。迄今为止我找到的最好的部分工作.. from Tkinter import * import os import Image, ImageTk
我正在编写一个简单的程序来解析编译器的输出并重新格式化任何错误消息,以便我们使用的 IDE(visual studio)可以解析它们。我们使用 nmake构建,它将使用如下命令行调用编译器: cc16
我有一个在coreos上运行的kubernetes集群。我希望在称为记录的Pod中的容器中运行journal2gelf https://github.com/systemd/journal2gelf。
为什么当管道中没有写入器时,读取器存在可以,但当管道中没有读取器时,写入器存在就不行? 。是不是因为reader需要等待,所以没有writer也没关系,而writer已经准备好数据了,即使数据准备好了
我在/etc/postfix/master.cf 中创建了一个 postfix 命令管道,其中包含一个在 STDOUT 和 STDERR 上产生输出的有效命令。在终端上调用时一切正常(因此在 STDO
我有一个命令需要来自管道的输入。例如,考虑著名的 cat 命令: $ echo Hello | cat Hello 假设我在 Perl 6 程序中有一个字符串,我想将其通过管道传递给命令: use v
因此,由于我们拥有各种设置,我习惯于遇到需要将一个可观察结果添加到另一个结果的地方,然后同时使用两者。我需要第一个在另一个之前完成的地方 getUser() .pipe( mergeMap
我在 Angular 5 中有一个非常简单的管道 import { Pipe, Injectable } from '@angular/core'; @Pipe({ name: "defaul
我是一名优秀的程序员,十分优秀!