图床共享云存储

项目背景

        在一些软件的使用场景中,比如阅读软件,我们需要存储大量的数据封面图片、客户的下载书籍等,对于这类情形,可以统一归类为海量小文件的存储问题,在Linux系统中,如果直接进行存储,会导致存储的文件比较分散,影响存储效率。在项目中我们使用Fastdfs来进行文件的上传和下载。

        Fastdfs是一种分布式的文件系统,主要由客户端、跟踪服务器和存储服务器组成,客户端主要负责文件的上传下载和删除等操作,跟踪服务器主要负责任务的调度工作,起到负载均衡的作用,存储服务器主要提供容量和备份服务。

项目介绍

        图床项目是一个可以允许用户上传、下载文件和图片以及分享图片的平台。使用Fastdfs架构存储图片和文件,使用MySQL、redis实现性能的优化。

        客户端登陆web服务器,可以在web界面进行文件和图片的上传下载功能,当有多个客户端进行请求操作时,通过nginx的反向代理功能,将客户端的请求转发给后端服务器,并将后端服务器的请求返回给客户端,分担后端服务器的负载,提高项目的性能,在网络模型部分使用reactor网络模型来处理请求,将处理后的请求封装成任务放入任务队列中,通过线程池来获取任务并执行,通过redis和mysql数据库的联合使用来提升和优化项目的性能,其中数据库中存储文件相关的信息,比如用户名、文件名、文件大小、文件的md5值、文件的url等,根据不同数据库的性质,MySQL作为持久化的数据存储,负责存储所有的业务,处理复杂的业务,以及长期的数据保留,redis作为高速缓存和消息代理,负责高频的读写操作,减轻MySQL的负担,提高系统的响应速度。数据库的连接都使用连接池进行实现,减少了频繁创建销毁连接的开销,redis数据库用来实现某些特定的功能,比如存储用户的token,通过设置过期时间到期销毁token让用户退出登陆,来保证数据的安全,以及使用redis中的有序集合来保存用户下载排量来进行快速排序。

应用技术

reactor网络模型、线程池、连接池、Http API+ Json、MySQL、redis、fastdfs、nginx

项目流程

1:实现reactor网络模型、线程池、连接池

2:使用fastdfs存储文件和图片,结合nginx-upload-module、nginx-fastdfs-modul实现文件的上传下载

3:通过MySQL维护图床用户信息、文件信息、共享文件和图片分享信息,使用索引最左匹配原则优化索引。

4:支持文件秒传功能

5:支持图片分享功能,并使用短链接优化分享长链接的长度

6:使用redis存储共享下载排行榜、用户token、图片分享id对应的实际图片url,缓解MySQL主数据库的读写压力

7:采用wrk+lua压力测试http接口的qps

参考连接

https://xxetb.xetslk.com/s/2fs2Vb

  • 13
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Typora图床搭建阿里云OSS的步骤如下: 1. 首先,登录阿里云账号并打开OSS控制台。 2. 创建一个新的存储空间(bucket),用于存放Typora上传的图片。 3. 在存储空间(bucket)设置中,找到权限管理,确保该存储空间(bucket)的访问权限设置为公共读。 4. 在存储空间(bucket)设置中,找到域名管理,将自定义域名与该存储空间(bucket)关联。 5. 下载并安装PicGo工具,它是一个用于快速上传图片并获取图片URL链接的工具。 6. 打开PicGo工具,配置阿里云OSS作为图床,并输入对应的OSS Access Key ID、Access Key Secret以及Bucket名称等信息。 7. 配置上传路径和命名规则,以便管理和组织上传的图片。 8. 保存配置并测试上传一张图片,确保能够成功上传并生成对应的URL链接。 9. 完成以上步骤后,即可在Typora中使用PicGo工具进行图片上传,将图片存储到阿里云OSS,并获取对应的URL链接,用于在Markdown文档中引用图片。 请注意,配置阿里云OSS时需要提供正确的Access Key ID和Access Key Secret,以确保上传图片的权限和安全性。同时,根据个人需求和隐私保护的考虑,可以选择将图片以相对路径的形式复制到md文件的次级目录同名文件夹下,而不是全部上传到图床。 参考资料: markdown的特性决定了其文字与图片是分离的,图片通过引用的方式添加到md中,本文所讲的是利用阿里云OSS搭建Typora图床,但是并不推荐将所有图片上传图床,推荐将图片以相对路径的形式复制到md文件的次级目录同名文件夹下,有利于隐私保护并且方便图片管理,只有在博客或者需要公开md时选择上传图床阿里云对象存储配置。 以上步骤就是使用图床将typora数据进行上传到网络上,将图片上传到图传上,这样不管文章发给谁,只要他有网络,他就可以进行访问,使用阿里云oss的目的也是为了防止图片进行丢失,效率极高,使用到图床,那就需要用上传图传的工具picgo了,使用起来也是非常方便,但是一定要注意配置,一步一步来,不然熬夜肝,就等于浪费时间。 尤其注意点。 而有了选择好图床之后,那就需要上传图片的工具,而大家常用的工具为:PicGo ,PicGo是一个用于快速上传图片并获取图片URL链接的工具,目前支持微博图床、七牛图床、腾讯云、又拍云、GitHub、阿里云、Imgur等图床购买对象存储oss。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [使用阿里云OSS搭建Typora图床配置](https://blog.csdn.net/qq_29688717/article/details/128740958)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Typora+阿里云oss搭建图床](https://blog.csdn.net/weixin_51253120/article/details/131680678)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值