自建图床的方案思考以及搭建教程

2024-04-15 18:52

本文主要是介绍自建图床的方案思考以及搭建教程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

现在markdown越来越受欢迎,但是markdown有一个很麻烦而且一直很难解决的问题就是文章中图片资源的处理。


不像word、pdf这种将图片内嵌在文件中,markdown只能引用外部的图片资源,这意味着要么在本地弄一个文件夹专门用来存放图片,通过相对路径引用;要么将图片存放在网上,通过图片链接引用。

如果存放本地以相对路径作为引用的方案,那么传播文档时还要将资源文件进行打包,并且以后想要发表到其他站点,就要考虑如何将这些本地文件转换成网络资源。除非是自用做做笔记,并且是纯本地模式使用,否则这种方案会很麻烦。

所以我个人更倾向于将图片存放在网上引用图片链接的形式,也就是所谓的图床。


但是使用图床也带来了很多的问题。

如果使用免费的图床,以后跑路了怎么办?如果使用GitHub、Gitee这类公共仓库,GitHub的网络稳定性是一个问题,而Gitee后来的审核政策导致图床无法使用也是一个问题。

而使用付费的图床,像是阿里的OSS、腾讯的COS等,万一被刷了,如果没有及时发现,可能一套房就被刷进去了。

图床的易用性也是一个问题,比如使用GitHub当图床,那么就需要在GitHub网页上上传图片,然后点开raw链接,或者在本地提交,然后push到仓库。这在我看来还是稍显麻烦的,不那么优雅。不过还好PC/Mac端有对应的工具,我也没有在移动端写markdown的需求,所以易用性倒是挺容易解决。

所以我思考了一些图床的方案,写下了这篇文章。


当然,我也没有想到一种可以既要又要还要的完美方案,每一种方案都有各自的局限性,只能是根据各种方案的优缺点,以及自身的需求做好取舍,选择一种最适合的方案。

另外,我希望数据是掌握在我自己手中的,所以文中没有列举公共免费图床的方案,这种直接网上一搜就有一大堆,该文章就不赘述了。


好了,废话不多说,接下来我将直接列出各个方案的组合及其优缺点,以供快速参考,不过在这之前先解释一下表格中各个方案的属性表示的含义。

属性解释

成本

就是正常情况下,维持这个图床所需要花的钱。

成本可控

是否会有意外因素,导致成本飙升。比如单OSS方案,可能会被刷流量,导致面临巨额账单。

隐私性

图床中的图片是否全部暴漏在公网中。比如使用GitHub作为图床,图床中的图片几乎是完全暴漏的,不能上传隐私性的图片。

网络稳定性

图片下载的速度。使用国内OSS方案,下载速度比较高,网络稳定性好;而像GitHub图床,由于不可抗力,普通用户无法访问。

是否需要域名

顾名思义,就是是否需要购买一个域名。普通的域名其实很便宜了,需要注意的是购买的时候要注意下续费价格,有些域名可能首年只要几块钱,续费价格很贵。

可迁移性

将一个图床的数据迁移到另一个图床,原来的图片链接是否仍然可访问。

举个例子,我以前使用过Gitee做图床,md文件中直接通过Gitee的域名进行引用,后面政策变更导致无法访问,以前的图片链接全部失效。

如果对可迁移性有要求,那就必须要申请域名,并且做一层路由转发。

举个例子:

原先使用Github作为图床,原图片链接形如:http://raw.github.com/user/repo/b.png

但是实际md中引用的自己的域名:http://img-gh.flycat.tech/user/repo/b.png

使用了反代将 img-gh.flycat.tech转发到 raw.github.com而不是直接访问原链接。

如果以后GitHub政策也变更,那只要将GitHub中的repo整个clone下来,然后上传到oss,再将 img-gh.flycat.tech/user/repo路由到对应的桶就行了,这样原来的图片链接仍然能够访问。

备案要求

是否需要备案。国内备案大概需要1~20天左右,周期会比较长,所以也是一个需要考虑的因素。

方案比较

组合成本成本可控性隐私性网络稳定性是否需要域名可迁移性备案要求
GitHub可控不可迁移
GitHub+域名+Cloudflare可控可迁移
GitHub+域名+Cloudflare+VPS可控可迁移
OSS不可控不可迁移
OSS+域名不可控可迁移
OSS+域名+CDN可控可迁移
OSS+域名+同机房服务器可控可迁移
自建图床可控可迁移

搭建教程地址:https://blog.flycat.tech/archives/1711109931805

这篇关于自建图床的方案思考以及搭建教程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/906643

相关文章

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因

Linux搭建ftp服务器的步骤

《Linux搭建ftp服务器的步骤》本文给大家分享Linux搭建ftp服务器的步骤,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录ftp搭建1:下载vsftpd工具2:下载客户端工具3:进入配置文件目录vsftpd.conf配置文件4:

Java Scanner类解析与实战教程

《JavaScanner类解析与实战教程》JavaScanner类(java.util包)是文本输入解析工具,支持基本类型和字符串读取,基于Readable接口与正则分隔符实现,适用于控制台、文件输... 目录一、核心设计与工作原理1.底层依赖2.解析机制A.核心逻辑基于分隔符(delimiter)和模式匹