我想在后台运行php脚本并将其PID存储在数据库中。这样我就可以检查特定脚本是否正在运行(稍后)。
我们可以使用getmypid
来获取当前的PID。
但是根据PHP手册
进程ID不是唯一的,因此它们是弱熵源。我们 建议不要依赖安全依赖的上下文中的pid。
......我不能依赖PID。
我的第二个想法是将流程创建时间存储到数据库中。
如何获取当前脚本的创建时间?以后如何与tasklist进行比较以检查特定脚本是否正在运行?
我在共享主机,windows / linux环境中运行。
答案 0 :(得分:2)
几乎没有修改来禁用非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;
}
?>
答案 1 :(得分:1)
这一切都取决于您对目标计算机的访问级别。您可以使用PHP CLI,存储PID(它们在特定时间点是唯一的,因此您不会有2个运行相同PID的进程)并在ps -ax
的输出中grep它们以检查它们是否正在运行。如果不是 - 从数据库中删除它们,这样就不会出现相同的PID问题。
答案 2 :(得分:0)
您可以尝试将PID与另一个ID一起使用,例如:
如果您有一个使用文件ID = 327的压缩作业,请尝试存储{PID} 327,并检查此特定作业是否仍在运行。
即使重新使用PID,也不会存储ID为327的PID,或者如果您重新启动ID为327的压缩过程,则PID可能会更改。
但是,为避免获得具有相同ID 327的PID,您必须先检查数据库,然后在组合ID的末尾添加一个计数器,例如{PID} 327_1。
希望这可以为您提供帮助。