基于Node.js实现Minio对象存储的图片自动压缩服务
利用 Minio 的通知功能,在有图片上传后,通知到 Nodejs 服务,压缩图片再上传
项目地址
https://github.com/houxiaozhao/minio-compresses-images
主要使用的库
- minio - Minio 的 Nodejs 客户端
- sharp - 图片压缩库
- koa - Nodejs 的 web 框架
- bull - Nodejs 的队列库
流程
因为 sharp 的处理图片速度比较慢,所以使用了队列,将图片压缩的任务放到队列中,然后再从队列中取出任务,进行压缩。
主要压缩的代码
1 | const minioClient = new minio.Client(config.minio); |
优化整个流程速度的几个重要的点
- 使用流的方式读取图片,然后再写入到 Minio 中,这样可以减少内存的使用,不产生临时文件
- sharp 添加 sequentialRead: true,这样可以让 sharp 顺序读取图片
- 使用队列,将图片压缩的任务放到队列中,然后再从队列中取出任务,进行压缩,这样可以让压缩图片的任务不会阻塞其他任务
- 不使用 docker 部署 minio,而是直接使用 minio 的二进制文件,这样可以减少网络延迟
- 适当提高 bull 的并发数,这样可以让队列中的任务更快的被处理
Minio 部署和配置
Minio 部署
下载二进制文件,然后执行
1 | MINIO_ROOT_USER=username MINIO_ROOT_PASSWORD=password minio server /data/minio --console-address ":9001" |
使用 minio 中的 listenBucketNotification 功能监听
不需要配置通知,直接使用 listenBucketNotification 功能监听
1 | let poller = minioClient.listenBucketNotification(config.minio.bucket, "", "", ["s3:ObjectCreated:Put"]); |
Minio 配置通知 Notification
点击Add Notification Target
有很多通知类型,我们选择Webhook
填写Webhook
的地址,这里填写的是 Nodejs 服务的地址,其他留空即可保存
创建和配置存储桶
- 点击
Create Bucket
- 起一个名字,其他不用改
创建成功后,点击刚创建的存储桶,然后点击Event
,最后点击Subscribe to Event
RAN 里选择 webhook,其他看情况修改,最后点击Save
Nodejs 服务部署和配置
安装依赖
1 | npm install |
配置
1 | // config.js |
启动
1 | node app.js |
此文章版权归houxiaozhao所有,如有转载,请注明来自原作者