Symfony Uncaught异常 - '该过程已通过信号" 9"

时间:2015-10-15 11:06:39

标签: php symfony pdf twig

尝试使用Phantomjs和Symfony的Process和Reposonse文件创建PDF文档时出现此错误。

这是我收到的错误消息

致命错误:未捕获的异常' Symfony \ Component \ Process \ Exception \ RuntimeException'有消息'该过程已通过信号" 9"发出信号。'

以下是我的代码:控制器文件

    namespace PhantomFox\Capture;

    use PhantomFox\Views\View;
    use Symfony\Component\Process\Process;
    use Symfony\Component\HttpFoundation\Response;

    class Capture
    {   
        protected $view;
        protected $pdf;

        public function __construct()
        {
            $this->view = new View;
        }

        public function load($filename, array $data = [])
        {
            $view = $this->view->load($filename, $data);

            $this->pdf = $this->captureImage($view);
        }

        public function respond($filename)
        {
            $response = new Response(file_get_contents($this->pdf), 200, [
                'Content-Description' => 'File Transfer',
                'Content-Disposition' => 'attachment; filename="' . $filename . '"',
                'Content-Transfer-Encoding' => 'binary',
                'Content-Type' => 'application/pdf',
            ]);

            unlink($this->pdf);

            $response->send();
        }

        protected function captureImage($view)
        {
            $path = $this->writeFile($view);

            $this->phantomProcess($path)->setTimeout(10)->mustRun();

            return $path;
        }
    protected function writeFile($view)
    {
        file_put_contents($path = 'app/tmp/storage/' . md5(uniqid()) . '.pdf' , $view);

        return $path;
    }

    public function phantomProcess($path)
    {
        return new Process('app/bin/phantomjs capture.js ' . $path);
    }

}

这是我的观点文件:

class AppController extends Controller {

    public function index() {

        $this->capture->load('index.html', [
            'order' => '123456',
            'name' => 'Wes Murray',
            'amount' => 100.00,
        ]);

        $this->capture->respond('index.pdf');

    }
}

2 个答案:

答案 0 :(得分:1)

根据这篇文章The process has been signaled with signal "9",这可能与您的主机内存不足有关。

i.am.michiel 3月4日7:56

  

这实际上可能是一个资源问题。你可能想检查一下   您的服务器的虚拟硬件。

德米特里3月4日11:56

  

@ i.am.michiel,谢谢,虚拟服务器内存不足。

检查您的服务器设置和硬件是否适合您要运行的PDF操作。

答案 1 :(得分:0)

当您更改 supervisord 配置时也会发生这种情况。

当您更改配置并运行重新读取和更新命令时,supervisord 将向子进程发送停止信号。如果它们没有在 stopwaitsecs 配置变量指定的时间内完成,它们将被 9 个信号杀死。

就我而言,我使用的是 Laravel,我必须将 stopwaitsecs 值设置为大于我运行时间最长的作业(正如文档中实际提到的那样)