《Designing Web APIs》第二章讲到事件驱动API的几种方式。
-
WebHooks: HTTP回调通知。 用于服务对服务的实时事件通知。
优点:服务对服务,使用HTTP协议。
缺点:不能跨防火墙,不能用在浏览器端,失败重试机制(三次重试:立即,1分钟后,5分钟后),安全(如何验证回调源)。 -
WebSockets:基于TCP的双向连接。用于浏览器和服务器之间的实时双向通信。
优点:双向流,天生的浏览器支持(也可用于服务对服务),跨防火墙。
缺点:需要持久链接,不能使用HTTP。 -
HTTP Streaming:基于HTTP的长链接。设置Transfer-Encoding=chunked,或者服务器端使用SSE(Server-sent events)浏览器使用EventSource API来监听事件。
优点:基于HTTP的流,浏览器支持,跨防火墙。
缺点:只能单向(服务器到浏览器),如果想注册不同的事件需要重新连接。