基于Actix的并发与可扩展微服务架构
1. WebSocket与Actors的结合
1.1 WebSocket简介
WebSocket是一种基于HTTP的全双工通信协议,常作为主HTTP交互的扩展,用于实时更新或通知。Actors模型非常适合实现WebSocket处理程序,因为可以将代码组合并隔离在一个地方,即Actor的实现中。Actix-web支持WebSocket协议,下面将为微服务添加通知功能。
1.2 Repeater Actor
为了向所有连接的客户端发送新评论的通知,需要维护一个连接客户端的列表。这里创建一个Repeater Actor,它可以将消息重新发送给多个订阅者。
1.2.1 定义RepeaterActor结构体
use actix::{Actor, Context, Handler, Message, Recipient};
use std::collections::HashSet;
use super::NewComment;
pub struct RepeaterActor {
listeners: HashSet<Recipient<RepeaterUpdate>>,
}
1.2.2 实现构造函数
impl RepeaterActor {
pub fn new() -> Self {
Self {
listener