components/openstack/cinder/files/solaris/zfs.py
author Qiang Strony Zhang <strony.zhang@oracle.com>
Thu, 12 Nov 2015 14:54:11 -0800
changeset 5087 e31e1e575df4
parent 4983 db2589571faa
child 5112 8ba7598c0426
permissions -rw-r--r--
22031461 volume attachment failed
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
     1
# vim: tabstop=4 shiftwidth=4 softtabstop=4
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
     2
# Copyright (c) 2012 OpenStack LLC.
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
     3
# All Rights Reserved.
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
     4
#
3998
5bd484384122 PSARC 2015/110 OpenStack service updates for Juno
Danek Duvall <danek.duvall@oracle.com>
parents: 2162
diff changeset
     5
# Copyright (c) 2014, 2015, Oracle and/or its affiliates. All rights reserved.
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
     6
#
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
     7
#    Licensed under the Apache License, Version 2.0 (the "License"); you may
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
     8
#    not use this file except in compliance with the License. You may obtain
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
     9
#    a copy of the License at
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    10
#
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    11
#         http://www.apache.org/licenses/LICENSE-2.0
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    12
#
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    13
#    Unless required by applicable law or agreed to in writing, software
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    14
#    distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    15
#    WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    16
#    License for the specific language governing permissions and limitations
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    17
#    under the License.
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    18
"""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    19
Drivers for Solaris ZFS operations in local and iSCSI modes
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    20
"""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    21
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    22
import abc
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    23
import fcntl
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    24
import os
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    25
import socket
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    26
import subprocess
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
    27
import time
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    28
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    29
from oslo.config import cfg
4983
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
    30
import paramiko
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    31
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    32
from cinder import exception
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    33
from cinder.i18n import _
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    34
from cinder.image import image_utils
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    35
from cinder.openstack.common import log as logging
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
    36
from cinder.openstack.common import processutils
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    37
from cinder.volume import driver
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    38
from cinder.volume.drivers.san.san import SanDriver
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    39
1912
b0c17ef05b75 18658040 zfs.py can't handle terabyte pools
Strony <strony.zhang@oracle.com>
parents: 1760
diff changeset
    40
from solaris_install.target.size import Size
b0c17ef05b75 18658040 zfs.py can't handle terabyte pools
Strony <strony.zhang@oracle.com>
parents: 1760
diff changeset
    41
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
    42
FLAGS = cfg.CONF
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    43
LOG = logging.getLogger(__name__)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    44
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    45
solaris_zfs_opts = [
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    46
    cfg.StrOpt('zfs_volume_base',
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    47
               default='rpool/cinder',
5087
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
    48
               help='The base dataset for ZFS volumes.'),
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
    49
    cfg.StrOpt('zfs_target_group',
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
    50
               default='tgt-grp',
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
    51
               help='iSCSI target group name.'), ]
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    52
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    53
FLAGS.register_opts(solaris_zfs_opts)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    54
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    55
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    56
class ZFSVolumeDriver(SanDriver):
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    57
    """Local ZFS volume operations."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    58
    protocol = 'local'
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    59
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    60
    def __init__(self, *args, **kwargs):
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    61
        super(ZFSVolumeDriver, self).__init__(execute=self.solaris_execute,
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    62
                                              *args, **kwargs)
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    63
        self.configuration.append_config_values(solaris_zfs_opts)
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    64
        self.run_local = self.configuration.san_is_local
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    65
        self.hostname = socket.gethostname()
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    66
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    67
    def solaris_execute(self, *cmd, **kwargs):
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    68
        """Execute the command locally or remotely."""
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    69
        if self.run_local:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    70
            return processutils.execute(*cmd, **kwargs)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    71
        else:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    72
            return super(ZFSVolumeDriver, self)._run_ssh(cmd,
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    73
                                                         check_exit_code=True)
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    74
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    75
    def check_for_setup_error(self):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    76
        """Check the setup error."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    77
        pass
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    78
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    79
    def create_volume(self, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    80
        """Create a volume."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    81
        size = '%sG' % volume['size']
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    82
        zfs_volume = self._get_zfs_volume_name(volume['name'])
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    83
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    84
        # Create a ZFS volume
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    85
        cmd = ['/usr/sbin/zfs', 'create', '-V', size, zfs_volume]
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    86
        self._execute(*cmd)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    87
        LOG.debug(_("Created ZFS volume '%s'") % volume['name'])
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    88
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    89
    def create_volume_from_snapshot(self, volume, snapshot):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    90
        """Create a cloned volume from a snapshot."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    91
        if volume['size'] != snapshot['volume_size']:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    92
            exception_message = (_("Could not create volume '%s' because "
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    93
                                   "its volume size of '%s' is different "
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    94
                                   "from that of the snapshot, '%s'.")
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    95
                                 % (volume['name'], volume['size'],
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    96
                                    snapshot['volume_size']))
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
    97
            raise exception.InvalidInput(reason=exception_message)
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    98
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    99
        # Create a ZFS clone
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   100
        zfs_snapshot = self._get_zfs_snap_name(snapshot)
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   101
        zfs_volume = self._get_zfs_volume_name(volume['name'])
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   102
        cmd = ['/usr/sbin/zfs', 'clone', zfs_snapshot, zfs_volume]
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   103
        self._execute(*cmd)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   104
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   105
        LOG.debug(_("Created cloned volume '%s'") % volume['name'])
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   106
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   107
    def create_cloned_volume(self, volume, src_vref):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   108
        """Create a clone of the specified volume."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   109
        if volume['size'] != src_vref['size']:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   110
            exception_message = (_("Could not clone volume '%s' because "
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   111
                                   "its volume size of '%s' is different "
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   112
                                   "from that of the source volume, '%s'.")
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   113
                                 % (volume['name'], volume['size'],
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   114
                                    src_vref['size']))
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   115
            raise exception.VolumeBackendAPIException(data=exception_message)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   116
4983
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   117
        self._zfs_send_recv(src_vref,
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   118
                            self._get_zfs_volume_name(volume['name']))
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   119
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   120
        LOG.debug(_("Created cloned volume '%s' from source volume '%s'")
4983
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   121
                  % (volume['name'], src_vref['name']))
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   122
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   123
    def delete_volume(self, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   124
        """Delete a volume.
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   125
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   126
        Firstly, the volume should be checked if it is a cloned one. If yes,
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   127
        its parent snapshot with prefix 'tmp-snapshot-' should be deleted as
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   128
        well after it is removed.
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   129
        """
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   130
        zvol = self._get_zvol_path(volume)
3998
5bd484384122 PSARC 2015/110 OpenStack service updates for Juno
Danek Duvall <danek.duvall@oracle.com>
parents: 2162
diff changeset
   131
        try:
5bd484384122 PSARC 2015/110 OpenStack service updates for Juno
Danek Duvall <danek.duvall@oracle.com>
parents: 2162
diff changeset
   132
            (out, _err) = self._execute('/usr/bin/ls', zvol)
5bd484384122 PSARC 2015/110 OpenStack service updates for Juno
Danek Duvall <danek.duvall@oracle.com>
parents: 2162
diff changeset
   133
        except processutils.ProcessExecutionError:
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   134
            LOG.debug(_("The volume path '%s' doesn't exist") % zvol)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   135
            return
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   136
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   137
        zfs_volume = self._get_zfs_volume_name(volume['name'])
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   138
        origin_snapshot = self._get_zfs_property('origin', zfs_volume)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   139
        tmp_cloned_vol = False
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   140
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   141
        # Check if it is the temporary snapshot created for the cloned volume
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   142
        if origin_snapshot.startswith(self.configuration.zfs_volume_base):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   143
            prop_type = self._get_zfs_property('type', origin_snapshot)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   144
            tmp_snap_prefix = 'tmp-snapshot-%s' % volume['id']
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   145
            if prop_type == 'snapshot' and tmp_snap_prefix in origin_snapshot:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   146
                tmp_cloned_vol = True
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   147
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   148
        cmd = ['/usr/sbin/zfs', 'destroy', zfs_volume]
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   149
        self._execute(*cmd)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   150
        LOG.debug(_("Deleted volume '%s'") % volume['name'])
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   151
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   152
        if tmp_cloned_vol:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   153
            self._execute('/usr/sbin/zfs', 'destroy', origin_snapshot)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   154
            LOG.debug(_("Deleted parent snapshot '%s' of volume '%s'")
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   155
                      % (origin_snapshot, volume['name']))
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   156
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   157
    def create_snapshot(self, snapshot):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   158
        """Create a snapshot."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   159
        cmd = ['/usr/sbin/zfs', 'snapshot', self._get_zfs_snap_name(snapshot)]
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   160
        self._execute(*cmd)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   161
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   162
        LOG.debug(_("Created snapshot '%s'") % snapshot['name'])
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   163
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   164
    def delete_snapshot(self, snapshot):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   165
        """Delete a snapshot."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   166
        cmd = ['/usr/sbin/zfs', 'destroy', self._get_zfs_snap_name(snapshot)]
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   167
        self._execute(*cmd)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   168
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   169
        LOG.debug(_("Deleted snapshot '%s'") % snapshot['name'])
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   170
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   171
    def ensure_export(self, context, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   172
        """Synchronously recreate an export for a logical volume."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   173
        pass
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   174
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   175
    def create_export(self, context, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   176
        """Export the volume."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   177
        pass
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   178
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   179
    def remove_export(self, context, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   180
        """Remove an export for a volume."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   181
        pass
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   182
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   183
    def initialize_connection(self, volume, connector):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   184
        """Initialize the connection and returns connection info."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   185
        volume_path = '%s/volume-%s' % (self.configuration.zfs_volume_base,
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   186
                                        volume['id'])
3998
5bd484384122 PSARC 2015/110 OpenStack service updates for Juno
Danek Duvall <danek.duvall@oracle.com>
parents: 2162
diff changeset
   187
        properties = {}
5bd484384122 PSARC 2015/110 OpenStack service updates for Juno
Danek Duvall <danek.duvall@oracle.com>
parents: 2162
diff changeset
   188
        properties['device_path'] = self._get_zvol_path(volume)
5bd484384122 PSARC 2015/110 OpenStack service updates for Juno
Danek Duvall <danek.duvall@oracle.com>
parents: 2162
diff changeset
   189
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   190
        return {
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   191
            'driver_volume_type': 'local',
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   192
            'volume_path': volume_path,
3998
5bd484384122 PSARC 2015/110 OpenStack service updates for Juno
Danek Duvall <danek.duvall@oracle.com>
parents: 2162
diff changeset
   193
            'data': properties
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   194
        }
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   195
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   196
    def terminate_connection(self, volume, connector, **kwargs):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   197
        """Disconnection from the connector."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   198
        pass
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   199
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   200
    def attach_volume(self, context, volume, instance_uuid, host_name,
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   201
                      mountpoint):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   202
        """Callback for volume attached to instance or host."""
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   203
        pass
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   204
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   205
    def detach_volume(self, context, volume):
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   206
        """ Callback for volume detached."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   207
        pass
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   208
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   209
    def get_volume_stats(self, refresh=False):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   210
        """Get volume status."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   211
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   212
        if refresh:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   213
            self._update_volume_stats()
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   214
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   215
        return self._stats
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   216
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   217
    def copy_image_to_volume(self, context, volume, image_service, image_id):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   218
        """Fetch the image from image_service and write it to the volume."""
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   219
        raise NotImplementedError()
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   220
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   221
    def copy_volume_to_image(self, context, volume, image_service, image_meta):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   222
        """Copy the volume to the specified image."""
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   223
        raise NotImplementedError()
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   224
1912
b0c17ef05b75 18658040 zfs.py can't handle terabyte pools
Strony <strony.zhang@oracle.com>
parents: 1760
diff changeset
   225
    def _get_zfs_property(self, prop, dataset):
b0c17ef05b75 18658040 zfs.py can't handle terabyte pools
Strony <strony.zhang@oracle.com>
parents: 1760
diff changeset
   226
        """Get the value of property for the dataset."""
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   227
        try:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   228
            (out, _err) = self._execute('/usr/sbin/zfs', 'get', '-H', '-o',
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   229
                                        'value', prop, dataset)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   230
            return out.rstrip()
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   231
        except processutils.ProcessExecutionError:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   232
            LOG.info(_("Failed to get the property '%s' of the dataset '%s'") %
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   233
                     (prop, dataset))
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   234
            return None
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   235
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   236
    def _get_zfs_snap_name(self, snapshot):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   237
        """Get the snapshot path."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   238
        return "%s/%s@%s" % (self.configuration.zfs_volume_base,
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   239
                             snapshot['volume_name'], snapshot['name'])
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   240
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   241
    def _get_zfs_volume_name(self, volume_name):
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   242
        """Add the pool name to get the ZFS volume."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   243
        return "%s/%s" % (self.configuration.zfs_volume_base,
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   244
                          volume_name)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   245
4983
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   246
    def _remote_piped_execute(self, cmd1, cmd2, ip, username, password):
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   247
        """Piped execute on a remote host."""
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   248
        LOG.debug(_("Piping cmd1='%s' into cmd='%s' on host '%s'") %
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   249
                  (' '.join(cmd1), ' '.join(cmd2), ip))
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   250
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   251
        client = paramiko.SSHClient()
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   252
        client.set_missing_host_key_policy(paramiko.AutoAddPolicy())
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   253
        client.connect(ip, username=username, password=password)
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   254
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   255
        cmd = ' '.join(cmd1) + '|' + ' '.join(cmd2)
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   256
        stdin, stdout, stderr = client.exec_command(cmd)
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   257
        channel = stdout.channel
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   258
        exit_status = channel.recv_exit_status()
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   259
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   260
        if exit_status != 0:
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   261
            LOG.error(_("_remote_piped_execute: failed to host '%s' with "
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   262
                        "stdout '%s' and stderr '%s'")
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   263
                      % (ip, stdout.read(), stderr.read()))
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   264
            msg = (_("Remote piped execution failed to host '%s'.") % ip)
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   265
            raise exception.VolumeBackendAPIException(data=msg)
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   266
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   267
    def _piped_execute(self, cmd1, cmd2):
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   268
        """Pipe output of cmd1 into cmd2."""
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   269
        LOG.debug(_("Piping cmd1='%s' into cmd2='%s'") %
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   270
                  (' '.join(cmd1), ' '.join(cmd2)))
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   271
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   272
        try:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   273
            p1 = subprocess.Popen(cmd1, stdout=subprocess.PIPE,
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   274
                                  stderr=subprocess.PIPE)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   275
        except:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   276
            LOG.error(_("_piped_execute '%s' failed.") % (cmd1))
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   277
            raise
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   278
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   279
        # Set the pipe to be blocking because evenlet.green.subprocess uses
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   280
        # the non-blocking pipe.
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   281
        flags = fcntl.fcntl(p1.stdout, fcntl.F_GETFL) & (~os.O_NONBLOCK)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   282
        fcntl.fcntl(p1.stdout, fcntl.F_SETFL, flags)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   283
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   284
        p2 = subprocess.Popen(cmd2, stdin=p1.stdout,
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   285
                              stdout=subprocess.PIPE,
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   286
                              stderr=subprocess.PIPE)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   287
        p1.stdout.close()
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   288
        stdout, stderr = p2.communicate()
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   289
        if p2.returncode:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   290
            msg = (_("_piped_execute failed with the info '%s' and '%s'.") %
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   291
                   (stdout, stderr))
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   292
            raise exception.VolumeBackendAPIException(data=msg)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   293
4983
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   294
    def _zfs_send_recv(self, src, dst):
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   295
        """Replicate the ZFS dataset by calling zfs send/recv cmd"""
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   296
        src_snapshot = {'volume_name': src['name'],
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   297
                        'name': 'tmp-snapshot-%s' % src['id']}
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   298
        src_snapshot_name = self._get_zfs_snap_name(src_snapshot)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   299
        prop_type = self._get_zfs_property('type', src_snapshot_name)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   300
        # Delete the temporary snapshot if it already exists
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   301
        if prop_type == 'snapshot':
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   302
            self.delete_snapshot(src_snapshot)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   303
        # Create a temporary snapshot of volume
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   304
        self.create_snapshot(src_snapshot)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   305
        src_snapshot_name = self._get_zfs_snap_name(src_snapshot)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   306
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   307
        cmd1 = ['/usr/sbin/zfs', 'send', src_snapshot_name]
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   308
        cmd2 = ['/usr/sbin/zfs', 'receive', dst]
4983
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   309
        # Due to pipe injection protection in the ssh utils method,
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   310
        # cinder.utils.check_ssh_injection(), the piped commands must be passed
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   311
        # through via paramiko.  These commands take no user defined input
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   312
        # other than the names of the zfs datasets which are already protected
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   313
        # against the special characters of concern.
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   314
        if not self.run_local:
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   315
            ip = self.configuration.san_ip
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   316
            username = self.configuration.san_login
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   317
            password = self.configuration.san_password
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   318
            self._remote_piped_execute(cmd1, cmd2, ip, username, password)
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   319
        else:
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   320
            self._piped_execute(cmd1, cmd2)
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   321
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   322
        # Delete the temporary src snapshot and dst snapshot
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   323
        self.delete_snapshot(src_snapshot)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   324
        dst_snapshot_name = "%s@tmp-snapshot-%s" % (dst, src['id'])
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   325
        cmd = ['/usr/sbin/zfs', 'destroy', dst_snapshot_name]
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   326
        self._execute(*cmd)
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   327
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   328
    def _get_zvol_path(self, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   329
        """Get the ZFS volume path."""
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   330
        return "/dev/zvol/rdsk/%s" % self._get_zfs_volume_name(volume['name'])
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   331
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   332
    def _update_volume_stats(self):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   333
        """Retrieve volume status info."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   334
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   335
        LOG.debug(_("Updating volume status"))
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   336
        stats = {}
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   337
        backend_name = self.configuration.safe_get('volume_backend_name')
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   338
        stats["volume_backend_name"] = backend_name or self.__class__.__name__
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   339
        stats["storage_protocol"] = self.protocol
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   340
        stats["driver_version"] = '1.0'
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   341
        stats["vendor_name"] = 'Oracle'
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   342
        stats['QoS_support'] = False
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   343
1912
b0c17ef05b75 18658040 zfs.py can't handle terabyte pools
Strony <strony.zhang@oracle.com>
parents: 1760
diff changeset
   344
        dataset = self.configuration.zfs_volume_base
b0c17ef05b75 18658040 zfs.py can't handle terabyte pools
Strony <strony.zhang@oracle.com>
parents: 1760
diff changeset
   345
        used_size = self._get_zfs_property('used', dataset)
b0c17ef05b75 18658040 zfs.py can't handle terabyte pools
Strony <strony.zhang@oracle.com>
parents: 1760
diff changeset
   346
        avail_size = self._get_zfs_property('avail', dataset)
b0c17ef05b75 18658040 zfs.py can't handle terabyte pools
Strony <strony.zhang@oracle.com>
parents: 1760
diff changeset
   347
        stats['total_capacity_gb'] = \
b0c17ef05b75 18658040 zfs.py can't handle terabyte pools
Strony <strony.zhang@oracle.com>
parents: 1760
diff changeset
   348
            (Size(used_size) + Size(avail_size)).get(Size.gb_units)
b0c17ef05b75 18658040 zfs.py can't handle terabyte pools
Strony <strony.zhang@oracle.com>
parents: 1760
diff changeset
   349
        stats['free_capacity_gb'] = Size(avail_size).get(Size.gb_units)
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   350
        stats['reserved_percentage'] = self.configuration.reserved_percentage
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   351
        stats['location_info'] =\
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   352
            ('ZFSVolumeDriver:%(hostname)s:%(zfs_volume_base)s' %
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   353
             {'hostname': self.hostname,
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   354
              'zfs_volume_base': self.configuration.zfs_volume_base})
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   355
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   356
        self._stats = stats
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   357
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   358
    def extend_volume(self, volume, new_size):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   359
        """Extend an existing volume's size."""
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   360
        volsize_str = 'volsize=%sg' % new_size
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   361
        zfs_volume = self._get_zfs_volume_name(volume['name'])
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   362
        try:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   363
            self._execute('/usr/sbin/zfs', 'set', volsize_str, zfs_volume)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   364
        except Exception:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   365
            msg = (_("Failed to extend volume size to %(new_size)s GB.")
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   366
                   % {'new_size': new_size})
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   367
            raise exception.VolumeBackendAPIException(data=msg)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   368
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   369
    def rename_volume(self, src, dst):
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   370
        """Rename the volume from src to dst in the same zpool."""
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   371
        cmd = ['/usr/sbin/zfs', 'rename', src, dst]
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   372
        self._execute(*cmd)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   373
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   374
        LOG.debug(_("Rename the volume '%s' to '%s'") % (src, dst))
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   375
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   376
    def migrate_volume(self, context, volume, host):
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   377
        """Migrate the volume among different backends on the same server.
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   378
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   379
        The volume migration can only run locally by calling zfs send/recv
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   380
        cmds and the specified host needs to be on the same server with the
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   381
        host. But, one exception is when the src and dst volume are located
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   382
        under the same zpool locally or remotely, the migration will be done
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   383
        by just renaming the volume.
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   384
        :param context: context
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   385
        :param volume: a dictionary describing the volume to migrate
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   386
        :param host: a dictionary describing the host to migrate to
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   387
        """
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   388
        false_ret = (False, None)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   389
        if volume['status'] != 'available':
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   390
            LOG.debug(_("Status of volume '%s' is '%s', not 'available'.") %
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   391
                      (volume['name'], volume['status']))
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   392
            return false_ret
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   393
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   394
        if 'capabilities' not in host or \
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   395
           'location_info' not in host['capabilities']:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   396
            LOG.debug(_("No location_info or capabilities are in host info"))
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   397
            return false_ret
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   398
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   399
        info = host['capabilities']['location_info']
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   400
        if (self.hostname != info.split(':')[1]):
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   401
            LOG.debug(_("Migration between two different servers '%s' and "
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   402
                      "'%s' is not supported yet.") %
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   403
                      (self.hostname, info.split(':')[1]))
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   404
            return false_ret
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   405
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   406
        dst_volume = "%s/%s" % (info.split(':')[-1], volume['name'])
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   407
        src_volume = self._get_zfs_volume_name(volume['name'])
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   408
        # check if the src and dst volume are under the same zpool
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   409
        if (src_volume.split('/')[0] == dst_volume.split('/')[0]):
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   410
            self.rename_volume(src_volume, dst_volume)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   411
        else:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   412
            self._zfs_send_recv(volume, dst_volume)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   413
            # delete the source volume
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   414
            self.delete_volume(volume)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   415
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   416
        provider_location = {}
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   417
        return (True, provider_location)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   418
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   419
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   420
class STMFDriver(ZFSVolumeDriver):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   421
    """Abstract base class for common COMSTAR operations."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   422
    __metaclass__ = abc.ABCMeta
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   423
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   424
    def __init__(self, *args, **kwargs):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   425
        super(STMFDriver, self).__init__(*args, **kwargs)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   426
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   427
    def _stmf_execute(self, *cmd):
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   428
        """Handle the possible race during the local execution."""
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   429
        tries = 0
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   430
        while True:
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   431
            try:
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   432
                self._execute(*cmd)
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   433
                return
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   434
            except processutils.ProcessExecutionError as ex:
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   435
                tries = tries + 1
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   436
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   437
                if tries >= self.configuration.num_shell_tries or \
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   438
                        'resource busy' not in ex.stderr:
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   439
                    raise
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   440
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   441
                time.sleep(tries ** 2)
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   442
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   443
    def _check_target(self, target, protocol):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   444
        """Verify if the target exists."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   445
        (out, _err) = self._execute('/usr/sbin/stmfadm', 'list-target')
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   446
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   447
        for line in [l.strip() for l in out.splitlines()]:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   448
            if line.startswith("Target:"):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   449
                if target == line.split()[-1]:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   450
                    break
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   451
        else:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   452
            LOG.debug(_("The target '%s' doesn't exist") % target)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   453
            return False
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   454
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   455
        # Verify if the target protocol is iSCSI.
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   456
        (out, _err) = self._execute('/usr/sbin/stmfadm', 'list-target',
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   457
                                    '-v', target)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   458
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   459
        for line in [l.strip() for l in out.splitlines()]:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   460
            if line.startswith("Target:"):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   461
                tmp_target = line.split()[-1]
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   462
            if line.startswith("Operational"):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   463
                status = line.split()[-1]
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   464
            if line.startswith("Protocol"):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   465
                tmp_protocol = line.split()[-1]
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   466
                break
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   467
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   468
        return (tmp_target == target and status == 'Online' and
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   469
                tmp_protocol == protocol)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   470
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   471
    def _check_tg(self, tg):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   472
        """Check if the target group exists."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   473
        (out, _err) = self._execute('/usr/sbin/stmfadm', 'list-tg')
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   474
        found = False
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   475
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   476
        for line in [l.strip() for l in out.splitlines()]:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   477
            if line.startswith("Target"):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   478
                if tg == line.split()[-1]:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   479
                    found = True
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   480
                    break
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   481
        else:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   482
            LOG.debug(_("The target group '%s' doesn't exist") % tg)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   483
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   484
        return found
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   485
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   486
    def _get_luid(self, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   487
        """Get the LU corresponding to the volume."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   488
        zvol = self._get_zvol_path(volume)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   489
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   490
        (out, _err) = self._execute('/usr/sbin/stmfadm', 'list-lu', '-v')
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   491
        luid = None
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   492
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   493
        for line in [l.strip() for l in out.splitlines()]:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   494
            if line.startswith("LU Name:"):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   495
                luid = line.split()[-1]
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   496
            if line.startswith("Alias") and line.split()[-1] == zvol:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   497
                break
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   498
        else:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   499
            luid = None
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   500
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   501
        if luid is not None:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   502
            LOG.debug(_("Got the LU '%s'") % luid)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   503
        else:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   504
            LOG.debug(_("Failed to get LU for volume '%s'")
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   505
                      % volume['name'])
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   506
        return luid
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   507
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   508
    def _get_view_and_lun(self, lu):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   509
        """Check the view entry of the LU and then get the lun and view."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   510
        view_and_lun = {}
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   511
        view_and_lun['view'] = view_and_lun['lun'] = None
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   512
        try:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   513
            (out, _err) = self._execute('/usr/sbin/stmfadm', 'list-view',
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   514
                                        '-l', lu, '-v')
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   515
        except processutils.ProcessExecutionError as error:
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   516
            if 'no views found' in error.stderr:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   517
                LOG.debug(_("No view is found for LU '%s'") % lu)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   518
                return view_and_lun
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   519
            else:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   520
                raise
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   521
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   522
        for line in [l.strip() for l in out.splitlines()]:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   523
            if line.startswith("View Entry:"):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   524
                view_and_lun['view'] = line.split()[-1]
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   525
            if line.startswith("LUN") and 'Auto' not in line.split()[-1]:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   526
                view_and_lun['lun'] = int(line.split()[-1])
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   527
                break
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   528
            if line.startswith("Lun"):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   529
                view_and_lun['lun'] = int(line.split()[2])
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   530
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   531
        if view_and_lun['view'] is None or view_and_lun['lun'] is None:
3998
5bd484384122 PSARC 2015/110 OpenStack service updates for Juno
Danek Duvall <danek.duvall@oracle.com>
parents: 2162
diff changeset
   532
            err_msg = (_("Failed to get the view_entry or LUN of the LU '%s'.")
5bd484384122 PSARC 2015/110 OpenStack service updates for Juno
Danek Duvall <danek.duvall@oracle.com>
parents: 2162
diff changeset
   533
                       % lu)
5bd484384122 PSARC 2015/110 OpenStack service updates for Juno
Danek Duvall <danek.duvall@oracle.com>
parents: 2162
diff changeset
   534
            raise exception.VolumeBackendAPIException(data=err_msg)
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   535
        else:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   536
            LOG.debug(_("The view_entry and LUN of LU '%s' are '%s' and '%d'.")
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   537
                      % (lu, view_and_lun['view'], view_and_lun['lun']))
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   538
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   539
        return view_and_lun
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   540
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   541
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   542
class ZFSISCSIDriver(STMFDriver, driver.ISCSIDriver):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   543
    """ZFS volume operations in iSCSI mode."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   544
    protocol = 'iSCSI'
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   545
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   546
    def __init__(self, *args, **kwargs):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   547
        super(ZFSISCSIDriver, self).__init__(*args, **kwargs)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   548
5087
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   549
    def do_setup(self, context):
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   550
        """Setup the target and target group."""
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   551
        target_group = self.configuration.zfs_target_group
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   552
        target_name = '%s%s-%s-target' % \
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   553
                      (self.configuration.iscsi_target_prefix,
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   554
                       self.hostname,
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   555
                       target_group)
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   556
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   557
        if not self._check_tg(target_group):
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   558
            self._stmf_execute('/usr/sbin/stmfadm', 'create-tg', target_group)
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   559
        if self._check_target(target_name, 'iSCSI'):
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   560
            return
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   561
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   562
        # Create and add the target into the target group
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   563
        self._stmf_execute('/usr/sbin/itadm', 'create-target', '-n',
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   564
                           target_name)
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   565
        self._stmf_execute('/usr/sbin/stmfadm', 'offline-target',
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   566
                           target_name)
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   567
        self._stmf_execute('/usr/sbin/stmfadm', 'add-tg-member', '-g',
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   568
                           target_group, target_name)
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   569
        self._stmf_execute('/usr/sbin/stmfadm', 'online-target',
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   570
                           target_name)
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   571
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   572
        assert self._check_target(target_name, 'iSCSI')
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   573
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   574
    def create_export(self, context, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   575
        """Export the volume."""
4982
df1be607c345 18595100 nova resize does not work
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4545
diff changeset
   576
        # If the volume is already exported there is nothing to do, as we
df1be607c345 18595100 nova resize does not work
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4545
diff changeset
   577
        # simply export volumes and they are universally available.
4983
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   578
        luid = self._get_luid(volume)
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   579
        if luid:
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   580
            view_lun = self._get_view_and_lun(luid)
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   581
            if view_lun['view'] is not None:
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   582
                return
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   583
            else:
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   584
                msg = (_("Failed to create logical unit for volume '%s' due "
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   585
                         "to an existing LU id but no view.") % volume['name'])
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   586
                raise exception.VolumeBackendAPIException(data=msg)
4982
df1be607c345 18595100 nova resize does not work
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4545
diff changeset
   587
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   588
        zvol = self._get_zvol_path(volume)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   589
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   590
        # Create a Logical Unit (LU)
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   591
        self._stmf_execute('/usr/sbin/stmfadm', 'create-lu', zvol)
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   592
        luid = self._get_luid(volume)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   593
        if not luid:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   594
            msg = (_("Failed to create LU for volume '%s'")
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   595
                   % volume['name'])
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   596
            raise exception.VolumeBackendAPIException(data=msg)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   597
5087
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   598
        # Add a view entry to the logical unit
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   599
        target_group = self.configuration.zfs_target_group
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   600
        self._stmf_execute('/usr/sbin/stmfadm', 'add-view',
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   601
                           '-t', target_group, luid)
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   602
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   603
    def remove_export(self, context, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   604
        """Remove an export for a volume.
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   605
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   606
        All of the related elements about the volume, including the
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   607
        target, target group, view entry and lu, are deleted.
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   608
        """
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   609
        luid = self._get_luid(volume)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   610
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   611
        # Remove the view entry
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   612
        if luid is not None:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   613
            view_lun = self._get_view_and_lun(luid)
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   614
            if view_lun['view']:
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   615
                self._stmf_execute('/usr/sbin/stmfadm', 'remove-view', '-l',
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   616
                                   luid, view_lun['view'])
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   617
5087
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   618
        # Remove the target and its target group if they were created by
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   619
        # earlier versions of the volume driver
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   620
        target_group = 'tg-%s' % volume['name']
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   621
        target_name = '%s%s' % (self.configuration.iscsi_target_prefix,
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   622
                                volume['name'])
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   623
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   624
        if self._check_target(target_name, 'iSCSI'):
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   625
            self._stmf_execute('/usr/sbin/stmfadm', 'offline-target',
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   626
                               target_name)
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   627
            self._stmf_execute('/usr/sbin/itadm', 'delete-target', '-f',
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   628
                               target_name)
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   629
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   630
        if self._check_tg(target_group):
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   631
            self._stmf_execute('/usr/sbin/stmfadm', 'delete-tg', target_group)
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   632
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   633
        # Remove the LU
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   634
        if luid is not None:
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   635
            self._stmf_execute('/usr/sbin/stmfadm', 'delete-lu', luid)
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   636
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   637
    def _get_iscsi_properties(self, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   638
        """Get iSCSI configuration
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   639
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   640
        Now we use the discovery address as the default approach to add
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   641
        objects into the initiator. A discovery address is an IP address:port
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   642
        combination used in a SendTargets discovery session in the initiator.
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   643
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   644
        :target_discovered:    boolean indicating whether discovery was used
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   645
        :target_iqn:           the IQN of the iSCSI target
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   646
        :target_portal:        the portal of the iSCSI target
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   647
        :target_lun:           the lun of the iSCSI target
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   648
        :volume_id:            the id of the volume
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   649
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   650
        :auth_method:, :auth_username:, :auth_password:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   651
            the authentication details. Right now, either auth_method is not
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   652
            present meaning no authentication, or auth_method == `CHAP`
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   653
            meaning use CHAP with the specified credentials.
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   654
        """
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   655
        luid = self._get_luid(volume)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   656
        if not luid:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   657
            msg = (_("Failed to get LU for volume '%s'") % volume['name'])
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   658
            raise exception.VolumeBackendAPIException(data=msg)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   659
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   660
        target_name = '%s%s' % (self.configuration.iscsi_target_prefix,
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   661
                                volume['name'])
5087
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   662
        if not self._check_target(target_name, 'iSCSI'):
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   663
            target_name = '%s%s-%s-target' % \
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   664
                          (self.configuration.iscsi_target_prefix,
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   665
                           self.hostname,
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   666
                           self.configuration.zfs_target_group)
e31e1e575df4 22031461 volume attachment failed
Qiang Strony Zhang <strony.zhang@oracle.com>
parents: 4983
diff changeset
   667
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   668
        properties = {}
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   669
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   670
        properties['target_discovered'] = True
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   671
        properties['target_iqn'] = target_name
3998
5bd484384122 PSARC 2015/110 OpenStack service updates for Juno
Danek Duvall <danek.duvall@oracle.com>
parents: 2162
diff changeset
   672
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   673
        # Here the san_is_local means that the cinder-volume runs in the
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   674
        # iSCSI target with iscsi_ip_address.
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   675
        if self.configuration.san_is_local:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   676
            target_ip = self.configuration.iscsi_ip_address
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   677
        else:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   678
            target_ip = self.configuration.san_ip
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   679
        properties['target_portal'] = ('%s:%d' %
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   680
                                       (target_ip,
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   681
                                        self.configuration.iscsi_port))
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   682
        view_lun = self._get_view_and_lun(luid)
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   683
        if view_lun['lun'] is not None:
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   684
            properties['target_lun'] = view_lun['lun']
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   685
        properties['volume_id'] = volume['id']
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   686
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   687
        auth = volume['provider_auth']
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   688
        if auth:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   689
            (auth_method, auth_username, auth_secret) = auth.split()
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   690
            properties['auth_method'] = auth_method
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   691
            properties['auth_username'] = auth_username
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   692
            properties['auth_password'] = auth_secret
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   693
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   694
        return properties
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   695
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   696
    def initialize_connection(self, volume, connector):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   697
        """Initialize the connection and returns connection info.
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   698
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   699
        The iSCSI driver returns a driver_volume_type of 'iscsi'.
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   700
        The format of the driver data is defined in _get_iscsi_properties.
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   701
        Example return value::
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   702
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   703
        {
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   704
            'driver_volume_type': 'iscsi'
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   705
            'data': {
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   706
                'target_discovered': True,
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   707
                'target_iqn':
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   708
                'iqn.1986-03.com.sun:02:200720c6-9bca-cb8f-c061-d427d7ab978f',
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   709
                'target_portal': '127.0.0.1:3260',
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   710
                'volume_id': 1,
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   711
            }
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   712
        }
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   713
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   714
        """
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   715
        initiator_name = connector['initiator']
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   716
        volume_name = volume['name']
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   717
        LOG.debug(_('Connecting the initiator %(initiator_name)s '
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   718
                    'for volume %(volume_name)s')
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   719
                  % {'initiator_name': initiator_name,
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   720
                     'volume_name': volume_name})
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   721
        iscsi_properties = self._get_iscsi_properties(volume)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   722
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   723
        return {
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   724
            'driver_volume_type': 'iscsi',
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   725
            'data': iscsi_properties
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   726
        }
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   727
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   728
    def terminate_connection(self, volume, connector, **kwargs):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   729
        """Disconnection from the connector."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   730
        initiator_name = connector['initiator']
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   731
        volume_name = volume['name']
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   732
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   733
        LOG.debug(_('Disconnecting the initiator %(initiator_name)s '
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   734
                    'for volume %(volume_name)s')
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   735
                  % {'initiator_name': initiator_name,
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   736
                     'volume_name': volume_name})
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   737
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   738
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   739
class ZFSFCDriver(STMFDriver, driver.FibreChannelDriver):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   740
    """ZFS volume operations in FC mode."""
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   741
    protocol = 'FC'
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   742
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   743
    def __init__(self, *args, **kwargs):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   744
        super(ZFSFCDriver, self).__init__(*args, **kwargs)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   745
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   746
    def check_for_setup_error(self):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   747
        """Check the setup error."""
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   748
        wwns = self._get_wwns()
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   749
        if not wwns:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   750
            msg = (_("Could not determine fibre channel world wide "
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   751
                     "node names."))
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   752
            raise exception.VolumeBackendAPIException(data=msg)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   753
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   754
    def _get_wwns(self):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   755
        """Get the FC port WWNs of the host."""
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   756
        (out, _err) = self._execute('/usr/sbin/fcinfo', 'hba-port', '-t')
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   757
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   758
        wwns = []
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   759
        for line in [l.strip() for l in out.splitlines()]:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   760
            if line.startswith("HBA Port WWN:"):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   761
                wwn = line.split()[-1]
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   762
                LOG.debug(_("Got the FC port WWN '%s'") % wwn)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   763
                wwns.append(wwn)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   764
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   765
        return wwns
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   766
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   767
    def _check_wwn_tg(self, wwn):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   768
        """Check if the target group 'tg-wwn-xxx' exists."""
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   769
        (out, _err) = self._execute('/usr/sbin/stmfadm', 'list-tg')
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   770
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   771
        for line in [l.strip() for l in out.splitlines()]:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   772
            if line.startswith("Target Group:") and wwn in line:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   773
                tg = line.split()[-1]
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   774
                break
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   775
        else:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   776
            LOG.debug(_("The target group 'tg-wwn-%s' doesn't exist.") % wwn)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   777
            tg = None
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   778
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   779
        return tg
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   780
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   781
    def _only_lu(self, lu):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   782
        """Check if the LU is the only one."""
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   783
        (out, _err) = self._execute('/usr/sbin/stmfadm', 'list-lu', '-v')
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   784
        linecount = 0
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   785
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   786
        for line in [l.strip() for l in out.splitlines()]:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   787
            if line.startswith("LU Name:"):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   788
                luid = line.split()[-1]
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   789
                linecount += 1
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   790
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   791
        if linecount == 1 and luid == lu:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   792
            LOG.debug(_("The LU '%s' is the only one.") % lu)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   793
            return True
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   794
        else:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   795
            return False
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   796
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   797
    def _target_in_tg(self, wwn, tg):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   798
        """Check if the target has been added into a target group."""
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   799
        target = 'wwn.%s' % wwn.upper()
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   800
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   801
        if tg is not None:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   802
            (out, _err) = self._execute('/usr/sbin/stmfadm', 'list-tg',
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   803
                                        '-v', tg)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   804
        else:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   805
            (out, _err) = self._execute('/usr/sbin/stmfadm', 'list-tg', '-v')
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   806
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   807
        for line in [l.strip() for l in out.splitlines()]:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   808
            if line.startswith("Member:") and target in line:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   809
                return True
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   810
        LOG.debug(_("The target '%s' is not in any target group.") % target)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   811
        return False
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   812
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   813
    def create_export(self, context, volume):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   814
        """Export the volume."""
4983
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   815
        # If the volume is already exported there is nothing to do, as we
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   816
        # simply export volumes and they are universally available.
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   817
        luid = self._get_luid(volume)
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   818
        if luid:
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   819
            view_lun = self._get_view_and_lun(luid)
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   820
            if view_lun['view'] is not None:
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   821
                return
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   822
            else:
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   823
                msg = (_("Failed to create logical unit for volume '%s' due "
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   824
                         "to an existing LU id but no view.") % volume['name'])
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   825
                raise exception.VolumeBackendAPIException(data=msg)
db2589571faa 21480249 create --source-volid should clone the volume w/o blocking the delete of source
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4982
diff changeset
   826
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   827
        zvol = self._get_zvol_path(volume)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   828
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   829
        # Create a Logical Unit (LU)
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   830
        self._stmf_execute('/usr/sbin/stmfadm', 'create-lu', zvol)
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   831
        luid = self._get_luid(volume)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   832
        if not luid:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   833
            msg = (_("Failed to create logic unit for volume '%s'")
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   834
                   % volume['name'])
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   835
            raise exception.VolumeBackendAPIException(data=msg)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   836
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   837
        wwns = self._get_wwns()
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   838
        wwn = wwns[0]
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   839
        target_group = self._check_wwn_tg(wwn)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   840
        if target_group is None:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   841
            target_group = 'tg-wwn-%s' % wwn
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   842
            if self._target_in_tg(wwn, None):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   843
                msg = (_("Target WWN '%s' has been found in another"
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   844
                         "target group, so it will not be added "
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   845
                         "into the expected target group '%s'.") %
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   846
                       (wwn, target_group))
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   847
                raise exception.VolumeBackendAPIException(data=msg)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   848
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   849
            # Create a target group for the wwn
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   850
            self._stmf_execute('/usr/sbin/stmfadm', 'create-tg', target_group)
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   851
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   852
            # Enable the target and add it to the 'tg-wwn-xxx' group
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   853
            self._stmf_execute('/usr/sbin/stmfadm', 'offline-target',
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   854
                               'wwn.%s' % wwn)
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   855
            self._stmf_execute('/usr/sbin/stmfadm', 'add-tg-member', '-g',
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   856
                               target_group, 'wwn.%s' % wwn)
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   857
            self._stmf_execute('/usr/sbin/stmfadm', 'online-target',
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   858
                               'wwn.%s' % wwn)
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   859
        assert self._target_in_tg(wwn, target_group)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   860
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   861
        # Add a logical unit view entry
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   862
        # TODO(Strony): replace the auto assigned LUN with '-n' option
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   863
        if luid is not None:
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   864
            self._stmf_execute('/usr/sbin/stmfadm', 'add-view', '-t',
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   865
                               target_group, luid)
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   866
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   867
    def remove_export(self, context, volume):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   868
        """Remove an export for a volume."""
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   869
        luid = self._get_luid(volume)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   870
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   871
        if luid is not None:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   872
            wwns = self._get_wwns()
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   873
            wwn = wwns[0]
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   874
            target_wwn = 'wwn.%s' % wwn
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   875
            target_group = 'tg-wwn-%s' % wwn
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   876
            view_lun = self._get_view_and_lun(luid)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   877
            if view_lun['view']:
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   878
                self._stmf_execute('/usr/sbin/stmfadm', 'remove-view', '-l',
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   879
                                   luid, view_lun['view'])
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   880
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   881
            # Remove the target group when only one LU exists.
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   882
            if self._only_lu(luid):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   883
                if self._check_target(target_wwn, 'Channel'):
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   884
                    self._stmf_execute('/usr/sbin/stmfadm', 'offline-target',
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   885
                                       target_wwn)
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   886
                if self._check_tg(target_group):
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   887
                    self._stmf_execute('/usr/sbin/stmfadm', 'delete-tg',
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   888
                                       target_group)
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   889
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   890
            # Remove the LU
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   891
            self._stmf_execute('/usr/sbin/stmfadm', 'delete-lu', luid)
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   892
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   893
    def _get_fc_properties(self, volume):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   894
        """Get Fibre Channel configuration.
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   895
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   896
        :target_discovered:    boolean indicating whether discovery was used
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   897
        :target_wwn:           the world wide name of the FC port target
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   898
        :target_lun:           the lun assigned to the LU for the view entry
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   899
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   900
        """
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   901
        wwns = self._get_wwns()
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   902
        if not wwns:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   903
            msg = (_("Could not determine fibre channel world wide "
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   904
                     "node names."))
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   905
            raise exception.VolumeBackendAPIException(data=msg)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   906
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   907
        luid = self._get_luid(volume)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   908
        if not luid:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   909
            msg = (_("Failed to get logic unit for volume '%s'")
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   910
                   % volume['name'])
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   911
            raise exception.VolumeBackendAPIException(data=msg)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   912
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   913
        properties = {}
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   914
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   915
        properties['target_discovered'] = True
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   916
        properties['target_wwn'] = wwns
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   917
        view_lun = self._get_view_and_lun(luid)
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   918
        if view_lun['lun'] is not None:
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   919
            properties['target_lun'] = view_lun['lun']
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   920
        return properties
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   921
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   922
    def initialize_connection(self, volume, connector):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   923
        """Initializes the connection and returns connection info.
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   924
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   925
        The  driver returns a driver_volume_type of 'fibre_channel'.
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   926
        The target_wwn can be a single entry or a list of wwns that
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   927
        correspond to the list of remote wwn(s) that will export the volume.
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   928
        Example return values:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   929
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   930
            {
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   931
                'driver_volume_type': 'fibre_channel'
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   932
                'data': {
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   933
                    'target_discovered': True,
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   934
                    'target_lun': 1,
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   935
                    'target_wwn': '1234567890123',
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   936
                }
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   937
            }
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   938
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   939
            or
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   940
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   941
             {
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   942
                'driver_volume_type': 'fibre_channel'
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   943
                'data': {
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   944
                    'target_discovered': True,
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   945
                    'target_lun': 1,
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   946
                    'target_wwn': ['1234567890123', '0987654321321'],
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   947
                }
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   948
            }
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   949
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   950
        """
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   951
        fc_properties = self._get_fc_properties(volume)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   952
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   953
        return {
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   954
            'driver_volume_type': 'fibre_channel',
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   955
            'data': fc_properties
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   956
        }