func (util *ISCSIUtil) DetachDisk(c iscsiDiskCleaner, mntPath string) error { device, cnt, err := mount.GetDeviceNameFromMount(c.mounter, mntPath) if err != nil { glog.Errorf("iscsi detach disk: failed to get device from mnt: %s\nError: %v", mntPath, err) return err } if err = c.mounter.Unmount(mntPath); err != nil { glog.Errorf("iscsi detach disk: failed to unmount: %s\nError: %v", mntPath, err) return err } cnt-- // if device is no longer used, see if need to logout the target if cnt == 0 { // strip -lun- from device path ind := strings.LastIndex(device, "-lun-") prefix := device[:(ind - 1)] refCount, err := getDevicePrefixRefCount(c.mounter, prefix) if err == nil && refCount == 0 { // this portal/iqn are no longer referenced, log out // extract portal and iqn from device path ind1 := strings.LastIndex(device, "-iscsi-") portal := device[(len("/dev/disk/by-path/ip-")):ind1] iqn := device[ind1+len("-iscsi-") : ind] glog.Infof("iscsi: log out target %s iqn %s", portal, iqn) out, err := c.plugin.execCommand("iscsiadm", []string{"-m", "node", "-p", portal, "-T", iqn, "--logout"}) if err != nil { glog.Errorf("iscsi: failed to detach disk Error: %s", string(out)) } } } return nil }
func (util *RBDUtil) DetachDisk(c rbdCleaner, mntPath string) error { device, cnt, err := mount.GetDeviceNameFromMount(c.mounter, mntPath) if err != nil { return fmt.Errorf("rbd detach disk: failed to get device from mnt: %s\nError: %v", mntPath, err) } if err = c.mounter.Unmount(mntPath); err != nil { return fmt.Errorf("rbd detach disk: failed to umount: %s\nError: %v", mntPath, err) } // if device is no longer used, see if can unmap if cnt <= 1 { // rbd unmap _, err = c.plugin.execCommand("rbd", []string{"unmap", device}) if err != nil { return fmt.Errorf("rbd: failed to unmap device %s:Error: %v", device, err) } // load ceph and image/pool info to remove fencing if err := util.loadRBD(c.rbdBuilder, mntPath); err == nil { // remove rbd lock util.defencing(c) } glog.Infof("rbd: successfully unmap device %s", device) } return nil }