TA的每日心情 | 衰 2021-2-2 11:21 |
---|
签到天数: 36 天 [LV.5]常住居民I
|
今天整理存储的时候发现80多台服务器上都有一个计划任务,每分钟从管理后台把图片同步至本地。我统计了下使用一年多了只占用很少了空间,图片数量也很少,大小平均在10K左右。
2 e1 F' e2 f9 g4 ^8 V这种情况我觉得再使用上面那种方式来进行同步就有点浪费了,而且还提高了维护成本,虽然计划任务是通过puppet推送下去的。
+ S6 y* N `& Y! a9 U于是我提出了整改方案,其中一个方案就是使用memcache来存储图片。nginx可以直接从memcahed中取出缓存展示给浏览器,从而提高性能。
4 P( K4 f1 U V( \memcached是nginx的核心模块,默认是可以直接使用。这个模块只能读,不能写,不过有第三方模块可以做到。
! O" J% h) y$ X$ W贴出示例:# b% E' u* _% d+ _- _; Z3 A& }
1) nginx的配置如下:! v1 j y+ Y8 H t/ z$ u/ e. |
- location ^~ /images/ {
0 Y& Q) I4 P/ ]* Q* z7 |$ H' i - set $memcached_key "$uri"; #用URI作为key去memcached中去读取内容 6 A# a! I3 i8 H& e e
- memcached_pass 127.0.0.1:11211;
7 r% j+ i& u* I - memcached_connect_timeout 5s; * ^# J* u2 b5 W& R
- memcached_read_timeout 5s;
, u! [# M# C, n9 l' P6 u: Z - memcached_send_timeout 5s; 5 ^8 o3 B- D+ [, M
- memcached_buffer_size 32k; 9 X) y3 u( b: L/ c" F, x
- error_page 404 502 504 = @fallback;
3 g+ q; h, I" y0 u - }
8 d0 W3 D0 o" J. E4 Q6 w" b, [ - location @fallback {
2 ? ^5 ?% g0 H$ a- u - proxy_pass http://backend;
; } G3 y4 J2 p9 `+ Z# p w) b - }
复制代码 : g6 n: ?* Q, O% \. X: X
2) 使用PHP向memcached写入一张图片:
+ ]; i9 [$ ]5 T: w4 ^5 ?- <?php 2 G3 o9 d% `2 L, M( h# |' l% R
- $pic = file_get_contents('./test.jpg'); 7 A# E* v9 ~+ l
- $memcache = new Memcache;
V8 E- `# b: ^* l; R6 }, Y$ r - $memcache->connect('localhost', 11211);
' E- v- U/ Z& ?4 ^! E# N - $memcache->add('/images/test.jpg', $pic, false, 0); //这里设置缓存不过期
f0 B& @, ?4 q - $memcache->close();
复制代码 , x5 z6 q' l2 |0 j/ _% d
3) 使用浏览器访问:http://localhost/images/test.jpg @2 C# i9 f7 U0 A6 n' I4 k: ^
上面是单台memcached的示例,在生产环境中可以使用upstream模块调度多个memcached实例来达到高可用。8 L' o5 |3 f* D8 ]
% b9 m+ L7 _5 [& ]- p& t- W$ t! ?& \6 q8 N( \
|
|