我想在后台运行一个php脚本,并将其PID存储在数据库中,以便稍后检查特定脚本是否正在运行。
我们可以使用getmypid
获取当前PID。
但根据PHP手册的说法:
进程ID并不唯一,因此它们是一个弱熵源。我们建议不要在安全相关的上下文中依赖pid。
...所以我不能依靠PID。
我的第二个想法是将进程创建时间存储到数据库中。
如何获取当前脚本创建时间?稍后如何与任务列表进行比较以检查特定脚本是否正在运行?
我在共享主机上运行,环境为Windows / Linux。
我想在后台运行一个php脚本,并将其PID存储在数据库中,以便稍后检查特定脚本是否正在运行。
我们可以使用getmypid
获取当前PID。
但根据PHP手册的说法:
进程ID并不唯一,因此它们是一个弱熵源。我们建议不要在安全相关的上下文中依赖pid。
...所以我不能依靠PID。
我的第二个想法是将进程创建时间存储到数据库中。
如何获取当前脚本创建时间?稍后如何与任务列表进行比较以检查特定脚本是否正在运行?
我在共享主机上运行,环境为Windows / Linux。
从php.net/getmypid获取到的内容,稍微修改以禁用非 cli 访问。
脚本可以使用/usr/bin/php script.php
执行。
此外,使用nohup /usr/bin/php script.php > nohup.out &
在后台启动nohup进程。
#!/usr/bin/php
<?php
if ( PHP_SAPI !== 'cli' ) {
die( "Cmd line access only!\n" );
}
define( 'LOCK_FILE', "/var/run/".basename( $argv[0], ".php" ).".lock" ); // can also use /tmp
if( isLocked() ) die( "Already running.\n" );
# The rest of your script goes here....
echo "Hello world!\n";
sleep(30);
unlink( LOCK_FILE );
exit(0);
function isLocked()
{
# If lock file exists, check if stale. If exists and is not stale, return TRUE
# Else, create lock file and return FALSE.
if( file_exists( LOCK_FILE ) )
{
# check if it's stale
$lockingPID = trim( file_get_contents( LOCK_FILE ) );
# Get all active PIDs.
$pids = explode( "\n", trim( `ps -e | awk '{print $1}'` ) );
# If PID is still active, return true
if( in_array( $lockingPID, $pids ) ) return true;
# Lock-file is stale, so kill it. Then move on to re-creating it.
echo "Removing stale lock file.\n";
unlink( LOCK_FILE );
}
file_put_contents( LOCK_FILE, getmypid() . "\n" );
return false;
}
?>
ps -ax
的输出中grep它们以检查它们是否正在运行。如果没有-从数据库中删除它们,以便您不会遇到相同PID的问题。您可以尝试使用PID与另一个ID,例如:
如果您有一个使用文件ID = 327的压缩作业,请尝试存储{PID} 327,并检查此特定作业是否仍在运行。
即使PID被重用,您也不会将具有ID 327存储的PID,或者如果您重新启动具有此特定ID 327的压缩过程,则PID可能会更改。
但是,为了避免使用此ID 327获取相同的PID,您需要先检查数据库,然后在组成的ID末尾添加计数器,例如{PID} 327_1。
希望这可以帮助到您。
srand(getmypid());
。你似乎需要某种进程监控机制,如daemontools、perp、minit等:大多数这些机制都会派生出一个子进程,并监视文件描述符和信号来查看子进程是否仍然活动。对于你的想法,你必须解决时序问题、权限等问题(以确定在数据库中存储的PID所对应的进程实际上是否是同一个进程)。 - akira一个极简、通用且独立于框架的作业队列接口
- akira