components/openstack/cinder/files/solaris/zfs.py
author Sean Wilcox <sean.wilcox@oracle.com>
Tue, 20 Oct 2015 05:38:14 -0700
changeset 4983 db2589571faa
parent 4982 df1be607c345
child 5087 e31e1e575df4
permissions -rw-r--r--
21480249 create --source-volid should clone the volume w/o blocking the delete of source
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',
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    48
               help='The base dataset for ZFS volumes.'), ]
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    49
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    50
FLAGS.register_opts(solaris_zfs_opts)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    51
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    52
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    53
class ZFSVolumeDriver(SanDriver):
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    54
    """Local ZFS volume operations."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    55
    protocol = 'local'
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    56
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    57
    def __init__(self, *args, **kwargs):
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    58
        super(ZFSVolumeDriver, self).__init__(execute=self.solaris_execute,
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    59
                                              *args, **kwargs)
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    60
        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
    61
        self.run_local = self.configuration.san_is_local
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    62
        self.hostname = socket.gethostname()
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    63
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    64
    def solaris_execute(self, *cmd, **kwargs):
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    65
        """Execute the command locally or remotely."""
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    66
        if self.run_local:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    67
            return processutils.execute(*cmd, **kwargs)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    68
        else:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    69
            return super(ZFSVolumeDriver, self)._run_ssh(cmd,
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    70
                                                         check_exit_code=True)
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    71
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    72
    def check_for_setup_error(self):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    73
        """Check the setup error."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    74
        pass
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    75
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    76
    def create_volume(self, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    77
        """Create a volume."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    78
        size = '%sG' % volume['size']
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
    79
        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
    80
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    81
        # Create a ZFS volume
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    82
        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
    83
        self._execute(*cmd)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    84
        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
    85
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    86
    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
    87
        """Create a cloned volume from a snapshot."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    88
        if volume['size'] != snapshot['volume_size']:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    89
            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
    90
                                   "its volume size of '%s' is different "
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    91
                                   "from that of the snapshot, '%s'.")
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    92
                                 % (volume['name'], volume['size'],
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    93
                                    snapshot['volume_size']))
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
    94
            raise exception.InvalidInput(reason=exception_message)
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    95
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    96
        # Create a ZFS clone
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
    97
        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
    98
        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
    99
        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
   100
        self._execute(*cmd)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   101
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   102
        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
   103
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   104
    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
   105
        """Create a clone of the specified volume."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   106
        if volume['size'] != src_vref['size']:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   107
            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
   108
                                   "its volume size of '%s' is different "
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   109
                                   "from that of the source volume, '%s'.")
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   110
                                 % (volume['name'], volume['size'],
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   111
                                    src_vref['size']))
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   112
            raise exception.VolumeBackendAPIException(data=exception_message)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   113
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
   114
        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
   115
                            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
   116
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   117
        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
   118
                  % (volume['name'], src_vref['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
    def delete_volume(self, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   121
        """Delete a volume.
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
        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
   124
        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
   125
        well after it is removed.
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   126
        """
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   127
        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
   128
        try:
5bd484384122 PSARC 2015/110 OpenStack service updates for Juno
Danek Duvall <danek.duvall@oracle.com>
parents: 2162
diff changeset
   129
            (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
   130
        except processutils.ProcessExecutionError:
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   131
            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
   132
            return
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   133
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   134
        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
   135
        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
   136
        tmp_cloned_vol = False
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   137
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   138
        # 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
   139
        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
   140
            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
   141
            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
   142
            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
   143
                tmp_cloned_vol = True
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   144
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   145
        cmd = ['/usr/sbin/zfs', 'destroy', zfs_volume]
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   146
        self._execute(*cmd)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   147
        LOG.debug(_("Deleted volume '%s'") % volume['name'])
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   148
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   149
        if tmp_cloned_vol:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   150
            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
   151
            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
   152
                      % (origin_snapshot, volume['name']))
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   153
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   154
    def create_snapshot(self, snapshot):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   155
        """Create a snapshot."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   156
        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
   157
        self._execute(*cmd)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   158
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   159
        LOG.debug(_("Created snapshot '%s'") % snapshot['name'])
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   160
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   161
    def delete_snapshot(self, snapshot):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   162
        """Delete a snapshot."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   163
        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
   164
        self._execute(*cmd)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   165
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   166
        LOG.debug(_("Deleted snapshot '%s'") % snapshot['name'])
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   167
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   168
    def ensure_export(self, context, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   169
        """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
   170
        pass
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   171
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   172
    def create_export(self, context, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   173
        """Export the volume."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   174
        pass
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   175
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   176
    def remove_export(self, context, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   177
        """Remove an export for a volume."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   178
        pass
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   179
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   180
    def initialize_connection(self, volume, connector):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   181
        """Initialize the connection and returns connection info."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   182
        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
   183
                                        volume['id'])
3998
5bd484384122 PSARC 2015/110 OpenStack service updates for Juno
Danek Duvall <danek.duvall@oracle.com>
parents: 2162
diff changeset
   184
        properties = {}
5bd484384122 PSARC 2015/110 OpenStack service updates for Juno
Danek Duvall <danek.duvall@oracle.com>
parents: 2162
diff changeset
   185
        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
   186
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   187
        return {
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   188
            'driver_volume_type': 'local',
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   189
            'volume_path': volume_path,
3998
5bd484384122 PSARC 2015/110 OpenStack service updates for Juno
Danek Duvall <danek.duvall@oracle.com>
parents: 2162
diff changeset
   190
            'data': properties
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   191
        }
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   192
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   193
    def terminate_connection(self, volume, connector, **kwargs):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   194
        """Disconnection from the connector."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   195
        pass
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   196
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   197
    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
   198
                      mountpoint):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   199
        """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
   200
        pass
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   201
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   202
    def detach_volume(self, context, volume):
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   203
        """ Callback for volume detached."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   204
        pass
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   205
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   206
    def get_volume_stats(self, refresh=False):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   207
        """Get volume status."""
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
        if refresh:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   210
            self._update_volume_stats()
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
        return self._stats
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   213
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   214
    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
   215
        """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
   216
        raise NotImplementedError()
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   217
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   218
    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
   219
        """Copy the volume to the specified image."""
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   220
        raise NotImplementedError()
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   221
1912
b0c17ef05b75 18658040 zfs.py can't handle terabyte pools
Strony <strony.zhang@oracle.com>
parents: 1760
diff changeset
   222
    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
   223
        """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
   224
        try:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   225
            (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
   226
                                        'value', prop, dataset)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   227
            return out.rstrip()
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   228
        except processutils.ProcessExecutionError:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   229
            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
   230
                     (prop, dataset))
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   231
            return None
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   232
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   233
    def _get_zfs_snap_name(self, snapshot):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   234
        """Get the snapshot path."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   235
        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
   236
                             snapshot['volume_name'], snapshot['name'])
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   237
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   238
    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
   239
        """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
   240
        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
   241
                          volume_name)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   242
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
   243
    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
   244
        """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
   245
        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
   246
                  (' '.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
   247
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
        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
   249
        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
   250
        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
   251
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
        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
   253
        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
   254
        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
   255
        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
   256
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
        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
   258
            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
   259
                        "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
   260
                      % (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
   261
            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
   262
            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
   263
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   264
    def _piped_execute(self, cmd1, cmd2):
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   265
        """Pipe output of cmd1 into cmd2."""
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   266
        LOG.debug(_("Piping cmd1='%s' into cmd2='%s'") %
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   267
                  (' '.join(cmd1), ' '.join(cmd2)))
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   268
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   269
        try:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   270
            p1 = subprocess.Popen(cmd1, stdout=subprocess.PIPE,
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   271
                                  stderr=subprocess.PIPE)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   272
        except:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   273
            LOG.error(_("_piped_execute '%s' failed.") % (cmd1))
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   274
            raise
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   275
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   276
        # 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
   277
        # the non-blocking pipe.
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   278
        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
   279
        fcntl.fcntl(p1.stdout, fcntl.F_SETFL, flags)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   280
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   281
        p2 = subprocess.Popen(cmd2, stdin=p1.stdout,
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   282
                              stdout=subprocess.PIPE,
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   283
                              stderr=subprocess.PIPE)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   284
        p1.stdout.close()
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   285
        stdout, stderr = p2.communicate()
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   286
        if p2.returncode:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   287
            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
   288
                   (stdout, stderr))
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   289
            raise exception.VolumeBackendAPIException(data=msg)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   290
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
   291
    def _zfs_send_recv(self, src, dst):
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   292
        """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
   293
        src_snapshot = {'volume_name': src['name'],
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   294
                        'name': 'tmp-snapshot-%s' % src['id']}
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   295
        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
   296
        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
   297
        # Delete the temporary snapshot if it already exists
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   298
        if prop_type == 'snapshot':
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   299
            self.delete_snapshot(src_snapshot)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   300
        # Create a temporary snapshot of volume
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   301
        self.create_snapshot(src_snapshot)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   302
        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
   303
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   304
        cmd1 = ['/usr/sbin/zfs', 'send', src_snapshot_name]
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   305
        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
   306
        # 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
   307
        # 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
   308
        # 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
   309
        # 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
   310
        # 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
   311
        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
   312
            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
   313
            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
   314
            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
   315
            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
   316
        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
   317
            self._piped_execute(cmd1, cmd2)
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   318
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   319
        # Delete the temporary src snapshot and dst snapshot
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   320
        self.delete_snapshot(src_snapshot)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   321
        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
   322
        cmd = ['/usr/sbin/zfs', 'destroy', dst_snapshot_name]
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   323
        self._execute(*cmd)
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   324
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   325
    def _get_zvol_path(self, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   326
        """Get the ZFS volume path."""
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   327
        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
   328
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   329
    def _update_volume_stats(self):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   330
        """Retrieve volume status info."""
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
        LOG.debug(_("Updating volume status"))
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   333
        stats = {}
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   334
        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
   335
        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
   336
        stats["storage_protocol"] = self.protocol
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   337
        stats["driver_version"] = '1.0'
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   338
        stats["vendor_name"] = 'Oracle'
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   339
        stats['QoS_support'] = False
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   340
1912
b0c17ef05b75 18658040 zfs.py can't handle terabyte pools
Strony <strony.zhang@oracle.com>
parents: 1760
diff changeset
   341
        dataset = self.configuration.zfs_volume_base
b0c17ef05b75 18658040 zfs.py can't handle terabyte pools
Strony <strony.zhang@oracle.com>
parents: 1760
diff changeset
   342
        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
   343
        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
   344
        stats['total_capacity_gb'] = \
b0c17ef05b75 18658040 zfs.py can't handle terabyte pools
Strony <strony.zhang@oracle.com>
parents: 1760
diff changeset
   345
            (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
   346
        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
   347
        stats['reserved_percentage'] = self.configuration.reserved_percentage
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   348
        stats['location_info'] =\
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   349
            ('ZFSVolumeDriver:%(hostname)s:%(zfs_volume_base)s' %
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   350
             {'hostname': self.hostname,
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   351
              '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
   352
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   353
        self._stats = stats
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   354
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   355
    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
   356
        """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
   357
        volsize_str = 'volsize=%sg' % new_size
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   358
        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
   359
        try:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   360
            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
   361
        except Exception:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   362
            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
   363
                   % {'new_size': new_size})
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   364
            raise exception.VolumeBackendAPIException(data=msg)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   365
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   366
    def rename_volume(self, src, dst):
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   367
        """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
   368
        cmd = ['/usr/sbin/zfs', 'rename', src, dst]
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   369
        self._execute(*cmd)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   370
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   371
        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
   372
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   373
    def migrate_volume(self, context, volume, host):
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   374
        """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
   375
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   376
        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
   377
        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
   378
        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
   379
        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
   380
        by just renaming the volume.
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   381
        :param context: context
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   382
        :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
   383
        :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
   384
        """
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   385
        false_ret = (False, None)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   386
        if volume['status'] != 'available':
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   387
            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
   388
                      (volume['name'], volume['status']))
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   389
            return false_ret
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   390
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   391
        if 'capabilities' not in host or \
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   392
           'location_info' not in host['capabilities']:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   393
            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
   394
            return false_ret
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   395
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   396
        info = host['capabilities']['location_info']
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   397
        if (self.hostname != info.split(':')[1]):
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   398
            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
   399
                      "'%s' is not supported yet.") %
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   400
                      (self.hostname, info.split(':')[1]))
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   401
            return false_ret
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   402
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   403
        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
   404
        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
   405
        # 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
   406
        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
   407
            self.rename_volume(src_volume, dst_volume)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   408
        else:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   409
            self._zfs_send_recv(volume, dst_volume)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   410
            # delete the source volume
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   411
            self.delete_volume(volume)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   412
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   413
        provider_location = {}
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   414
        return (True, provider_location)
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   415
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   416
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   417
class STMFDriver(ZFSVolumeDriver):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   418
    """Abstract base class for common COMSTAR operations."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   419
    __metaclass__ = abc.ABCMeta
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   420
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   421
    def __init__(self, *args, **kwargs):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   422
        super(STMFDriver, self).__init__(*args, **kwargs)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   423
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   424
    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
   425
        """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
   426
        tries = 0
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   427
        while True:
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   428
            try:
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   429
                self._execute(*cmd)
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   430
                return
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   431
            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
   432
                tries = tries + 1
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   433
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   434
                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
   435
                        '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
   436
                    raise
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   437
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   438
                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
   439
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   440
    def _check_target(self, target, protocol):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   441
        """Verify if the target exists."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   442
        (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
   443
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   444
        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
   445
            if line.startswith("Target:"):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   446
                if target == line.split()[-1]:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   447
                    break
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   448
        else:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   449
            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
   450
            return False
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   451
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   452
        # Verify if the target protocol is iSCSI.
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   453
        (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
   454
                                    '-v', target)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   455
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   456
        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
   457
            if line.startswith("Target:"):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   458
                tmp_target = line.split()[-1]
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   459
            if line.startswith("Operational"):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   460
                status = line.split()[-1]
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   461
            if line.startswith("Protocol"):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   462
                tmp_protocol = line.split()[-1]
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   463
                break
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   464
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   465
        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
   466
                tmp_protocol == protocol)
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
    def _check_tg(self, tg):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   469
        """Check if the target group exists."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   470
        (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
   471
        found = False
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   472
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   473
        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
   474
            if line.startswith("Target"):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   475
                if tg == line.split()[-1]:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   476
                    found = True
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   477
                    break
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   478
        else:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   479
            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
   480
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   481
        return found
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   482
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   483
    def _get_luid(self, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   484
        """Get the LU corresponding to the volume."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   485
        zvol = self._get_zvol_path(volume)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   486
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   487
        (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
   488
        luid = None
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
        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
   491
            if line.startswith("LU Name:"):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   492
                luid = line.split()[-1]
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   493
            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
   494
                break
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   495
        else:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   496
            luid = None
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   497
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   498
        if luid is not None:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   499
            LOG.debug(_("Got the LU '%s'") % luid)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   500
        else:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   501
            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
   502
                      % volume['name'])
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   503
        return luid
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   504
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   505
    def _get_view_and_lun(self, lu):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   506
        """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
   507
        view_and_lun = {}
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   508
        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
   509
        try:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   510
            (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
   511
                                        '-l', lu, '-v')
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   512
        except processutils.ProcessExecutionError as error:
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   513
            if 'no views found' in error.stderr:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   514
                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
   515
                return view_and_lun
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   516
            else:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   517
                raise
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   518
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   519
        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
   520
            if line.startswith("View Entry:"):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   521
                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
   522
            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
   523
                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
   524
                break
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   525
            if line.startswith("Lun"):
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()[2])
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   527
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   528
        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
   529
            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
   530
                       % lu)
5bd484384122 PSARC 2015/110 OpenStack service updates for Juno
Danek Duvall <danek.duvall@oracle.com>
parents: 2162
diff changeset
   531
            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
   532
        else:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   533
            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
   534
                      % (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
   535
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   536
        return view_and_lun
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   537
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
class ZFSISCSIDriver(STMFDriver, driver.ISCSIDriver):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   540
    """ZFS volume operations in iSCSI mode."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   541
    protocol = 'iSCSI'
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   542
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   543
    def __init__(self, *args, **kwargs):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   544
        super(ZFSISCSIDriver, self).__init__(*args, **kwargs)
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 create_export(self, context, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   547
        """Export the volume."""
4982
df1be607c345 18595100 nova resize does not work
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4545
diff changeset
   548
        # 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
   549
        # 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
   550
        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
   551
        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
   552
            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
   553
            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
   554
                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
   555
            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
   556
                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
   557
                         "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
   558
                raise exception.VolumeBackendAPIException(data=msg)
4982
df1be607c345 18595100 nova resize does not work
Sean Wilcox <sean.wilcox@oracle.com>
parents: 4545
diff changeset
   559
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   560
        zvol = self._get_zvol_path(volume)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   561
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   562
        # 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
   563
        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
   564
        luid = self._get_luid(volume)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   565
        if not luid:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   566
            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
   567
                   % volume['name'])
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   568
            raise exception.VolumeBackendAPIException(data=msg)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   569
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   570
        # Create a target group and a target belonging to the target group
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   571
        target_group = 'tg-%s' % volume['name']
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   572
        self._stmf_execute('/usr/sbin/stmfadm', 'create-tg', target_group)
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   573
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   574
        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
   575
                                volume['name'])
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   576
        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
   577
                           target_group, target_name)
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   578
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   579
        self._stmf_execute('/usr/sbin/itadm', 'create-target', '-n',
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   580
                           target_name)
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   581
        assert self._check_target(target_name, 'iSCSI')
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   582
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   583
        # Add a view entry to the logical unit with the specified LUN, 8776
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   584
        if luid is not None:
3998
5bd484384122 PSARC 2015/110 OpenStack service updates for Juno
Danek Duvall <danek.duvall@oracle.com>
parents: 2162
diff changeset
   585
            self._stmf_execute('/usr/sbin/stmfadm', 'add-view', '-n', '8776',
2162
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   586
                               '-t', target_group, luid)
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   587
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   588
    def remove_export(self, context, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   589
        """Remove an export for a volume.
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   590
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   591
        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
   592
        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
   593
        """
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   594
        luid = self._get_luid(volume)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   595
        target_group = 'tg-%s' % volume['name']
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   596
        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
   597
                                volume['name'])
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   598
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   599
        # Remove the view entry
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   600
        if luid is not None:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   601
            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
   602
            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
   603
                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
   604
                                   luid, view_lun['view'])
1760
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
        # Remove the target and its target group
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   607
        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
   608
            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
   609
                               target_name)
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   610
            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
   611
                               target_name)
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   612
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   613
        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
   614
            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
   615
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   616
        # Remove the LU
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   617
        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
   618
            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
   619
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   620
    def _get_iscsi_properties(self, volume):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   621
        """Get iSCSI configuration
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   622
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   623
        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
   624
        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
   625
        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
   626
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   627
        :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
   628
        :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
   629
        :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
   630
        :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
   631
        :volume_id:            the id of the volume
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
        :auth_method:, :auth_username:, :auth_password:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   634
            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
   635
            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
   636
            meaning use CHAP with the specified credentials.
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   637
        """
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   638
        luid = self._get_luid(volume)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   639
        if not luid:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   640
            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
   641
            raise exception.VolumeBackendAPIException(data=msg)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   642
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   643
        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
   644
                                volume['name'])
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   645
        properties = {}
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   646
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   647
        properties['target_discovered'] = True
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   648
        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
   649
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   650
        # 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
   651
        # iSCSI target with iscsi_ip_address.
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   652
        if self.configuration.san_is_local:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   653
            target_ip = self.configuration.iscsi_ip_address
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   654
        else:
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   655
            target_ip = self.configuration.san_ip
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   656
        properties['target_portal'] = ('%s:%d' %
4545
538c0aeae836 PSARC 2015/289 OpenStack Cinder Enhancements
Strony <strony.zhang@oracle.com>
parents: 3998
diff changeset
   657
                                       (target_ip,
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   658
                                        self.configuration.iscsi_port))
1760
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   659
        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
   660
        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
   661
            properties['target_lun'] = view_lun['lun']
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   662
        properties['volume_id'] = volume['id']
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   663
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   664
        auth = volume['provider_auth']
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   665
        if auth:
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   666
            (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
   667
            properties['auth_method'] = auth_method
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   668
            properties['auth_username'] = auth_username
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   669
            properties['auth_password'] = auth_secret
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   670
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   671
        return properties
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   672
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   673
    def initialize_connection(self, volume, connector):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   674
        """Initialize the connection and returns connection info.
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   675
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   676
        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
   677
        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
   678
        Example return value::
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   679
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   680
        {
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   681
            'driver_volume_type': 'iscsi'
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   682
            'data': {
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   683
                'target_discovered': True,
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   684
                'target_iqn':
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   685
                '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
   686
                'target_portal': '127.0.0.1:3260',
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   687
                'volume_id': 1,
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   688
            }
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   689
        }
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   690
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   691
        """
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   692
        initiator_name = connector['initiator']
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   693
        volume_name = volume['name']
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   694
        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
   695
                    'for volume %(volume_name)s')
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   696
                  % {'initiator_name': initiator_name,
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   697
                     'volume_name': volume_name})
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   698
        iscsi_properties = self._get_iscsi_properties(volume)
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   699
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   700
        return {
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   701
            'driver_volume_type': 'iscsi',
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   702
            'data': iscsi_properties
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
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   705
    def terminate_connection(self, volume, connector, **kwargs):
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   706
        """Disconnection from the connector."""
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   707
        initiator_name = connector['initiator']
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   708
        volume_name = volume['name']
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   709
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   710
        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
   711
                    'for volume %(volume_name)s')
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   712
                  % {'initiator_name': initiator_name,
353323c7bdc1 PSARC/2013/350 OpenStack for Solaris (Umbrella)
Drew Fisher <drew.fisher@oracle.com>
parents:
diff changeset
   713
                     'volume_name': volume_name})
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   714
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   715
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   716
class ZFSFCDriver(STMFDriver, driver.FibreChannelDriver):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   717
    """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
   718
    protocol = 'FC'
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   719
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   720
    def __init__(self, *args, **kwargs):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   721
        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
   722
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   723
    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
   724
        """Check the setup error."""
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   725
        wwns = self._get_wwns()
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   726
        if not wwns:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   727
            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
   728
                     "node names."))
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   729
            raise exception.VolumeBackendAPIException(data=msg)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   730
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   731
    def _get_wwns(self):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   732
        """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
   733
        (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
   734
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   735
        wwns = []
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   736
        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
   737
            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
   738
                wwn = line.split()[-1]
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   739
                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
   740
                wwns.append(wwn)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   741
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   742
        return wwns
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   743
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   744
    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
   745
        """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
   746
        (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
   747
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   748
        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
   749
            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
   750
                tg = line.split()[-1]
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   751
                break
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   752
        else:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   753
            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
   754
            tg = None
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   755
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   756
        return tg
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
    def _only_lu(self, lu):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   759
        """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
   760
        (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
   761
        linecount = 0
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   762
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   763
        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
   764
            if line.startswith("LU Name:"):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   765
                luid = line.split()[-1]
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   766
                linecount += 1
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   767
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   768
        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
   769
            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
   770
            return True
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   771
        else:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   772
            return False
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   773
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   774
    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
   775
        """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
   776
        target = 'wwn.%s' % wwn.upper()
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   777
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   778
        if tg is not None:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   779
            (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
   780
                                        '-v', tg)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   781
        else:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   782
            (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
   783
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   784
        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
   785
            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
   786
                return True
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   787
        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
   788
        return False
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   789
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   790
    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
   791
        """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
   792
        # 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
   793
        # 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
   794
        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
   795
        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
   796
            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
   797
            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
   798
                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
   799
            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
   800
                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
   801
                         "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
   802
                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
   803
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   804
        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
   805
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   806
        # 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
   807
        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
   808
        luid = self._get_luid(volume)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   809
        if not luid:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   810
            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
   811
                   % volume['name'])
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   812
            raise exception.VolumeBackendAPIException(data=msg)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   813
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   814
        wwns = self._get_wwns()
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   815
        wwn = wwns[0]
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   816
        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
   817
        if target_group is None:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   818
            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
   819
            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
   820
                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
   821
                         "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
   822
                         "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
   823
                       (wwn, target_group))
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   824
                raise exception.VolumeBackendAPIException(data=msg)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   825
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   826
            # 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
   827
            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
   828
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   829
            # 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
   830
            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
   831
                               'wwn.%s' % wwn)
0fee3eccf153 19596691 instance failed to launch, cinder hit resource busy in stmfadm
Strony <strony.zhang@oracle.com>
parents: 1944
diff changeset
   832
            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
   833
                               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
   834
            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
   835
                               'wwn.%s' % wwn)
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   836
        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
   837
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   838
        # 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
   839
        # 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
   840
        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
   841
            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
   842
                               target_group, luid)
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   843
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   844
    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
   845
        """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
   846
        luid = self._get_luid(volume)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   847
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   848
        if luid is not None:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   849
            wwns = self._get_wwns()
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   850
            wwn = wwns[0]
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   851
            target_wwn = 'wwn.%s' % wwn
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   852
            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
   853
            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
   854
            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
   855
                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
   856
                                   luid, view_lun['view'])
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   857
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   858
            # 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
   859
            if self._only_lu(luid):
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   860
                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
   861
                    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
   862
                                       target_wwn)
1944
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   863
                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
   864
                    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
   865
                                       target_group)
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
            # 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
   868
            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
   869
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   870
    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
   871
        """Get Fibre Channel configuration.
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   872
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   873
        :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
   874
        :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
   875
        :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
   876
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   877
        """
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   878
        wwns = self._get_wwns()
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   879
        if not wwns:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   880
            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
   881
                     "node names."))
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   882
            raise exception.VolumeBackendAPIException(data=msg)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   883
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   884
        luid = self._get_luid(volume)
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   885
        if not luid:
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   886
            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
   887
                   % volume['name'])
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   888
            raise exception.VolumeBackendAPIException(data=msg)
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
        properties = {}
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   891
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   892
        properties['target_discovered'] = True
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   893
        properties['target_wwn'] = wwns
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   894
        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
   895
        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
   896
            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
   897
        return properties
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   898
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   899
    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
   900
        """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
   901
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   902
        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
   903
        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
   904
        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
   905
        Example return values:
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
            {
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   908
                'driver_volume_type': 'fibre_channel'
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   909
                'data': {
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   910
                    'target_discovered': True,
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   911
                    'target_lun': 1,
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   912
                    'target_wwn': '1234567890123',
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   913
                }
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
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   916
            or
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   917
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   918
             {
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   919
                'driver_volume_type': 'fibre_channel'
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   920
                'data': {
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   921
                    'target_discovered': True,
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   922
                    'target_lun': 1,
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   923
                    'target_wwn': ['1234567890123', '0987654321321'],
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
            }
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   926
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   927
        """
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   928
        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
   929
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   930
        return {
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': fc_properties
56ac2df1785b PSARC/2014/207 OpenStack Glance Update to Havana
Drew Fisher <drew.fisher@oracle.com>
parents: 1912
diff changeset
   933
        }