1

我的 Dropbox 文件夹中有我的项目文件,所以我也可以在办公室玩弄我的文件。

我的项目包含一个EmbeddableDocumentStorewithUseEmbeddedHttpServer设置为true.

const int ravenPort = 8181;
NonAdminHttp.EnsureCanListenToWhenInNonAdminContext(ravenPort);
var ds = new EmbeddableDocumentStore { 
    DataDirectory = "Data", 
    UseEmbeddedHttpServer = true, 
    Configuration = { Port = ravenPort } 
};

现在,当我在办公室电脑上开始我的项目时,我看到了这条消息:Could not open transactional storage: D:\Dropbox\...\Data

由于它处于我开发阶段的早期,我删除了我的 Dropbox 上的数据文件夹,项目完美地开始了。现在我回到家我遇到了同样的问题!我当然不想每次都删除这个文件夹。

我不能将我的开发数据存储在我的 Dropbox 上吗?我应该绕过一些东西来让它工作吗?

4

1 回答 1

4

将数据目录设置为本地计算机上的物理磁盘卷。您将无法使用任何类型的映射驱动器、网络共享、UNC 路径、保管箱或 skydrive 作为数据目录。仅仅因为你有一个驱动器号并不意味着你有一个物理磁盘。

唯一有意义的非物理存储类型是通过 iSCSI 或 FibreChannel 从 SAN 连接的 LUN,或者在虚拟化或云环境中连接的 VHD。它们都将作为物理磁盘呈现给操作系统。

几乎任何数据访问环境都是如此。如果您不相信我,请尝试使用 SQL Server。在 RavenDB 的案例中,它使用 ESENT 作为其数据存储,这需要直接访问文件系统。

更新

澄清一下,即使您存储在物理磁盘上,也不能依赖任何类型的同步技术,例如 DropBox 或 SkyDrive。为什么?因为他们将对文件进行共享读取锁定以监视更改。像 ESENT(RavenDB 所基于)这样的技术需要对文件进行排他锁

SQL Server 和 Windows 虚拟机等其他技术也在其数据存储上采用排他锁。为什么?因为它们以随机访问的方式不断地读写数据位到文件中。您真的希望 DropBox 尝试对每一位数据更改执行同步操作吗?这将是非常低效和有问题的。

使用共享锁的应用程序没有这个问题。例如,当您处理 MS Word 文档时,这一切都是在内存中完成的。当您保存文件时,DropBox 可以读取整个文件并将其同步到云端。它可以通过仅发送已更改的位来进行优化,但它仍然需要能够读取文件才能这样做。

因此,如果 DropBox 对 ESENT 文件具有共享读锁,那么当 RavenDB 尝试以独占方式打开它时,它会出现错误并引发您所看到的异常。

于 2013-01-15T22:27:05.013 回答