Php 使用System_守护程序包的Codeigniter守护程序
我正在尝试使用带有CodeIgniter的CLI的System_守护程序包创建守护程序。这对我来说是一个新的领域,我正在努力 以下是我所拥有的: 将消息注入AWS SQS队列的CI控制器(感谢[url=提供了关于如何将AWS SDK集成到CI中的出色说明。请参见此处:) 一种CI控制器,接收队列中的消息并将其写入日志文件,然后删除队列中的消息 我希望有一个CI守护进程,它将侦听此队列,在消息存在时接收消息,并对消息执行一些有用的操作,然后删除消息。因此,我从System_守护进程文档中的示例开始,并从接收程序添加到CI代码中。请参阅下面的代码 这是正确的做法吗?你能引导我以“正确的方式”这样做吗?我已经浏览了各种知识丰富的论坛,并得出了简短的结论……请帮帮我 MmizPhp 使用System_守护程序包的Codeigniter守护程序,php,codeigniter,daemon,Php,Codeigniter,Daemon,我正在尝试使用带有CodeIgniter的CLI的System_守护程序包创建守护程序。这对我来说是一个新的领域,我正在努力 以下是我所拥有的: 将消息注入AWS SQS队列的CI控制器(感谢[url=提供了关于如何将AWS SDK集成到CI中的出色说明。请参见此处:) 一种CI控制器,接收队列中的消息并将其写入日志文件,然后删除队列中的消息 我希望有一个CI守护进程,它将侦听此队列,在消息存在时接收消息,并对消息执行一些有用的操作,然后删除消息。因此,我从System_守护进程文档中的示例开始
!/usr/bin/php-q
守护进程是在后台“永远”运行的进程。
在这里,您只需检查队列中的一条新消息,然后退出。
基本上,您必须添加一个循环,该循环包含所有需要执行的代码。您需要在循环中执行休眠,以避免守护进程占用所有可用资源
无论如何,php不擅长守护程序,因为有些内存在脚本结束之前是不会被释放的。如果你的脚本没有结束(像守护程序一样),它会消耗掉所有可用内存(根据php配置),然后出错而死。你必须非常小心地编写脚本,以避免此类内存泄漏
另外,请注意,每次您向sqs库询问一些事情时,它都会向Amazon服务器发送一个http请求
作为补偿,我建议您使用每分钟运行一次的cronjob来检查新任务。这样可以避免内存泄漏(php进程在执行之间停止)和过多的网络使用(请求在一分钟内发出)
在最后一个注释中,如果你不打算有很多任务(也就是说,守护进程99%的时间不做任何事情),那么就考虑使用推送队列。用推送队列,不再是你的脚本轮询队列,而是队列通知你的脚本(即用标准的HTTP请求调用脚本)。每次都需要完成一些任务。这样可以避免不必要地运行脚本
我不知道amazon是否提供推送队列,但ironmq(另一个“免费”队列服务)可以提供它们。
更多信息:感谢您的建议!我也得出结论,cron作业是一条可行之路。也感谢push_队列指针。非常感谢。
#!/usr/bin/php -q
<?php
// Make it possible to test in source directory
// This is for PEAR developers only
ini_set('include_path', ini_get('include_path').':..');
// Include Class
error_reporting(E_ALL);
require_once "System/Daemon.php";
// Bare minimum setup
System_Daemon::setOption("appName", "receiveaws");
System_Daemon::setOption("logLocation","/tmp/log/receiveaws.log");
System_Daemon::setOption("appPidLocation","/tmp/log/receiveaws/receiveaws.pid");
System_Daemon::log(System_Daemon::LOG_INFO, "Daemon not yet started so this will be written on-screen");
// Spawn Deamon!
System_Daemon::start();
System_Daemon::log(System_Daemon::LOG_INFO, "Daemon: '".
System_Daemon::getOption("appName").
"' spawned! This will be written to ".
System_Daemon::getOption("logLocation"));
System_Daemon::log(System_Daemon::LOG_WARNING, 'My php code starting');
class Receiveaws extends CI_Controller {
public function index(){
if ($this->input->is_cli_request()) {
//Load the aws library
$this->load->library('awslib');
$sqs = new AmazonSQS();
//Get the queue to look at
$res=$sqs->get_queue_url('example-queue');
//Get the queue's url
$qurl=($res->body->GetQueueUrlResult->QueueUrl);
System_Daemon::log(System_Daemon::LOG_INFO,$qurl);
//Get a message from the queue
$response = $sqs->receive_message($qurl);
//If there was a message received, then do something
if ($res->isOK()) {
System_Daemon::log(System_Daemon::LOG_INFO,"Receive message successful");
//Now delete message from queue
$res=$sqs->delete_message($qurl,$rcpt_hand);
if ($res->isOK()) {
System_Daemon::log(System_Daemon::LOG_INFO,"Delete message successful");
}
} else {
//go back to check for messages
//How do you do that?
}
} else {
//Access from URL - so bail out?
//how do you not bail out of the daemon from here?
}
}
}
System_Daemon::stop();
?>