SCSI Persistent Reservation Live Migration
This document explains how to live migrate SCSI Persistent Reservations.
The scsi-block device migrates SCSI Persistent Reservations when the
migrate-pr=on parameter is given. Migration is enabled by default in
versioned machine types since QEMU 11.0. It is disabled by default on older
machine types and needs to be explicitly enabled with --device
scsi-block,migrate-pr=on,....
When migration is enabled, QEMU snoops PERSISTENT RESERVATION OUT commands and tracks the reservation key registered by the guest as well as reservations that the guest acquires. This information is migrated along with the guest and the destination QEMU submits a PERSISTENT RESERVATION OUT command with the PREEMPT service action to atomically transfer the reservation to the destination before the guest starts running on the destination.
The following persistent reservation capabilities reported by the PERSISTENT RESERVATION IN command with the REPORT CAPABILITIES service action are masked from the guest by QEMU when migration is enabled:
Specify Initiator Ports Capable (SIP_C)
All Target Ports Capable (ATC_C)
When migration is disabled, the scsi-block device is live migrated but
reservations remain in place on the source. Usually this is not the intended
behavior unless there is another mechanism to update reservations during
migration. The PERSISTENT RESERVATION IN command also does not mask
capabilities reported to the guest when migration is disabled.
Limitations
QEMU does not remember snooped reservation details across restart, so software inside the guest must acquire the reservation after boot in order for live migration to work. Similarly, if the reservation is acquired outside the guest then it will not live migrate along with the guest.
Snooping only considers the PERSISTENT RESERVATION OUT commands from the guest and does not track reservation changes made by other SCSI initiators. QEMU’s snooped reservation details can become stale if another SCSI initiator makes changes to the reservation.
Guests running on the same host share a single SCSI initiator identity unless Fibre Channel N_Port ID Virtualization is configured. As a consequence, multiple guests on the same hosts may observe unexpected behavior if they use the same physical LUN. From the LUN’s perspective all guests are the same initiator and there is no way to distinguish between guests.