Waveter Asked: 2016-02-24 19:03:02 +0800 CST2016-02-24 19:03:02 +0800 CST 2016-02-24 19:03:02 +0800 CST 持久文件句柄、弹性文件句柄和持久文件句柄之间的区别 772 在 CIFS/SMB 协议中,我看到有 3 种类型的文件句柄:持久、弹性和持久。它们之间有什么区别? samba 3 个回答 Voted Best Answer Ward - Reinstate Monica 2016-02-24T23:32:30+08:002016-02-24T23:32:30+08:00 耐用手柄是 SMB 2.0 的一部分 弹性句柄是 SMB 2.1 的一部分 持久句柄是 SMB 2.2 的一部分,现在称为 SMB3 我对以下内容的主要参考是: https://wiki.samba.org/index.php/SMB3_kernel_status 虽然这最初是针对 Samba3 的,但它有更多细节: https://wiki.samba.org/index.php/Samba3/SMB2 持久文件句柄允许与 SMB 服务器的连接在短暂的网络中断中幸存 - 当打开进程终止时,不一定要清理持久句柄。当客户端尝试重新连接时,如果 oplock(/lease) 仍然存在,它会重新连接到文件。 但是如果另一个客户端尝试打开文件,则 oplock/lease 被破坏并且第一个客户端无法重新连接。 即使 oplock/lease 被破坏,弹性文件句柄也会被保留,但坦率地说,我无法了解其工作原理的所有技术细节。下面的参考资料之一说,Durable 和 Resilient 之间的区别在于句柄的创建方式 -通过 create context 调用实现 Durable,而通过 IOCTL 实现 Resilient。 (我无法理解的主要事情是锁定排序和重放如何适应这一点,但看起来这并不是持久性和弹性之间的关键区别。) 对于持久句柄,我想不出比这个 Samba 文档更好的东西: 持久文件句柄类似于具有强大保证的持久文件句柄。使用持久性标志设置为 true 的持久 v2 创建请求 blob 请求它们。服务器仅授予标记为 CA(持续可用)的共享的持久句柄。 据我所知,这些还没有在 Samba 中实现,但目标是支持集群和持续可用性,所以它正在开发中。 Mark Rabinovich 2016-02-25T21:21:51+08:002016-02-25T21:21:51+08:00 有关持久句柄的更多信息...持久句柄可跨同一集群的多个服务器使用。当一台服务器因任何原因宕机时,客户端机器可以半透明地通过与另一台服务器的连接继续使用此句柄。这就是为什么持久句柄(与持久和弹性句柄相反)的实现超出了纯 SMB 范围的原因。例如,我们的 NQ 存储期望持久句柄的完整语义在自定义 VFS 中实现,而 SMB 引擎负责相应的语法。 Shivam Dhanadhya 2019-02-01T21:52:16+08:002019-02-01T21:52:16+08:00 Samba 持久句柄维护文件句柄的状态,即使集群中的其中一台服务器出现故障,新的主服务器也可以获取当前文件句柄并继续 I/O,而不会出现任何 I/O 错误。
我对以下内容的主要参考是:
https://wiki.samba.org/index.php/SMB3_kernel_status
虽然这最初是针对 Samba3 的,但它有更多细节:
https://wiki.samba.org/index.php/Samba3/SMB2
持久文件句柄允许与 SMB 服务器的连接在短暂的网络中断中幸存 - 当打开进程终止时,不一定要清理持久句柄。当客户端尝试重新连接时,如果 oplock(/lease) 仍然存在,它会重新连接到文件。
但是如果另一个客户端尝试打开文件,则 oplock/lease 被破坏并且第一个客户端无法重新连接。
即使 oplock/lease 被破坏,弹性文件句柄也会被保留,但坦率地说,我无法了解其工作原理的所有技术细节。下面的参考资料之一说,Durable 和 Resilient 之间的区别在于句柄的创建方式 -通过 create context 调用实现 Durable,而通过 IOCTL 实现 Resilient。 (我无法理解的主要事情是锁定排序和重放如何适应这一点,但看起来这并不是持久性和弹性之间的关键区别。)
对于持久句柄,我想不出比这个 Samba 文档更好的东西:
据我所知,这些还没有在 Samba 中实现,但目标是支持集群和持续可用性,所以它正在开发中。
有关持久句柄的更多信息...持久句柄可跨同一集群的多个服务器使用。当一台服务器因任何原因宕机时,客户端机器可以半透明地通过与另一台服务器的连接继续使用此句柄。这就是为什么持久句柄(与持久和弹性句柄相反)的实现超出了纯 SMB 范围的原因。例如,我们的 NQ 存储期望持久句柄的完整语义在自定义 VFS 中实现,而 SMB 引擎负责相应的语法。
Samba 持久句柄维护文件句柄的状态,即使集群中的其中一台服务器出现故障,新的主服务器也可以获取当前文件句柄并继续 I/O,而不会出现任何 I/O 错误。