Discourse 对上传服务器托管网的附件会进行清理,对于一些没有任何被引用的附件,Discourse 会认为是垃圾而清理掉。
原因应该是为了降低存储空间的使用,但是我们目前使用的是 S3 ,所以对存储空间并没有太多的要求。
根据官方的说法,如果满足下面的条件的上传附件将会被清理掉:
https://github.com/discourse/discourse/blob/master/app/jobs/scheduled/clean_up_uploads.rb
TL;DR: an image is orphaned if and only if it’s not referenced
- in the latest version of a post
- in a draft
- in a queued post
- in a logo site setting
- in a custom emoji
- in a theme
- in a user avatar/background/card image
- in a cat服务器托管网egory logo/background image
官方的讨论地址为:How to make an image orphaned so that it gets removed? – support – Discourse Meta
通过代码,我们会看到,Discourse 使用了一个查询来判断附件是否被引用。
这个表是:upload_references
如果附件没有被关联到主题中,这个附件就会被认为是没有关联的附件而被清理掉。
根据我们备份恢复的情况来看,我们估计可能是这个表 upload_references 丢数据了,导致 uploads 中标的数据被清理掉了。
本地查询
我们本地查询了下操作前 3 天的记录。
发现这个表中有:9000 多条记录。
服务器查询
同时,我们对服务器上的表进行了查询。
查询结果返回的是:6000 多。
很明显这里有差距,那肯定是在恢复的过程中可能丢数据了。
我们需要做的就是把本地表中的数据恢复到服务器上。
运行 SQL:select count(*) from upload_references;
来查看下服务器上的记录,貌似服务器上的参考引用全部被恢复了。
因为我们禁用了自动清理程序,所以我们现在应该可以把自动清理进程打开了。
服务器托管,北京服务器托管,服务器租用 http://www.fwqtg.net
机房租用,北京机房租用,IDC机房托管, http://www.fwqtg.net
相关推荐: 这个字段我明明传了呀,为什么收不到 – Spring 中首字母小写,第二个字母大写造成的参数问题
问题现象 vSwitchId、uShape、iPhone… 这类字段名,有什么特点?很容易看出来吧,首字母小写,第二个字母大写。它们看起来确实是符合 Java 中对字段所推崇的“小驼峰命名法”,即第一个单词小写,后面的单词首字母大写。但是,如果你在项目中给…