视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
奥克斯空调压缩机不启动 tcl空调显示e6 空调e6怎么解决 澳柯玛空调压缩机不启动 美的空调怎么加氟 空调显示e6不制冷 志高空调压缩机不启动 志高空调怎么加氟 中央空调显示e6是什么意思 春兰空调故障代码e2 新手学习MySQL外键所要知道的知识 新手SQLServer数据库dba需要注意的小细节 格力空调怎么加氟 怎么加空调氟 空调除湿原理是啥 松下空调怎么加氟 春兰空调故障代码e4 空调一小时几度电 格力空调加氟方法 LG空调怎么加氟 浏览器AdobeFlashPlayer插件去除沙箱(保护模式)特性增强稳定 新手学堂最常用Oracle命令集锦 新手知识选择正确的MySQL安装包 新手学堂MySQL数据库多表删除方法 新手学堂Linux下Oracle的自动启动及停止 新手进阶查看MySQL表结构命令 新手进阶Python连接MySQL代码 格力中央空调故障代码e1 大金中央空调内机漏水 新手使用PL/SQLDeveloper面临的问题 志高空调压缩机不工作 中央空调内机漏水 格力空调e6怎么办 格力空调故障代码e6是什么问题 格力空调故障代码e6代表什么故障 格力空调故障代码f0 惠康空调内机漏水 澳柯玛空调压缩机不工作 奥克斯空调压缩机不工作 格力空调故障代码e5怎么办
山寨技术下的网站图片服务器(NGINX)
2020-11-09 13:32:24 责编:小采
文档

网站数据存储需要做好前期的规划,不然数据量上来以后无论是管理还是性能上都带来很多问题,对于需要存储大量文件、图片的网站来说是个重点的话题,通常网页文字内容和网页图片内容 所占用的存储空间相比较的话,显然是图片存储占用的空间要远远超过网站文字

网站数据存储需要做好前期的规划,不然数据量上来以后无论是管理还是性能上都带来很多问题,对于需要存储大量文件、图片的网站来说是个重点的话题,通常网页文字内容和网页图片内容 所占用的存储空间相比较的话,显然是图片存储占用的空间要远远超过网站文字内容所需要存储的空间,从另外一个角度上来看访问图片所占用的网络带宽要远远超过文字内容所占用的带宽。
在系统运行上的瓶颈对于互联网用户来说往往不是落在系统内部计算的I/O瓶颈上,而是落在网络带宽的瓶颈上。把存储图片的服务器和访问图片服务器的网络入口独立出来,在条件允许的情况下给予更的高网络带宽和独立的域名,有利于扩展性和整体性能的发挥,将计算、存储的扩展性和带宽的资源做到合理分配,互不影响,是我们当前的目标。

除此之外,还需要能做到:
1.使用廉价机器(老机器)构建分布式网络存储环境,支持150TB以上的存储容量,
2.数据在线同步,支持文件副本复制,无明显的单点问题,可快速恢复故障节点,
3.通用文件系统,不需要修改上层应用就可以使用(支持fuse),web服务器可以直接读取分布式存储空间,无中间转取。
4.支持在线不停机的情况下扩展存储的空间,
5.随机读写的高效,并且支持海量小文件(5kb)的高效读写,
6.可监控运行时的存储使用状态,最好是web界面。

得到了一些个解决方案,但依然不满足,对存储本身还有更高的期望:
1.需要避免图片文件重复的写入,建立图片存储的索引,根据唯一的图片文件名的查询后,再判断是否写入,
2.小图片,签名照,小头像,表情图片 放在缓存里读取,让数据更靠近cpu,设计的黄金原则,我们尽量把能放入Redis缓存中的数据就在Redis里读取。

架构介绍
1.负载均衡:HAproxy采用RoundRobin负载均衡算法,分载前端用户请求的压力到每个web图片服务器上,
2.web服务:采用Nginx-0.9.6 做图片的web服务器,对网站的大、中、小图片进行读取,加上Nginx的Redis模块对缓存中的微型(头像)图片进行读取,
3. 缓存服务器:存储网站的 微型图片,签名照,小头像,表情图片,通过Nginx的Redis模块直接读取,通过调用Redis的java API程序对数据进行写入,
4.存储单元:采用Moosefs 存储 大、中、小图片,并且提供监控管理界面,查看存储空间运行状态,
5.图片索引:将图片名和图片url路径作为键值对(Key/Value),放入HBase 中存储,并且进行数据查询,避免图片重复存储,便于将来管理,
6.应用服务器:对图片写入的操作全部由Java应用服务器完成。

我们目前图片存储的系统架构,如图所示:

查看大图请点击这里

关于HBase的话题在这里就不多说了,可以参考我之前写的几篇文件文章,主要想说说Moosefs的体系:
1 Master 管理服务器:负责各个数据存储服务器的管理,文件读写调度,文件空间回收以及恢复.多节点拷贝
2 Chunk 元数据日志服务器: 负责备份master服务器的变化日志文件,文件类型为changelog_ml.*.mfs,以便于在master server出问题的时候接替其进行工作
3 Metalogger 数据存储服务器:负责连接管理服务器,听从管理服务器调度,提供存储空间,并为客户提供数据传输.
4 Client 客户端: 通过fuse内核接口挂接远程管理服务器上所管理的数据存储服务器,看起来共享的文件系统和本地unix文件系统使用一样的效果.

最有代表性的成功案例
豆瓣网(Douban Inc),155 TB的存储空间,
Master server: Gentoo Linux / ReiserFS 3.6
24 chunk servers: Gentoo Linux / ReiserFS / XFS
3 metalogger(s): Gentoo Linux / ReiserFS 3.6
37 client machines: Gentoo Linux

其实,采用某种技术只是一种具体实现的手段,或许从外界的统计数据来看 mogileFS、ceph、FastDFS 等其他产品具有更高的读写性能,甚至可以到满足我上述的任何一项要求,但我们所关注的侧重点不一样,要需要简单,易上手,够用就行,所以在这里利用Moosefs做了一个抛砖引玉。

–end–

下载本文
显示全文
专题奥克斯空调压缩机不启动奥克斯空调压缩机不启动专题tcl空调显示e6tcl空调显示e6专题空调e6怎么解决空调e6怎么解决专题澳柯玛空调压缩机不启动澳柯玛空调压缩机不启动专题美的空调怎么加氟美的空调怎么加氟专题空调显示e6不制冷空调显示e6不制冷专题志高空调压缩机不启动志高空调压缩机不启动专题志高空调怎么加氟志高空调怎么加氟专题中央空调显示e6是什么意思中央空调显示e6是什么意思专题春兰空调故障代码e2春兰空调故障代码e2专题格力空调怎么加氟格力空调怎么加氟专题怎么加空调氟怎么加空调氟专题空调除湿原理是啥空调除湿原理是啥专题松下空调怎么加氟松下空调怎么加氟专题春兰空调故障代码e4春兰空调故障代码e4专题空调一小时几度电空调一小时几度电专题格力空调加氟方法格力空调加氟方法专题LG空调怎么加氟LG空调怎么加氟专题格兰仕空调故障代码e4格兰仕空调故障代码e4专题空调一小时用多少电空调一小时用多少电专题日立空调怎么加氟日立空调怎么加氟专题格兰仕空调故障代码cf格兰仕空调故障代码cf专题空调每小时耗电量空调每小时耗电量专题海信空调怎么加氟海信空调怎么加氟专题空调一个小时几度电空调一个小时几度电专题海尔空调怎么加氟海尔空调怎么加氟专题富士通空调怎么加氟富士通空调怎么加氟专题空调一晚上几度电空调一晚上几度电专题格兰仕空调e7故障代码格兰仕空调e7故障代码专题格兰仕空调怎么加氟格兰仕空调怎么加氟专题nginx性能监控工具专题nginx配置虚拟域名专题nginx基于域名的虚拟主机专题nginx多个虚拟主机专题nginx 默认虚拟主机专题nginx配置多域名专题okhttp dns专题nginx配置域名https专题nginx配置https域名专题自己搭建ngrok服务器专题nginx 虚拟ip专题nginx配置域名转发专题nginx 应用专题ngrok.com专题nginx 网页不更新专题访问虚拟机web服务专题nginx发布静态资源专题nginxcache搭建cdn专题nginx 配置ipv6专题nginx dns专题