- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我看到 bash(RHEL 5.3 上的版本 3.2.25)出现了非常非常非常的奇怪行为。
我有一个执行以下操作的“启动器”脚本(作为前台进程,在始终保持打开的终端中运行):
上面的想法本质上是让A、C和两个B相互通信,直到它们被用户杀死。 (它们以 while sleep DURATION; do ... ; done
循环继续运行。)
问题:
完成上述 3 个步骤后,当我从另一个终端窗口重复发出 ps -ef
时,我有时会看到一些额外的 B 虚假实例(比如B3、B4...) 和/或有时会列出一个额外的、虚假的 A 实例!
这些额外的实例是暂时的——它们来自 ps -ef
list 。
此外,这些虚假实例恰好是有效(或所需)进程的子进程,而不是兄弟进程。例如,B3 和 B4 将分别列出 B1 和 B2 作为它们的父级;同样,虚假的 A2 会将 A 列为其父级!
现在,我非常确定我不可能从 B 中创建任何额外的 B 实例,也不会从 A 中创建任何 A 实例。 p>
那么,这里发生了什么?
非常感谢,提前。
PS: 不久前,我在 cron 作业的上下文中看到了类似的问题(多个虚假实例),这些作业旨在在首次启动时无限期地挂起。在这里,即使我有明确的逻辑来防止 crond
启动任何其他实例(通过检查磁盘上是否存在锁定文件),我也会看到我的 cron 作业的多个实例。而且,即使在这里,我也不太能弄清楚问题所在。
$ ps -ejfH
UID PID PPID PGID SID C STIME TTY TIME CMD
root 28503 1 28474 11126 0 22:14 pts/1 00:00:31 /bin/bash A
root 28525 28503 28474 11126 0 22:14 pts/1 00:00:26 /bin/bash B
root 16143 28525 28474 11126 0 23:14 pts/1 00:00:00 [B] <defunct>
root 16144 28525 28474 11126 0 23:14 pts/1 00:00:00 /bin/bash B
root 28531 28503 28474 11126 0 22:14 pts/1 00:00:23 /bin/bash B
root 28566 28503 28474 11126 0 22:14 pts/1 00:00:01 /bin/bash C
$ ps -ejfH
UID PID PPID PGID SID C STIME TTY TIME CMD
root 28503 1 28474 11126 0 22:14 pts/1 00:00:31 /bin/bash A
root 28525 28503 28474 11126 0 22:14 pts/1 00:00:26 /bin/bash B
root 28531 28503 28474 11126 0 22:14 pts/1 00:00:23 /bin/bash B
root 28566 28503 28474 11126 0 22:14 pts/1 00:00:01 /bin/bash C
root 18579 28503 28474 11126 0 23:14 pts/1 00:00:00 /bin/bash A
$ ps -ejfH
UID PID PPID PGID SID C STIME TTY TIME CMD
root 28503 1 28474 11126 0 22:14 pts/1 00:00:31 /bin/bash A
root 28525 28503 28474 11126 0 22:14 pts/1 00:00:26 /bin/bash B
root 22717 28525 28474 11126 0 23:14 pts/1 00:00:00 /bin/bash B
root 22718 22717 28474 11126 0 23:14 pts/1 00:00:00 /bin/bash B
root 28531 28503 28474 11126 0 22:14 pts/1 00:00:23 /bin/bash B
root 28566 28503 28474 11126 0 22:14 pts/1 00:00:01 /bin/bash C
$ ps -ejfH
UID PID PPID PGID SID C STIME TTY TIME CMD
root 28503 1 28474 11126 0 22:14 pts/1 00:00:31 /bin/bash A
root 28525 28503 28474 11126 0 22:14 pts/1 00:00:26 /bin/bash B
root 28531 28503 28474 11126 0 22:14 pts/1 00:00:23 /bin/bash B
root 28566 28503 28474 11126 0 22:14 pts/1 00:00:01 /bin/bash C
$ ps -ejfH
UID PID PPID PGID SID C STIME TTY TIME CMD
root 28503 1 28474 11126 0 22:14 pts/1 00:00:32 /bin/bash A
root 28525 28503 28474 11126 0 22:14 pts/1 00:00:27 /bin/bash B
root 28531 28503 28474 11126 0 22:14 pts/1 00:00:24 /bin/bash B
root 32021 28531 28474 11126 0 23:15 pts/1 00:00:00 /bin/bash B
root 32023 32021 28474 11126 0 23:15 pts/1 00:00:00 [B] <defunct>
root 28566 28503 28474 11126 0 22:14 pts/1 00:00:01 /bin/bash C
root 32013 28503 28474 11126 0 23:15 pts/1 00:00:00 /bin/bash A
$ ps -ejfH
UID PID PPID PGID SID C STIME TTY TIME CMD
root 28503 1 28474 11126 0 22:14 pts/1 00:00:32 /bin/bash A
root 28525 28503 28474 11126 0 22:14 pts/1 00:00:27 /bin/bash B
root 28531 28503 28474 11126 0 22:14 pts/1 00:00:24 /bin/bash B
root 28566 28503 28474 11126 0 22:14 pts/1 00:00:01 /bin/bash C
root 2310 28503 28474 11126 0 23:15 pts/1 00:00:00 /bin/bash A
root 2324 2310 28474 11126 0 23:15 pts/1 00:00:00 /bin/bash A
$ ps -ejfH
UID PID PPID PGID SID C STIME TTY TIME CMD
root 28503 1 28474 11126 0 22:14 pts/1 00:00:32 /bin/bash A
root 28525 28503 28474 11126 0 22:14 pts/1 00:00:27 /bin/bash B
root 28531 28503 28474 11126 0 22:14 pts/1 00:00:24 /bin/bash B
root 9219 28531 28474 11126 0 23:16 pts/1 00:00:00 [B] <defunct>
root 28566 28503 28474 11126 0 22:14 pts/1 00:00:02 /bin/bash C
$ ps -ejfH
UID PID PPID PGID SID C STIME TTY TIME CMD
root 28503 1 28474 11126 0 22:14 pts/1 00:00:32 /bin/bash A
root 28525 28503 28474 11126 0 22:14 pts/1 00:00:27 /bin/bash B
root 28531 28503 28474 11126 0 22:14 pts/1 00:00:24 /bin/bash B
root 28566 28503 28474 11126 0 22:14 pts/1 00:00:02 /bin/bash C
root 9692 28503 28474 11126 0 23:16 pts/1 00:00:00 /bin/bash A
$ ps -ejfH
UID PID PPID PGID SID C STIME TTY TIME CMD
root 28503 1 28474 11126 0 22:14 pts/1 00:00:33 /bin/bash A
root 28525 28503 28474 11126 0 22:14 pts/1 00:00:27 /bin/bash B
root 28531 28503 28474 11126 0 22:14 pts/1 00:00:24 /bin/bash B
root 28566 28503 28474 11126 0 22:14 pts/1 00:00:02 /bin/bash C
root 15686 28503 28474 11126 0 23:16 pts/1 00:00:00 /bin/bash A
最佳答案
有许多 bash 功能可以生成子 shell 来执行部分脚本。我的猜测是您的 A 和 B 脚本正在使用其中的一些功能。除了通过在 ( ... )
中包含命令来显式创建子 shell 之外,还将为管道中运行的任何 bash 命令创建子 shell,在命令替换 ($( .. . )
或反引号),或以 &
为背景。这是一个说明这些的脚本:
$ cat a
#!/bin/bash
echo "Initial subshell count: $BASH_SUBSHELL"
ps -opid,ppid,command | egrep "PID|bash ./a"
echo "input" | while read line; do
echo "Subshell count in pipeline: $BASH_SUBSHELL"
ps -opid,ppid,command | egrep "PID|bash ./a"
done
output=$(echo "Subshell count in \$(): $BASH_SUBSHELL"
ps -opid,ppid,command | egrep "PID|bash ./a"
)
echo "$output"
( echo "Subshell count in (): $BASH_SUBSHELL"
ps -opid,ppid,command | egrep "PID|bash ./a"
)
{ echo "Subshell count in backgrounded command: $BASH_SUBSHELL"
ps -opid,ppid,command | egrep "PID|bash ./a"
} &
sleep 1
$ ./a
Initial subshell count: 0
PID PPID COMMAND
1410 158 /bin/bash ./a
1412 1410 egrep PID|bash ./a
Subshell count in pipeline: 1
PID PPID COMMAND
1410 158 /bin/bash ./a
1414 1410 /bin/bash ./a
1416 1414 egrep PID|bash ./a
Subshell count in $(): 1
PID PPID COMMAND
1410 158 /bin/bash ./a
1417 1410 /bin/bash ./a
1419 1417 egrep PID|bash ./a
Subshell count in (): 1
PID PPID COMMAND
1410 158 /bin/bash ./a
1420 1410 /bin/bash ./a
1422 1420 egrep PID|bash ./a
Subshell count in backgrounded command: 1
PID PPID COMMAND
1410 158 /bin/bash ./a
1423 1410 /bin/bash ./a
1426 1423 egrep PID|bash ./a
(注意:在 echo ... | while ...
示例中,echo
和 while 循环都在子 shell 中执行;但是 echo 命令退出得太快ps
来显示它。)
关于linux - bash 启动额外的、虚假的后台进程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9164348/
从 0 开始搭建一套后台管理系统,成本巨大,所以都会选择一套成熟的组件库,基于此,再堆叠业务逻辑。我们公司的组件库基于 Ant Design。Ant Design 包含一套完整的后台解决方案,不仅
在我的 IOS 应用程序中,我有一个标记为 retain 的 NSDate* 属性 当我的应用程序再次激活时,属性值已被释放。 我是否误解了属性和内存管理的工作原理,我该如何防范? 最佳答案 很明显,
我有一个使用 BackgroundWorker 组件的示例 WinForms 应用程序。它工作正常,但是当我点击 Cancel 按钮取消后台线程时,它并没有取消线程。当我点击 Cancel 按钮调用
我目前正在开发一个应用程序,该应用程序在启动时会对服务器执行 ping 操作,该服务器会为每个连接的设备返回一个唯一标识符。设备每 5 秒从服务器检索另一页以获取一组不同的数据。这个唯一的 ID 可以
我正在开发一个应用程序,当它通过主页按钮在后台按下时,计时器应该启动,当应用程序返回前台并且计时器已经过了一定时间时,应该是执行。 我的问题是 当我的应用程序转到背景/前景? 是否有特殊的方法或其他技
我有 map View ,其中几乎没有 MKPointAnnotation。 一切正常,但是, View 的 MKPoiintAnnotation 的“背景”是“不可见的”,因此不是很“可见”。 我想
我在 iOS 中开发广告数据应用程序。我的应用程序广告数据在前台很好。但我想在 ios 后台宣传信标数据。我设置了背景外设设置。和广告数据 advertisingData = [CBAdvertise
如果我有一组操作,我想根据特定条件在后台工作程序中运行,例如,我有 10 个条件 if(a) BackgroundWorker doA = new backgroundworker() if(
我想独立运行一个函数。从我调用的函数中,我想在不等待其他函数结束的情况下返回。 我试过用 threadind,但这会等待,结束。 thread = threading.Thread(target=my
我想在用户在线时立即执行一些任务,即使他在后台也是如此。我正在使用 Reachability 类来检查互联网。但是当我在后台时,这个类没有通知我。我知道有人早些时候问过这个问题,但没有找到任何解决方案
我在后台播放文本转语音时出现间歇性(哎呀!)问题,由 Apple Watch 触发。我已经正确设置了后台模式、AVSession 类别和 WatchKitExtensionRequest 处理程序。
我有一个相当复杂的程序,所以我不会在这里转储整个程序。这是一个简化版本: class Report { private BackgroundWorker worker; public
我有一个任务在 backgroundworker 中运行。单击开始按钮,用户将启动该过程,并获得一个取消按钮来取消处理。 当用户点击取消时,我想显示一个消息框“进程尚未完成,你想继续吗”。 这里我希望
我有一个按以下方式编码的脚本。我想将它作为后台/守护进程运行,但是一旦我启动脚本,如果我关闭它从程序运行的终端窗口终止。我需要做什么来保持程序运行 loop do pid = fork do
我正在制作一个使用 ActivityRecognition API 在后台跟踪用户 Activity 的应用,如果用户在指定时间段(例如 1 小时)内停留在同一个地方,系统就会推送通知告诉用户去散步.
当尝试使用 URLSession 的 dataTaskPublisher 方法发送后台请求时: URLSession(configuration: URLSessionConfiguration.ba
当我编译这段代码时,我得到了他的错误,对象引用设置为null,错误位置在Dowork中,argumenttest.valueone = 8; public partial class Form1 :
有什么方法可以使用最小化或不活动的应用程序吗?我可以打开我的应用程序,然后打开并使用另一个应用程序,然后按一个按钮来激活我的程序吗? 例如,打开我的应用程序,打开 Safari,按下按钮(F1 或任何
我的具体要求是一个在后台运行的应用程序,被通知显示器即将进入休眠状态或者设备已经或即将达到空闲超时 - 然后唤醒并执行一些(简短的)一段代码。 我在这里找到了有关应用程序被置于后台或暂停的通知的引用:
我有一个 LSUIElement 设置为 1 的应用程序。它有一个内置编辑器,因此我希望该应用程序在编辑器打开时出现在 Cmd+Tab 循环中。 -(void)stepIntoForegrou
我是一名优秀的程序员,十分优秀!