使用Nginx+Memcached的小图片存储方案

今天整理存储的时候发现80多台服务器上都有一个计划任务,每分钟从管理后台把图片同步至本地。我统计了下使用一年多了只占用很少了空间,图片数量也很少,大小平均在10K左右。

这种情况我觉得再使用上面那种方式来进行同步就有点浪费了,而且还提高了维护成本,虽然计划任务是通过puppet推送下去的。

于是我提出了整改方案,其中一个方案就是使用memcache来存储图片。nginx可以直接从memcahed中取出缓存展示给浏览器,从而提高性能。

memcached是nginx的核心模块,默认是可以直接使用。这个模块只能读,不能写,不过有第三方模块可以做到。

贴出示例:

1) nginx的配置如下:

location ^~ /images/ {
    set $memcached_key  "$uri"; #用URI作为key去memcached中去读取内容
    memcached_pass      127.0.0.1:11211;
    memcached_connect_timeout 5s;
    memcached_read_timeout 5s;
    memcached_send_timeout 5s;
    memcached_buffer_size 32k;
    error_page    404 502 504 = @fallback;
}
location @fallback {
    proxy_pass    ;
}

2) 使用PHP向memcached写入一张图片:
<?php
$pic = file_get_contents('./test.jpg');
$memcache = new Memcache;
$memcache->connect('localhost', 11211);
$memcache->add('/images/test.jpg', $pic, false, 0); //这里设置缓存不过期
$memcache->close();

3) 使用浏览器访问:

上面是单台memcached的示例,在生产环境中可以使用upstream模块调度多个memcached实例来达到高可用。

推荐阅读

CentOS 6.2实战部署Nginx+MySQL+PHP

使用Nginx搭建WEB服务器

Memcached 安装及启动脚本

PHP中使用Memcached的性能问题

Ubuntu下安装Memcached及命令解释

搭建基于Linux6.3+Nginx1.2+PHP5+MySQL5.5的Web服务器全过程

CentOS 6.3下Nginx性能调优

CentOS 6.3下配置Nginx加载ngx_pagespeed模块

CentOS 6.4安装配置Nginx+Pcre+php-fpm

Nginx 的详细介绍请点这里
Nginx 的下载地址请点这里

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/dec59a650b442eda093c6f41e104ecc3.html