清除服务器上传队列的文件,异步高效处理视频上传

异步高效处理视频上传

由 学院君 创建于4个月前, 最后更新于 4个月前

版本号 #2

662 views

0 likes

2 collects

通过队列处理上传

对于图片、文件、视频上传之类的耗时任务,可以将上传到服务端后的压缩、处理和存储操作推送到消息队列异步处理:

d39990513217ee65a0456cd80209e785.png

Laravel 会将一个序列化的文件对象推送到队列,然后进行处理。

如果想要将文件内容推送到队列,可以将文件进行二进制序列化:

d26017fadaf8f5013091cce7409a78cb.png

接下来,在 CompressAndStoreVideo 的 handle 方法中,可以将文章内容写入磁盘并进行处理。

使用这种方法可行,但是将整个文件内容推送到队列会占据太大的存储空间,如果是基于 Redis 驱动的队列的话,会消耗大量的内存空间,对于某些第三方的队列服务(SQS)对每个队列任务的大小还有限制,所以这不是最优解。

减少任务负荷大小

处理队列任务时,应该让队列任务负荷尽可能小和简单,比如 Laravel 默认会将 Model 实例转化为 ModelIdentifier 推送到消息队列以便减少队列任务负荷大小。

ModelIdentifier 是一个包含模型 ID、类名、数据库连接、关联关系的简单对象实例:

552368b6ae71df12f1496ba1b72ca6d5.png

在真正处理队列任务时,Laravel 会通过这些属性来构建一个全新的 Model 实例。这种模式被称之为 Reference-Based 消息传递或者 ClaimCheck 模式。

我们也可以使用这种模式来处理视频上传 —— 只将文件引用推送到队列:

906d14af7877a44e38de8709e9120e5f.png

现在,在队列任务处理器中,可以通过该文件的临时存储路径加载文件,处理并输出到指定位置,最后删除这个临时文件:

e10a08a236c05ad73e3bfe1bd00ca7c2.png

处理任务失败

Laravel 会将处理失败的任务存放到 failed_jobs 数据表中,以便后续可以重新运行这些失败任务。

对于文件上传任务来说,如果失败后不想手动重试,则临时文件需要删除,你可以在任务类的 failed 方法中执行这个删除操作:

bcb286ff999da422ff1837a20ae76c3a.png

如果还想重试,则不能删除临时文件,这种情况下,你可以推送一个延迟的文件删除任务到队列:

b4ed04a21ebd61cf9088fbd5dfdda13b.png

现在,在 handle 方法中,需要在运行任务前先检查临时文件是否存在:

8020f5c726fdb3c28bd5a1b8ae8acb1d.png

如果不存在,抛出异常、记录日志、然后将该任务从队列中删除,这样就不会重试它了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值