[ovirt-users] Ovirt Python SDK adding a directlun
Juan Hernandez
jhernand at redhat.com
Fri May 9 13:23:42 UTC 2014
On 05/09/2014 10:31 AM, Juan Hernandez wrote:
> On 05/08/2014 11:37 PM, Gary Lloyd wrote:
>> When I add direct Luns this way the size shows as <1 on the GUI and 0 when called from the rest api. All the other items mentioned are not present.
>>
>> Thanks
>>
>
> Ah, I understand. This is probably related to the fact that you aren't
> creating a storage domain, only the storage connection. This should work
> correctly, but I guess that either the GUI or the backend aren't
> completely prepared for this. I'm checking.
>
I think this is a bug, and I didn't find any way to workaround it other
than creating the LUN using the GUI instead of the RESTAPI. I opened the
following BZ to track it:
https://bugzilla.redhat.com/1096217
>>> On 8 May 2014, at 18:05, Juan Hernandez <jhernand at redhat.com> wrote:
>>>
>>>> On 05/08/2014 05:04 PM, Gary Lloyd wrote:
>>>>
>>>> We are working on a script so that we can create an ISCSI LUN on our SAN
>>>> and then directly assign it to a vm.
>>>>
>>>> We have been able to get it to work but with one small annoyance. I
>>>> can't figure out how to populate size,serial,vendor_id and product_id
>>>> via the api. Would anyone be able to point me in the right direction ?
>>>> code (see def add_disk):
>>>>
>>>> def get_clusterid(cluster_name):
>>>> cluster = ovirt_api.clusters.get(cluster_name)
>>>> try:
>>>> return cluster.id <http://cluster.id>
>>>> except:
>>>> logging.error('the cluster: %s does not appear to exist' %
>>>> cluster_name )
>>>> sys.exit(1)
>>>>
>>>> def nominate_host(cluster_id):
>>>> for host in ovirt_api.hosts.list():
>>>> if host.cluster.id <http://host.cluster.id> == cluster_id and
>>>> host.status.state == 'up':
>>>> host.iscsidiscover
>>>> return host
>>>> logging.error('could not find a suitable host to nominate in cluster:')
>>>> sys.exit(1)
>>>>
>>>>
>>>> def iscsi_discover_and_login(cluster,target,portal,chap_user,chap_pass):
>>>> clusterid=get_clusterid(cluster)
>>>> host=nominate_host(clusterid)
>>>>
>>>> iscsidet = params.IscsiDetails()
>>>> iscsidet.address=portal
>>>> iscsidet.username=chap_user
>>>> iscsidet.password=chap_pass
>>>> iscsidet.target=target
>>>>
>>>> host.iscsidiscover(params.Action(iscsi=iscsidet))
>>>> result = host.iscsilogin(params.Action(iscsi=iscsidet))
>>>>
>>>> if result.status.state == 'complete':
>>>>
>>>> storecon = params.StorageConnection()
>>>> storecon.address=portal
>>>> storecon.type_='iscsi'
>>>> storecon.port=3260
>>>> storecon.target=target
>>>> storecon.username=chap_user
>>>> storecon.password=chap_pass
>>>>
>>>> ovirt_api.storageconnections.add(storecon)
>>>>
>>>> return result
>>>> # error checking code needs to be added to this function
>>>>
>>>> def add_disk(vm_name,wwid,target,size,portal):
>>>>
>>>> logunit = params.LogicalUnit()
>>>> logunit.id <http://logunit.id>=wwid
>>>> logunit.vendor_id='EQLOGIC'
>>>> logunit.product_id='100E-00'
>>>> logunit.port=3260
>>>> logunit.lun_mapping=0
>>>> logunit.address=portal
>>>> logunit.target=target
>>>> logunit.size=size * 1073741824
>>>>
>>>> stor = params.Storage(logical_unit=[logunit])
>>>> stor.type_='iscsi'
>>>>
>>>>
>>>> disk = params.Disk()
>>>> disk.alias = 'vm-' + vm_name
>>>> disk.name <http://disk.name> = disk.alias
>>>> disk.interface = 'virtio'
>>>> disk.bootable = True
>>>> disk.type_ = 'iscsi'
>>>> disk.format='raw'
>>>> disk.set_size(size * 1073741824)
>>>> #disk.size=size * 1073741824
>>>> #disk.active=True
>>>>
>>>> disk.lun_storage=stor
>>>>
>>>> try:
>>>> result = ovirt_api.disks.add(disk)
>>>> except:
>>>> logging.error('Could not add disk')
>>>> sys.exit(1)
>>>>
>>>> attachdisk=ovirt_api.disks.get(disk.alias)
>>>> attachdisk.active = True
>>>>
>>>> try:
>>>> ovirt_api.vms.get(vm_name).disks.add(attachdisk)
>>>> except:
>>>> logging.error('Could attach disk to vm')
>>>> sys.exit(1)
>>>>
>>>> return result
>>>>
>>>>
>>>>
>>>> If we could just get the size to show correctly that would be enough,
>>>> the others don't really matter to me.
>>>>
>>>>
>>>> Thanks
>>>>
>>>> /Gary Lloyd/
>>>
>>> For a direct LUN disk all these values are ready only. Why do you need
>>> to change them?
>>>
>>> --
>>> Dirección Comercial: C/Jose Bardasano Baos, 9, Edif. Gorbea 3, planta
>>> 3ºD, 28016 Madrid, Spain
>>> Inscrita en el Reg. Mercantil de Madrid – C.I.F. B82657941 - Red Hat S.L.
>> _______________________________________________
>> Users mailing list
>> Users at ovirt.org
>> http://lists.ovirt.org/mailman/listinfo/users
>>
>
>
--
Dirección Comercial: C/Jose Bardasano Baos, 9, Edif. Gorbea 3, planta
3ºD, 28016 Madrid, Spain
Inscrita en el Reg. Mercantil de Madrid – C.I.F. B82657941 - Red Hat S.L.
More information about the Users
mailing list