在短视频app开发的很多业务场景中对数据实时性的要求会比较高,为提升数据的实时性,我们常采用轮询的方式进行数据的获取,如果在短视频app开发中使用轮询后数据实时性仍不达标,那我们不妨试试长连接。
一、轮询
在短视频app开发中,轮询方式有两种,分别是短轮询和长轮询,不同的轮询方式适用不同的业务场景,且具备不同的优缺点:
1、短轮询
所谓的短轮询是指前端通过定时器实现请求的定时发送,服务端在接收到请求后立即返回结果,以此来实现数据的实时刷新。
(1)优点:短轮询在短视频app开发中时间较为简单。
(2)缺点:前端设置时间间隔定时去请求数据,就有可能导致返回数据相同或返回空结果,导致无用请求过多,浪费系统资源。而且实时性并不容易把控,如果在轮询请求刚结束完一轮时,数据进行了更新,那在下一轮轮询开始前,显示的数据均不是zui新数据。
2、长轮询
所谓的长轮询是指短视频app开发的客户端发起请求后,服务端会在数据没有更新时等待一段时间后再返回结果,如果在等待时间结束后,数据仍没有更新则返回空结果。客户端在接收到服务端返回的结果后会立即再次发送新请求。
(1)优点:长轮询避免了大量重复请求,且可以更好地控制数据实时性、
(2)缺点:服务端消耗的资源比较大,如果数据更新比较频繁的话,长轮询无法及时处理。
二、长连接
通过上述内容可知,虽然长轮询弥补了短轮询的部分缺点,却无法灵活应对短视频app开发中数据更新比较频繁的场景,为此,我们不妨尝试一下长连接。
所谓的长连接其实就是在客户端和服务端之间建立一个持久的、用于数据传输的连接,该连接建立后并不会随着单次请求的结束而断开,而是会一直保持连接状态。
在短视频app开发中使用长连接可以实现同一条信道的复用,节省了连接创建所占用的时间,但是长连接可能会存在对头阻塞问题。
为实现达标的数据实时性,在短视频app开发时,我们不仅可以采取轮询,还能采用长连接。其实短视频app开发就是一个不断钻研的过程中,只是经过多方面的尝试,才能选择出一条合适的、正确的发展道路。
声明:本文由云豹科技原创,转载请注明作者名及原文链接,否则视为侵权