I do and I understand

消息中心(实现)

前言


在上一章主要梳理了信息中心的运行机制,了解了服务端是如何把更新的信息主动推送给客户端的,接下来我会介绍下消息中心是如何搭建的以及现在可能会出现问题。

背景知识


laravel 队列运行机制:队列
消息中心实现逻辑:消息中心(逻辑)

消息中心

1.设置配置

.env文件

1
2
BROADCAST_DRIVER = redis
QUEUE_DRIVER=redis

config/app.php

1
App\Providers\BroadcastServiceProvider::class  //加载
2. 设置路由

//设置用户频道,以便客户端监听。为了方便,直接返回true

1
2
3
Broadcast::channel('todoevent.updated.*', function($user, $userId){
return true;
});
3. 添加predis依赖
1
composer require predis/predis
4. 创建事件类
1
php artisan make:event TodoEventUpdated

//默认是不实现ShouldBroadcast接口

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
        class TodoEventUpdated implements ShouldBroadcast
{
use InteractsWithSockets, SerializesModels;

public $event;

public function __construct($event)
{
$this->event= $event;
}

//添加私人频道,于路由设置一致
public function broadcastOn()
{
if($this->event) {

return new PrivateChannel('todoevent.updated.' . $this->event->get('user_id'));
}
}

//可对事件内容作修改。返回客户端需要的内容
// public function broadcastWith()
// {
// }
}
5. 测试广播已到redis

HomeController.php

1
2
3
4
5
use App\Events\TodoEventUpdated;
public function index()
{
broadcast(new TodoEventUpdated(collect(['user_id' => 8164])));
}

执行home/index后,查看redis客户端

1
2
"SELECT" "0"
"RPUSH" "queues:default" "{event}"

event已经写入redis,代表redis连接成功

6. 开启消费进程
1
php artisan queue:work

//发现事件已被消费

1
2
Processing: App\Events\TodoEventUpdated
Processed: App\Events\TodoEventUpdated
7. 安装 laravel-echo-server,订阅redis
1
cnpm install -g laravel-echo-server

安装成功后,移步到项目下

1
2
laravel-echo-server init  //初始化
laravel-echo-server start //启动

image
laravel-echo-server 已成功的监听了 redis 。
注:laravel-echo-server 运行在6001端口,如果你用的是homestead等集成环境,请查看端口是否开启

8. 安装socket.io-client、laravel-echo
1
2
cnpm i --save socket.io-client
cnpm i --save laravel-echo

打开/resources/assets/js/bootstrap.js,会出现下面代码

1
2
3
4
5
6
import Echo from 'laravel-echo'
window.Pusher = require('pusher-js');
window.Echo = new Echo({
broadcaster: 'pusher',
key: 'your-pusher-key'
});

改造为:

1
2
import Echo from 'laravel-echo'
window.LaravelEcho= Echo;

编译

1
cnpm run dev

以上的事件广播都搭建完了。下面让第三方应用可以监听吧

9. 第三方应用监听
1
2
3
4
5
6
7
8
9
10
11
<script src="http://xxx:6001/socket.io/socket.io.js"></script> //引入socket.io客户端
<script src="text/javascript">
window.Echo = new LaravelEcho({
broadcaster: 'socket.io',
host: 'http://xxx:6001'
});
Echo.private('todoevent.updated.8164')
.listen('TodoEventUpdated', function(event) {
console.log(event); //获取的信息
});
</script>