2016-04-13 11 views
1

Ich aktualisierte Laravel 5.1 zu 5.2 und das Ereignis überträgt nicht mehr.Ereignisübertragung in Laravel 5.2 mit Redis und Socket.io

Ich benutze Laravel Homestead mit PHP 7 und hhvm, Knoten 5.3.0, Redis 3.0.6.

Redis funktioniert gut. (Ich habe Redis :: publish probiert).

Ich habe das Ereignis ausgelöst, aber ich bekomme keine Nachricht.

Event-Klasse

namespace App\Events; 

use App\Events\Event; 
use Illuminate\Queue\SerializesModels; 
use Illuminate\Contracts\Broadcasting\ShouldBroadcast; 

class UserSignedUp extends Event implements ShouldBroadcast 
{ 
    use SerializesModels; 

    public $username; 

    /** 
    * Create a new event instance. 
    * 
    * @return void 
    */ 
    public function __construct($username) 
    {print_r($username); 
     $this->username = $username; 
    } 

    /** 
    * Get the channels the event should be broadcast on. 
    * 
    * @return array 
    */ 
    public function broadcastOn() 
    { 
     return ['test-channel']; 
    } 
} 

Strecke

Route::get('event', function() { 
    $data = [ 
     'event' => 'UserSignedUp', 
     'data' => [ 
      'username' => 'JohnDoe' 
     ] 
    ]; 

// Works fine 
    Redis::publish('test-channel', json_encode($data)); 

// It does not broadcast anything 
    event(new \App\Events\UserSignedUp('JohnDoe')); 
}); 

Socket.io Server

var app = require('express')(); 
var http = require('http').Server(app); 
var io = require('socket.io')(http); 
var Redis = require('ioredis'); 
var redis = new Redis(); 

redis.subscribe('test-channel', function (err, count) { 
}); 

redis.on('message', function (channel, message) { 
    console.log('Message Recieved: ' + message); 

    message = JSON.parse(message); 

    io.emit(channel + ':' + message.event, message.data); 
}); 

http.listen(3000, function() { 
    console.log('Listening on Port 3000'); 
}); 

Env Config

CACHE_DRIVER=redis 
SESSION_DRIVER=redis 
QUEUE_DRIVER=redis 
BROADCAST_DRIVER=redis 

REDIS_HOST=127.0.0.1 
REDIS_PASSWORD=null 
REDIS_PORT=6379 

Antwort

5

alle Ereignisse, die ausgelöst werden, werden in der redis Warteschlange geschoben, die Sie übertragen müssen den Auftrag in der Warteschlange freigeben, können Sie die

php artisan queue:listen ....

oder

php artisan queue:work

Befehl

+0

Hallo da! Ich habe das gleiche Problem mit Laravel 5.3. Ich habe 'php artisan queue: work' und' php artisan queue: listen' versucht, aber keiner von ihnen hat funktioniert. Als ddr angegeben 'Ereignis (new \ App \ Events \ TestEvent());' sendet nichts. Irgendwelche andere Empfehlung? – KoKa