探索中国CIO人才现状 | 第四季调研报告
存储SCSI锁解读:Windows Cluster篇
2013-01-20  作者:存储在线 

  SCSI锁的作用:


  在一个共享存储的环境下,多台前端主机可能会同时访问同一台存储设备,如果此时多台主机在同一时点上对一个LUN进行写操作,那么可想而知这个LUN将不知道哪个数据先写,哪个数据后写。为了防止这种情况发生而导致的数据损坏,所以就有了SCSI锁的概念。通过SCSIReservation机制来进行SCSI锁的操作,目前绝大多数的磁盘都支持‘SCSIreservvation命令‘。如果一台主机给磁盘传输了一条SCSIReservation命令,则这个磁盘对于其他的主机就处于锁定状态。如果有其他的主机给已经被锁定的磁盘发送读写请求,则会收到‘reservationconflict’报错信息。如果保留SCSI锁的主机崩溃,或者其他主机给磁盘发送‘breakreservation或者resettarget命令,用来解除SCSI锁。然后,第二个主机发送I/O请求之前需要重新发送SCSIReservation命令给磁盘。


  SCSI锁的分类:


  SCSI锁有两种类型:SCSI-2Reservation和SCSI-3Reservation。一个LUN上只能存在一种类型的SCSI锁。


  SCSI-2Reservation只允许设备被发出SCSI锁的Initiator访问,也就是主机的HBA。比如主机1上的HBA1对访问的LUN加上SCSI-2锁,此时即使主机1的HBA2也无法访问这个LUN。所以SCSI-2Reservation也被称为SinglePathReservation。


  SCSI-3Reservation(PersistentReservation)是使用PRKey来对磁盘进行加锁。通常一台Host会有唯一的PRKey,不同的主机对应的PRKey也不同。所以一般SCSI-3Reservation通常被应用在多通路的共享环境下面。这里SCSI-3Reservation也称之为PersistentReservation。


  WindowsCluster中的SCSI锁:


  Windows2003集群中使用SCSI-2reserve/release命令。作为非持久的reservation,所以集群中的一台节点会持有SCSI-2Reservation的锁,然后每过3秒会重新刷新一次。如果故障转移发生,则切换节点主机会在相应的磁盘上放置SCSI-2Reservation然后维护SCSI锁。如果所有节点主机上的集群服务都会关闭,Reservation也不会保留。


  Windows2008集群中使用SCSI-3persistentreservation机制。如果磁盘从主机上没有正确移除,集群使用的磁盘(ClusterDisk)会保留着这些Reservation。锁对应的SCSI锁会一直存在于相应的磁盘之上,即使集群服务被关闭或者磁盘对于主机取消掩饰(unmasked)。所以,有些时候需要强行移除磁盘上的Reservation。


  在Windows环境中,移除Reservation移除的命令是(disknumber可以在Windows的DiskManagement中找到)