我正在尝试编写一段Python代码作为一个子进程,它将在Linux shell中执行一个连续的命令,直到子进程2中的一个循环结束。
这是我正在尝试运行的连续命令:
"while (true); do dd if=/mnt/DATA/random.dat of=/dev/null bs=128K iflag=direct >> /mnt/DATA/random.dat; sleep 0.2; done > /dev/null 2>&1"我希望它一直运行,直到在另一个子进程下完成其他操作:
"for cycle in range(10)"
.
.
.我不确定我到底在寻找什么,因为我不知道如何恰当地提出一个问题。
发布于 2019-08-30 16:22:17
本质上,您正在尝试在两个独立的进程之间进行通信;特别是当一个进程希望另一个进程退出时。
传统上,这类事情是通过"pid文件“来完成的,就像这样……
让读取MMC的进程在启动时在文件中写入自己的“进程id”。当另一个进程想要停止它时,它读取该文件以获取进程id并终止它。
# Write our pid to disk so other processes know which pid to kill
echo $$ > /tmp/stress.pid然后,在另一个过程中:
# Kill our friend
xargs -a /tmp/stress.pid kill另一种选择可能是将压力测试和for循环放在同一个脚本中,如下所示:
#!/bin/bash
stressMMC(){
while : ; do
echo "[stress] Thrashing MMC..."
# dd if=... of=...
sleep 1
done
}
# Run stress function in background and save its process id
stressMMC &
stressPID=$!
# Mainline code
for ((i=0;i<10;i++)) ; do
echo "[main] Looping..."
if [ $i -eq 5 ] ; then
echo "[main] Killing stressMMC"
kill $stressPID > /dev/null 2>&1
fi
sleep 1
done示例输出
[main] Looping...
[stress] Thrashing MMC...
[main] Looping...
[stress] Thrashing MMC...
[stress] Thrashing MMC...
[main] Looping...
[stress] Thrashing MMC...
[main] Looping...
[stress] Thrashing MMC...
[main] Looping...
[stress] Thrashing MMC...
[main] Looping...
[main] Killing stressMMC
./go: line 22: 37291 Terminated: 15 stressMMC
[main] Looping...
[main] Looping...
[main] Looping...
[main] Looping...另一种选择是通过文件系统通信,因此这里有一个基于此的特别难看的解决方案!
在重复读取MMC的过程中,将测试放入循环中,以查看文件是否存在,如果存在,则中断或退出:
while : ; do
[ -f /tmp/STOP ] && break
dd if= of= ...
done在另一个过程中,当您想要用信号通知它停止时,只需创建标记文件,使用:
touch /tmp/STOP很难看,但很有效。
当然,你可以把它修饰一下:
https://stackoverflow.com/questions/57713491
复制相似问题