zoukankan      html  css  js  c++  java
  • 缩略图相关

    图片服务器上缩略图的那些事儿

    最近一周又对图片服务器进行了一次升级,当然不是硬件上的。

    作为一个图片类网站,我相信你会不可避免的遇到以下问题。

    • 1 怎么搭建独立的图片服务器

    • 2 图片服务器的目录结构怎么设计?

    • 3 web服务器怎么跟图片服务器打交道?

    • 4 每张图片有很多尺寸的缩略图,上传之后要全部生成吗?

    • 5 怎么提高程序中生成缩略图的效率,做到不影响用户体验?

    • 6 该死的产品经理又增加了许多新的需求,多出了几种缩略图尺寸,我该怎么办?

    不管你想不相信,这些问题我都遇到了,而且对于没有任何经验的我,我才用了最容易想到,也是最笨的方法。看看我最开始的解决方法:

    • 1 买个服务器装个系统,要个大点的硬盘就完了呗。

    • 2 全部放到一个文件夹中。

    • 3 我会告诉你我用的是FTP的方式上传吗(我居然都没想到用NFS)

    • 4 全部生成,妥妥的

    • 5 没啥好办法,java里面写程序处理

    • 6 写了个java程序,动态处理这种自定义尺寸的缩略图

    你会发现,我的这些解决方法都好傻啊。对,我也发现了。但是在当时来说,是我能想到的最有效的办法。

    随着图片文件的增多,访问量的增大,怎么提升性能成了考虑的重点。把我现在的解决方案记录一下。

    • 1 这个没什么好说的。

    • 2 根据图片文件名称来存入指定的文件夹。例如图片名称为d5e0b1f51baeec36.jpg,放到/d5/e0/文件夹下,当然,也可以用上传时间等方式命名文件夹。通过Nginx rewrite到指定的文件夹。

    • 3 web服务器POST图片到图片服务器。图片服务器按照指定的规则保存。

    • 4 图片服务器只保存原图,如果访问的缩略图不存在,则生成后保存,生成的方式见下述。

    • 5 Nginx+lua+graphicsmagick搞定,具体的可以参见我前一篇文章。

    • 6 解决方法跟4,5条一样的。

    ============================================================

    .NET 响应式自动缩略图服务器

     

    做互联网网站,总是会涉及到缩略图问题,之前一直是在上传图片时生成不同尺寸的缩略图,一直感觉又费力又不好管理,之后就写子

    ThumbnailServer 用于部署一个图片服务器,在使用图片时才将图片转为对应的缩略图,类似淘宝图片空间

    比如,物理上存在图片

    /x.jpg 那么访问 

    /x.jpg_60X60.jpg

    /x.jpg_600X600.jpg

    就可以得到它的不同尺寸的缩略图

    ThumbnailServer

    可以支持:

    路径-尺寸白名单

    图片类型白名单

    图片路径白名单

    如下代码:

    ThumbnailConfig.Start().Include("/Images", setting => 
                    setting.AllSize().Store()
                    );

    在Application Start中配置即可

    GitHub: https://github.com/chsword/ThumbnailServer

    另外再推荐一个不错的响应式缩略图服务,功能很强大,按比例缩放、裁剪图片都可以通过Querystring来完成,优点是插件很多,功能强大

    地址:http://imageresizing.net

    /a.jpg

    /a.jpg?w=120

    /a.jpg?w=100&h=200

  • 相关阅读:
    浮点数小数点后开始非零数字的起始位置
    关于接口测试
    性能测试模型之曲线拐点模型
    2018春招实习笔试面试总结(PHP)
    mysql删除表中的记录
    浅析单点登录
    MySQL两种引擎的比较
    Redis初探(windows/linux安装)
    剑指offer试题(PHP篇三)
    剑指offer试题(PHP篇二)
  • 原文地址:https://www.cnblogs.com/qq260250932/p/5314113.html
Copyright © 2011-2022 走看看