Java技术栈 —— 网络带宽受限,图片预览加速

一、方法列表

方法 解释
图片压缩 降低图片大小
图片懒加载 滚动加载:只加载用户视野范围内的图片,当用户滚动页面时再加载其他图片
按需加载:根据用户的操作预测需要加载的图片,例如在电商网站中,只加载用户正在查看的商品图片
CDN内容分发网络 将图片存储在多个地理位置不同的服务器上,用户可以从距离最近的服务器加载图片,减少延迟
缓存策略 浏览器缓存或应用缓存
优化图片格式 如WebP格式,它通常比JPEG或PNG提供更好的压缩率
分片加载 将大图片分割成多个小块,逐一请求加载
使用流式传输 渐进式JPEG:允许图片逐步加载,从模糊到清晰,给用户一种快速加载的感觉
优化图片质量 降低质量:在不显著影响视觉效果的前提下,适当降低图片的质量以减少文件大小

分片加载和流式传输有区别,分片加载是将图片分割成小块,然后按顺序加载这些图片块

流式传输是,用户会首先看到一个低质量的版本,随着数据的不断到达,图片的质量会逐渐提高。

二、原实现 —— Nginx+Minio

我目前采用的是nginx+minio的实现,局域网可以直接访问minio的图片预览链接,那么在外网的话,通过nginx转发到本地的图片预览链接也是一样的,nginx配置如下

location ^~ /preview/minio/ {
        rewrite ^/preview/minio/(.*) /$1 break;
        
        proxy_pass http://{minio_ip}:{minio_console_port}/;
        #proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
        proxy_redirect off
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值