博客地址:http://blog.csdn.net/shelleyliu0415
由于SharePoint2013的New Feature-Sharedded Storage的加入,数据存储方式发生了改变,数据是存储在互不相关的一堆Blob(ShreddedStorage)中,每个Blob都会有自己的BSN(BLOB SequenceNumber ). 比方说我们有一个叫做Document.docx的文档, 与此文档关联的存储碎片会分布在一系列的BLOBs. 互不相关的BLOBs每个都被赋予一个独一无二的ID(offset)让文档被请求的时候可以用正确的顺序重新构造文档. 在这些BLOBs中,有些是会被Version所公用的,也就未被修改的BLOBs. (默认情况下平均以64KB为一个数据块进行存储),如下图所示:
那么如果客户按照之前介绍的内容部署了FileStreamProvider,想实现FileStreamProvider的方式管理SharePoint站点里的数据时,默认情况下,无法触发到RBS的配置,将Blob取出来,那么我们该如何实现需求呢?
解决方案:我们可以通过修改RBSProvider的触发条件来实现需求,设置触发条件为1KB,即Blob为1KB的话,就会触发RBS,将Blob取出来,存储到其他的存储介质中,如下所示:
$cdb = Get-SPContentDatabase "WSS_Content"
$cdb.RemoteBlobStorageSettings.MinimumBlobStorageSize = 1024
$cdb.Update()
如下图所示:
验证一下环境信息,FileStreamProvider已经Enable+可用,触发RBS的Rule=1KB,如下图所示:
这样,我们可以上传一个文件,做一下实验Document的Blob是否被存储到自定义的Blob Store里:
通过命令在alldocs表中获取该文件的ID,如下图所示:
根据获取到的ID信息,到docstreams表中查看文件的content和rbs状态,如下图所示:
从图中可以看出Content的值都显示NULL,RBSid有值,说明该文件的Blobs已经全部触发RBS 设置,全部取出。
我们可以到自定义的BlobStore里查看信息,如下图所示:
验证通过,若用户新上传文件的话,对应的Blob会借助Blob Store去存储,如何修改触发RBS的Rule的值以及如何检验是否Blob被取出,SharePoint留有的是Stub,本文也都做了相应的介绍,希望能给大家带来帮助,谢谢阅读!