Php 使用System_守护程序包的Codeigniter守护程序

Php 使用System_守护程序包的Codeigniter守护程序,php,codeigniter,daemon,Php,Codeigniter,Daemon,我正在尝试使用带有CodeIgniter的CLI的System_守护程序包创建守护程序。这对我来说是一个新的领域,我正在努力 以下是我所拥有的: 将消息注入AWS SQS队列的CI控制器(感谢[url=提供了关于如何将AWS SDK集成到CI中的出色说明。请参见此处:) 一种CI控制器,接收队列中的消息并将其写入日志文件,然后删除队列中的消息 我希望有一个CI守护进程,它将侦听此队列,在消息存在时接收消息,并对消息执行一些有用的操作,然后删除消息。因此,我从System_守护进程文档中的示例开始

我正在尝试使用带有CodeIgniter的CLI的System_守护程序包创建守护程序。这对我来说是一个新的领域,我正在努力

以下是我所拥有的: 将消息注入AWS SQS队列的CI控制器(感谢[url=提供了关于如何将AWS SDK集成到CI中的出色说明。请参见此处:)

一种CI控制器,接收队列中的消息并将其写入日志文件,然后删除队列中的消息

我希望有一个CI守护进程,它将侦听此队列,在消息存在时接收消息,并对消息执行一些有用的操作,然后删除消息。因此,我从System_守护进程文档中的示例开始,并从接收程序添加到CI代码中。请参阅下面的代码

这是正确的做法吗?你能引导我以“正确的方式”这样做吗?我已经浏览了各种知识丰富的论坛,并得出了简短的结论……请帮帮我

Mmiz

!/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();
?>