1.FastDFS
FastDFS是用c语言编写的一款开源分布式文件存储系统。是用这个框架很容易搭建一套高性能的文件服务器集群提供文件上传下载功能。
FastDFS的架构?
FastDFS 架构包括 Tracker server 和 Storage server。客户端请求 Tracker server 进行文件上传、下载,通过 Tracker server 调度最终由 Storage server 完成文件上传和下载。
Tracker server
作用是负载均衡和调度,通过 Tracker server 在文件上传时可以根据一些策略找到 Storage server 提供文件上传服务。可以将 tracker 称为追踪服务器或调度服务器。
Storage server
作用是文件存储,客户端上传的文件最终存储在 Storage 服务器上, Storageserver 没有实现自己的文件系统而是利用操作系统的文件系统来管理文件。可以将 storage 称为存储服务器。
服务端两个角色:
Tracker:管理集群,tracker 也可以实现集群。每个 tracker 节点地位平等。收集 Storage 集群的状态。
Storage:实际保存文件 Storage 分为多个组,每个组之间保存的文件是不同的。每 个组内部可以有多个成员,组成员内部保存的内容是一样的,组成员的地位是一致的,没有 主从的概念。
2.Nginx
Nginx是一款自由的、开源的、高性能的HTTP服务器和反向代理服务器;同时也是一个IMAP、POP3、SMTP代理服务器;Nginx可以作为一个HTTP服务器进行网站的发布处理,另外Nginx可以作为反向代理进行负载均衡的实现。
3.Django项目中上传和使用图片的流程
- 浏览器通过admin页面上传图片(原本Django是把图片保存在Django所在的服务器的MEDIA_ROOT路径下),Django把文件上传到fastdfs服务器上,服务器给django返回文件id,django保存在对应的表中。
- 浏览器访问html页面,django渲染页面(<img src="http:10.211.55.8:22122:80/文件id">)并返回渲染后的页面
- 浏览器解析页面上的图片链接,并访问FastDFS系统上的Nginx获取图片,nginx返回图片,并在浏览器上面显示。
4.使用FastDFS+Nginx的原因
为了解决高并发的问题,故建立分布式存储系统,使用Nginx作为代理服务器(因为Nginx常用作静态内容服务和代理服务器,直面外来的请求转发给django)
优点1:可以实现海量存储
优点2:存储容量扩展方便
优点3:解决文件重复问题
优点4:结合nginx提高网站提供图片的效率
5.在ubuntu上配置FastDFS+Nginx
参考链接:
https://blog.csdn.net/xiaoxie762457/article/details/80690841
6.在Django中使用FastDFS的配置
6.1 自定义文件存储类+改进
//settings
//utils.fdfs.storage
//client.conf
一些操作
数据存放在/home/fastdfs/
下
查看fastdfs服务器是否启动ps -ef | grep fdfs
监视 fdfs_monitor /etc/fdfs/client.conf