- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个 crontab,看起来像:
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
HOME=/
0-59 * * * * /var/www/html/private/fivemin/zdaemon.php >> /dev/null &
越简单越好,对吧?
我正在测试的 zdaemon.php 是:
#!/usr/bin/php
<?
while(true){
sleep(1);
}
?>
无论何时运行,它都会像这样挂起:
root 15532 0.0 0.1 57228 1076 ? Ss 19:09 0:00 crond
root 16681 0.0 0.1 72196 1428 ? S 21:46 0:00 crond
root 16682 0.0 0.0 0 0 ? Zs 21:46 0:00 [bash] <defunct>
root 16683 0.0 0.5 54800 5740 ? S 21:46 0:00 /usr/bin/php /var/www/html/private/fivemin/zdaemon.php
root 16687 0.0 0.1 72196 1428 ? S 21:47 0:00 crond
root 16688 0.0 0.0 0 0 ? Zs 21:47 0:00 [bash] <defunct>
root 16689 0.0 0.5 54800 5740 ? S 21:47 0:00 /usr/bin/php /var/www/html/private/fivemin/zdaemon.php
我整天都在为这件事绞尽脑汁。有没有人见过这个?有什么想法吗?
这是对:Init.d script hanging 的引用
最佳答案
僵尸 进程本身并不一定是坏事。它表明 child 进程已经死亡,parent 进程还没有获得它的状态(使用 wait()
或相关的系统调用).
发生的事情如下 - cron
对它启动的脚本中的 stderr 感兴趣(这样它可以在脚本失败时通过电子邮件将其发送给您),因此它创建了一个 pipe,它附加了脚本的 stderr 到写端(文件描述符 2)。然后 cron
坐在管道的读取端读取,等待脚本退出并读取 eof (零字节的 read()
) - 然后它获取脚本的返回状态。
在您的示例中,生成的守护程序继承了 stderr 文件描述符,因此当中间 shell 退出(并失效)时,管道将由守护程序保持打开状态。因此,cron
从不读取 eof,因此从不获取返回状态。
解决方案是确保您的守护程序的 stderr 已关闭。这可以通过以下方式实现:
0-59 * * * * /var/www/html/private/fivemin/zdaemon.php >> /dev/null 2>&1 &
这会将 stdout 和 stderr 写入 /dev/null
关于php - 疯狂的 crond 行为。不断制作失效的 bash 进程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3748432/
我的系统基于 Linux ( 3.12.14 ),我可以看到僵尸进程 [ sh ]非常频繁地创建。 我发现 (crond -l 9) 是僵尸的父进程。我确认,始终 crond -l 9 是父进程。 根
我有一台基于 64 位 Fedora 24 的精简单用户操作系统的机器: 供应商:Acer Veriton VN4640G CPU:Intel(R) Core(TM) i5-6400T CPU @ 2
我是 CentOS 的新手,每当我尝试重新启动 puppet 服务 - pe-puppetdb、pe-puppetserver 等时,我都会收到以下错误: Jun 23 04:03:01 abc.xy
我正在尝试运行一个 Node 12.13.0 Alpine Docker 容器,该容器每 15 分钟运行一次脚本。根据 Alpine's wiki cron section ,我应该能够在 Docke
语境 我正在尝试 日程安排 中的一些摄取工作 Alpine 容器。我花了一段时间才明白为什么我的 定时任务 没有启动:crond 似乎没有运行 rc-service -l | grep crond 根
我有一个运行 busybox 的嵌入式设备。该设备已安装并运行 crond,但没有 atd 守护程序。我需要安排任务在给定时间运行(只运行一次,而不是定期运行)。我知道,“kosher”方法是使用 a
假设我正在实现一个时钟,并且我想最小化每单位时间的唤醒次数。所以,我只想在整分钟被叫醒(当我需要更新显示时)。在 C(或 C++)中执行此操作(最好是可移植的)的最佳方法是什么? 最佳答案 C++03
我有一个每分钟从 cron 启动的 php 脚本。 除了在 24 小时内大约运行 10 次之外,它几乎总是没有任何问题。 它失败的时候我会得到一个段错误,比如:bin/sh: 第 1 行:21815
默认情况下,crond 未在 official postgres alpine image 中运行.我如何定义我的 Dockerfile 以确保守护进程在后台运行?我希望它默认运行,如果可能的话,即使
/etc/init.d/crond 没有运行的可能原因是什么? 如何调试? 可以查找哪些日志文件来对此进行调试? 最佳答案 请检查:- tail -f /var/log/cron和tail -f /v
我知道这个问题已经被问过无数次了,但我正在寻找一个使用 crond 的 native 日志功能的解决方案。我不想通过管道传输每个 cron 的输出并在前面添加时间戳。 我像这样启动 crond: cr
几个小时以来,我一直在为这个问题苦苦思索。我欢迎任何关于下一步去向的新想法。 目标是通过 SSH 登录自定义应用程序 CLI,然后使用自定义 CLI 命令之一在远端设备上下拉调试 shell。在客户端
我有一个 crontab,看起来像: SHELL=/bin/bash PATH=/sbin:/bin:/usr/sbin:/usr/bin MAILTO=root HOME=/ 0-59 * * *
我正在使用下面的 Dockerfile 和 entrypoint.sh。我需要以非 root 用户身份在容器中启动 crond 服务,但我得到了 Permission denied。如何以非 root
我希望能够使用 cron 在一个小时内在容器服务中运行一个简单的 bash 脚本。我通过 docker-compose 使用 Alpine Linux 和自定义 Dockerfile 来生成基于 ph
我有一个非常基本的 python 脚本,它使用 boto 来查询我的 EC2 实例的状态。当我从控制台运行它时,它工作正常,我很高兴。问题是当我想添加一些自动化并通过 crond 运行脚本时。我注意到
我在 Alpine Linux 上运行非根 crontab 文件时遇到了麻烦。 我已经浏览了另外两个与 cron 相关的帖子,但我没有答案: https://askubuntu.com/questio
我正在我的 Ubuntu 16.04 中编写一些计划任务。 但是当我尝试通过以下方式启动 crond.service 时 sudo service crond start 我收到消息 crond.se
如果我在命令 shell 上以交互方式运行我的脚本,它就会工作: $ cat ndmpcopy_cron_parallel_svlinf05.bash #!/usr/software/bin/bash
我是一名优秀的程序员,十分优秀!