使用Supervisor运行棘轮腹板并在laravel中排队

时间:2017-03-30 00:32:01

标签: php laravel supervisor ratchet phpwebsocket

我做了一个工匠命令,在某个端口上运行一个websockets,如下面的

class webSockets extends Command
{
    /**
     * The name and signature of the console command.
     *
     * @var string
     */
    protected $signature = 'run:socket {port?}';

    /**
     * The console command description.
     *
     * @var string
     */
    protected $description = 'Run websockets for specified port';

    /**
     * Create a new command instance.
     *
     * @return void
     */
    public function __construct(RedisInterface $redis)
    {
        $this->redis=$redis;
        parent::__construct();
    }

    /**
     * Execute the console command.
     *
     * @return mixed
     */
    public function handle()
    {
        //
       $port = $this->argument('port');
       if($port=='8182') {
            $server = IoServer::factory(
                         new SocketController($this->redis),$port
                    );
       }
       else if($port=='8181'){
            $server = IoServer::factory(
                         new Socket1Controller($this->redis),$port
                    );
       }



       $server->run();
    }
}

我可以运行这些套接字轻松运行如下面的工匠命令

php artisan run:socket 8181
php artisan run :socket 8182

我需要将它部署在生产服务器上,该服务器上有数千个设备连接在该网络套接字上。 我试过主管守护程序,但没有运气

我的conf文件如下所示

[program:ratchet]
command                 = php /var/www/v3 artisan run:socket 8181;php /var/www/v3 artisan run:socket 8182
process_name            = Ratchet
numprocs                = 1
autostart               = true
autorestart             = true
stdout_logfile          = ./logs/info.log
stderr_logfile          = ./logs/error.log

我意识到端口8181和8182都是免费的,并且没有收到任何消息。

当我尝试sudo service supervisorctl时,我看到所有进程都有正常运行时间0:00:00和不同的pid

laravel_queue                    RUNNING   pid 62246, uptime 0:00:00
ratchet:Ratchet                  RUNNING   pid 62245, uptime 0:00:00
supervisor> status
laravel_queue                    RUNNING   pid 62305, uptime 0:00:00
ratchet:Ratchet                  RUNNING   pid 62304, uptime 0:00:00
supervisor> status
laravel_queue                    RUNNING   pid 62419, uptime 0:00:00
ratchet:Ratchet                  RUNNING   pid 62418, uptime 0:00:00
supervisor> status
laravel_queue                    RUNNING   pid 62553, uptime 0:00:00
ratchet:Ratchet                  RUNNING   pid 62552, uptime 0:00:00
supervisor> status
laravel_queue                    RUNNING   pid 62689, uptime 0:00:00
ratchet:Ratchet                  RUNNING   pid 62688, uptime 0:00:00
supervisor> status
laravel_queue                    RUNNING   pid 62819, uptime 0:00:00
ratchet:Ratchet                  RUNNING   pid 62818, uptime 0:00:00
supervisor> status

我错过了什么吗?

1 个答案:

答案 0 :(得分:0)

  

我设法通过在主管上单独处理来解决这个问题

  1. 管理队列
  2. 在/etc/supervisord/conf.d/中创建laravel_queue.conf:

    [program:laravel_queue]
    command= php artisan queue:listen redis --timeout=7200
    directory=/var/www/gpsv3
    stderr_logfile=/var/www/gpsv3/storage/logs/laraqueue.err.log
    stdout_logfile=/var/www/gpsv3/storage/logs/laraqueue.out.log
    redirect_stderr=true
    

    赋予它执行权限:chmod + x laravel_queue.conf

    现在更新主管:sudo supervisorctl reread。并开始使用以下更改:sudo supervisorctl update。

    1. 套接字侦听器
    2. 在/etc/supervisord/conf.d/中创建socket.conf:

      [program:socket]
      command= php artisan run:socket 8182
      directory=/var/www/gpsv3
      stderr_logfile=/var/www/gpsv3/storage/logs/socket.err.log
      stdout_logfile=/var/www/gpsv3/storage/logs/socket.out.log
      redirect_stderr=true
      

      赋予它执行权限:chmod + x socket.conf

      现在更新主管:sudo supervisorctl reread。并开始使用以下更改:sudo supervisorctl update。