[ 
https://issues.apache.org/jira/browse/CLOUDSTACK-4665?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=13965383#comment-13965383
 ] 

ASF subversion and git services commented on CLOUDSTACK-4665:
-------------------------------------------------------------

Commit 75792bf08e86bfb9bb9c23c86d275f6fe5d4346b in cloudstack's branch 
refs/heads/4.4 from [~widodh]
[ https://git-wip-us.apache.org/repos/asf?p=cloudstack.git;h=75792bf ]

CLOUDSTACK-4665: Check if a snapshot is protected before trying to unprotect

Otherwise a RBDException will be thrown with the message that the snapshot
isn't protected.

Conflicts:

        
plugins/hypervisors/kvm/src/com/cloud/hypervisor/kvm/storage/LibvirtStorageAdaptor.java


> ceph:delete volume fails with ArrayIndexOutOfBoundsException
> ------------------------------------------------------------
>
>                 Key: CLOUDSTACK-4665
>                 URL: https://issues.apache.org/jira/browse/CLOUDSTACK-4665
>             Project: CloudStack
>          Issue Type: Bug
>      Security Level: Public(Anyone can view this level - this is the 
> default.) 
>          Components: Management Server
>    Affects Versions: 4.2.0
>            Reporter: sadhu suresh
>            Assignee: Wido den Hollander
>             Fix For: 4.5.0
>
>
> delete volume failed with exception and this leads to agent disconnect on 
> host side sometimes
> steps:
> 1.create diskoffering based on RBD based storage
> 2.create data disk and attach to instance
> 3.detach the data disk and delete the data volume
> Actual result:
> delete volume failed with exception.
> and volume state is in expunge state.
>  Unsupported data object (VOLUME, 
> org.apache.cloudstack.storage.datastore.PrimaryDataStoreImpl@7ed5043e), no 
> need to delete from object in store ref table
> Management log:
> 55,085 DEBUG [agent.transport.Request] (AgentManager-Handler-10:null) Seq 
> 4-1926960794: Processing:  { Ans: , MgmtId: 7175246184473, via: 4, Ver: v1, 
> Flags: 10, [{"com.cloud.agent.api.Answer":{"result":false,"details":"empty 
> String","wait":0}}] }
> 2013-09-13 23:08:55,086 DEBUG [agent.transport.Request] 
> (StatsCollector-3:null) Seq 4-1926960794: Received:  { Ans: , MgmtId: 
> 7175246184473, via: 4, Ver: v1, Flags: 10, { Answer } }
> 2013-09-13 23:08:55,086 DEBUG [agent.manager.AgentManagerImpl] 
> (StatsCollector-3:null) Details from executing class 
> com.cloud.agent.api.GetHostStatsCommand: empty String
> 2013-09-13 23:08:55,087 WARN  [cloud.resource.ResourceManagerImpl] 
> (StatsCollector-3:null) Unable to obtain host 4 statistics.
> 2013-09-13 23:08:55,087 WARN  [cloud.server.StatsCollector] 
> (StatsCollector-3:null) Received invalid host stats for host: 4
> 2013-09-13 23:08:58,598 DEBUG [cloud.api.ApiServlet] (catalina-exec-20:null) 
> ===START===  10.252.192.100 -- GET  
> command=listVolumes&response=json&sessionkey=DjciUSGRnKCBl6Oban7oUhZ9O2o%3D&listAll=true&page=1&pagesize=20&_=1379074592467
> 2013-09-13 23:08:58,619 DEBUG [cloud.api.ApiServlet] (catalina-exec-20:null) 
> ===END===  10.252.192.100 -- GET  
> command=listVolumes&response=json&sessionkey=DjciUSGRnKCBl6Oban7oUhZ9O2o%3D&listAll=true&page=1&pagesize=20&_=1379074592467
> 2013-09-13 23:08:58,809 DEBUG [agent.manager.AgentManagerImpl] 
> (AgentManager-Handler-2:null) SeqA 2-13479: Processing Seq 2-13479:  { Cmd , 
> MgmtId: -1, via: 2, Ver: v1, Flags: 11, 
> [{"com.cloud.agent.api.ConsoleProxyLoadReportCommand":{"_proxyVmId":2,"_loadInfo":"{\n
>   \"connections\": []\n}","wait":0}}] }
> 2013-09-13 23:08:58,818 DEBUG [agent.manager.AgentManagerImpl] 
> (AgentManager-Handler-2:null) SeqA 2-13479: Sending Seq 2-13479:  { Ans: , 
> MgmtId: 7175246184473, via: 2, Ver: v1, Flags: 100010, 
> [{"com.cloud.agent.api.AgentControlAnswer":{"result":true,"wait":0}}] }
> 2013-09-13 23:09:01,031 DEBUG [cloud.api.ApiServlet] (catalina-exec-15:null) 
> ===START===  10.252.192.100 -- GET  
> command=listVolumes&id=78601d43-4649-40bd-b6aa-86e46e427020&response=json&sessionkey=DjciUSGRnKCBl6Oban7oUhZ9O2o%3D&_=1379074594899
> 2013-09-13 23:09:01,071 DEBUG [cloud.api.ApiServlet] (catalina-exec-15:null) 
> ===END===  10.252.192.100 -- GET  
> command=listVolumes&id=78601d43-4649-40bd-b6aa-86e46e427020&response=json&sessionkey=DjciUSGRnKCBl6Oban7oUhZ9O2o%3D&_=1379074594899
> 2013-09-13 23:09:01,269 DEBUG [cloud.api.ApiServlet] (catalina-exec-5:null) 
> ===START===  10.252.192.100 -- GET  
> command=listTags&response=json&sessionkey=DjciUSGRnKCBl6Oban7oUhZ9O2o%3D&resourceId=78601d43-4649-40bd-b6aa-86e46e427020&resourceType=Volume&listAll=true&_=1379074595115
> 2013-09-13 23:09:01,278 DEBUG [cloud.api.ApiServlet] (catalina-exec-5:null) 
> ===END===  10.252.192.100 -- GET  
> command=listTags&response=json&sessionkey=DjciUSGRnKCBl6Oban7oUhZ9O2o%3D&resourceId=78601d43-4649-40bd-b6aa-86e46e427020&resourceType=Volume&listAll=true&_=1379074595115
> 2013-09-13 23:09:01,804 DEBUG [agent.manager.AgentManagerImpl] 
> (AgentManager-Handler-15:null) Ping from 1
> 2013-09-13 23:09:04,308 DEBUG [cloud.api.ApiServlet] (catalina-exec-1:null) 
> ===START===  10.252.192.100 -- GET  
> command=deleteVolume&id=78601d43-4649-40bd-b6aa-86e46e427020&response=json&sessionkey=DjciUSGRnKCBl6Oban7oUhZ9O2o%3D&_=1379074598164
> 2013-09-13 23:09:04,512 INFO  [cloud.storage.VolumeManagerImpl] 
> (catalina-exec-1:null) Expunging volume 16 from primary data store
> 2013-09-13 23:09:04,980 DEBUG [agent.transport.Request] 
> (catalina-exec-1:null) Seq 1-308871219: Sending  { Cmd , MgmtId: 
> 7175246184473, via: 1, Ver: v1, Flags: 100011, 
> [{"org.apache.cloudstack.storage.command.DeleteCommand":{"data":{"org.apache.cloudstack.storage.to.VolumeObjectTO":{"uuid":"78601d43-4649-40bd-b6aa-86e46e427020","volumeType":"DATADISK","dataStore":{"org.apache.cloudstack.storage.to.PrimaryDataStoreTO":{"uuid":"2c19704e-55d4-31aa-b0e7-a52f1fffab9e","id":2,"poolType":"RBD","host":"10.147.41.3","path":"sadhu1","port":6789}},"name":"da1","size":5368709120,"path":"07bf47b1-d5da-429f-903a-53517cd0e0fd","volumeId":16,"accountId":2,"format":"QCOW2","id":16,"hypervisorType":"KVM"}},"wait":0}}]
>  }
> 2013-09-13 23:09:05,136 DEBUG [agent.manager.AgentManagerImpl] 
> (AgentManager-Handler-13:null) Ping from 2
> 2013-09-13 23:09:05,291 DEBUG [agent.manager.AgentManagerImpl] 
> (AgentManager-Handler-11:null) Ping from 3
> @                                                                             
>                                                                               
>             @                                                                 
>                                                                               
>                         @                                                     
>                                                                               
>           3 23:09:01,804 DEBUG [agent.manager.AgentManagerImpl] 
> (AgentManager-Handler-15:null) Ping from 1
> 2013-09-13 23:09:04,308 DEBUG [cloud.api.ApiServlet] (catalina-exec-1:null) 
> ===START===  10.252.192.100 -- GET  
> command=deleteVolume&id=78601d43-4649-40bd-b6aa-86e46e427020&response=json&sessionkey=DjciUSGRnKCBl6Oban7oUhZ9O2o%3D&_=1379074598164
> 2013-09-13 23:09:04,512 INFO  [cloud.storage.VolumeManagerImpl] 
> (catalina-exec-1:null) Expunging volume 16 from primary data store
> 2013-09-13 23:09:04,980 DEBUG [agent.transport.Request] 
> (catalina-exec-1:null) Seq 1-308871219: Sending  { Cmd , MgmtId: 
> 7175246184473, via: 1, Ver: v1, Flags: 100011, 
> [{"org.apache.cloudstack.storage.command.DeleteCommand":{"data":{"org.apache.cloudstack.storage.to.VolumeObjectTO":{"uuid":"78601d43-4649-40bd-b6aa-86e46e427020","volumeType":"DATADISK","dataStore":{"org.apache.cloudstack.storage.to.PrimaryDataStoreTO":{"uuid":"2c19704e-55d4-31aa-b0e7-a52f1fffab9e","id":2,"poolType":"RBD","host":"10.147.41.3","path":"sadhu1","port":6789}},"name":"da1","size":5368709120,"path":"07bf47b1-d5da-429f-903a-53517cd0e0fd","volumeId":16,"accountId":2,"format":"QCOW2","id":16,"hypervisorType":"KVM"}},"wait":0}}]
>  }
> 2013-09-13 23:09:05,136 DEBUG [agent.manager.AgentManagerImpl] 
> (AgentManager-Handler-13:null) Ping from 2
> 2013-09-13 23:09:05,291 DEBUG [agent.manager.AgentManagerImpl] 
> (AgentManager-Handler-11:null) Ping from 3
> 2013-09-13 23:09:06,124 DEBUG [agent.transport.Request] 
> (AgentManager-Handler-7:null) Seq 1-308871219: Processing:  { Ans: , MgmtId: 
> 7175246184473, via: 1, Ver: v1, Flags: 10, 
> [{"com.cloud.agent.api.Answer":{"result":false,"details":"java.lang.ArrayIndexOutOfBoundsException:
>  0\n\tat com.sun.jna.Structure.toArray(Structure.java:1042)\n\tat 
> com.sun.jna.Structure.toArray(Structure.java:1065)\n\tat 
> com.ceph.rbd.RbdImage.snapList(Unknown Source)\n\tat 
> com.cloud.hypervisor.kvm.storage.LibvirtStorageAdaptor.deletePhysicalDisk(LibvirtStorageAdaptor.java:732)\n\tat
>  
> com.cloud.hypervisor.kvm.storage.LibvirtStoragePool.deletePhysicalDisk(LibvirtStoragePool.java:158)\n\tat
>  
> com.cloud.hypervisor.kvm.storage.KVMStorageProcessor.deleteVolume(KVMStorageProcessor.java:1129)\n\tat
>  
> com.cloud.storage.resource.StorageSubsystemCommandHandlerBase.execute(StorageSubsystemCommandHandlerBase.java:114)\n\tat
>  
> com.cloud.storage.resource.StorageSubsystemCommandHandlerBase.handleStorageCommands(StorageSubsystemCommandHandlerBase.java:53)\n\tat
>  
> com.cloud.hypervisor.kvm.resource.LibvirtComputingResource.executeRequest(LibvirtComputingResource.java:1286)\n\tat
>  com.cloud.agent.Agent.processRequest(Agent.java:525)\n\tat 
> com.cloud.agent.Agent$AgentRequestHandler.doTask(Agent.java:852)\n\tat 
> com.cloud.utils.nio.Task.run(Task.java:83)\n\tat 
> java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1146)\n\tat
>  
> java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)\n\tat
>  java.lang.Thread.run(Thread.java:679)\n","wait":0}}] }
> 2013-09-13 23:09:06,124 DEBUG [agent.transport.Request] 
> (catalina-exec-1:null) Seq 1-308871219: Received:  { Ans: , MgmtId: 
> 7175246184473, via: 1, Ver: v1, Flags: 10, { Answer } }
> 2013-09-13 23:09:06,142 WARN  
> [storage.datastore.ObjectInDataStoreManagerImpl] (catalina-exec-1:null) 
> Unsupported data object (VOLUME, 
> org.apache.cloudstack.storage.datastore.PrimaryDataStoreImpl@7ed5043e), no 
> need to delete from object in store ref table
> 2013-09-13 23:09:06,162 DEBUG [cloud.api.ApiServlet] (catalina-exec-1:null) 
> ===END===  10.252.192.100 -- GET  
> command=deleteVolume&id=78601d43-4649-40bd-b6aa-86e46e427020&response=json&sessionkey=DjciUSGRnKCBl6Oban7oUhZ9O2o%3D&_=1379074598164
> 2013-09-13 23:09:08,810 DEBUG [agent.manager.AgentManagerImpl] 
> (AgentManager-Handler-1:null) SeqA 2-13481: Processing Seq 2-13481:  { Cmd , 
> MgmtId: -1, via: 2, Ver: v1, Flags: 11, 
> [{"com.cloud.agent.api.ConsoleProxyLoadReportCommand":{"_proxyVmId":2,"_loadInfo":"{\n
>   \"connections\": []\n}","wait":0}}] }
> 2013-09-13 23:09:08,819 DEBUG [agent.manager.AgentManagerImpl] 
> (AgentManager-Handler-1:null) SeqA 2-13481: Sending Seq 2-13481:  { Ans: , 
> MgmtId: 7175246184473, via: 2, Ver: v1, Flags: 100010, 
> [{"com.cloud.agent.api.AgentControlAnswer":{"result":true,"wait":0}}] }
> 2013-09-13 23:09:11,733 DEBUG [storage.secondary.SecondaryStorageManagerImpl] 
> (secstorage-1:null) Zone 1 is ready to launch secondary storage VM
> 2013-09-13 23:09:12,634 DEBUG [cloud.consoleproxy.ConsoleProxyManagerImpl] 
> (consoleproxy-1:null) Zone 1 is ready to launch console proxy
> 2013-09-13 23:09:18,810 DEBUG [agent.manager.AgentManagerImpl] 
> (AgentManager-Handler-4:null) SeqA 2-13482: Processing Seq 2-13482:  { Cmd , 
> MgmtId: -1, via: 2, Ver: v1, Flags: 11, 
> [{"com.cloud.agent.api.ConsoleProxyLoadReportCommand":{"_proxyVmId":2,"_loadInfo":"{\n
>   \"connections\": []\n}","wait":0}}] }
> 2013-09-13 23:09:18,817 DEBUG [agent.manager.AgentManagerImpl] 
> (AgentManager-Handler-4:null) SeqA 2-13482: Sending Seq 2-13482:  { Ans: , 
> MgmtId: 7175246184473, via: 2, Ver: v1, Flags: 100010, 
> [{"com.cloud.agent.api.AgentControlAnswer":{"result":true,"wait":0}}] }
> 2013-09-13 23:09:23,810 DEBUG [agent.manager.AgentManagerImpl] 
> (AgentManager-Handler-14:null) SeqA 2-13483: Processing Seq 2-13483:  { Cmd , 
> MgmtId: -1, via: 2, Ver: v1, Flags: 11, 
> [{"com.cloud.agent.api.ConsoleProxyLoadReportCommand":{"_proxyVmId":2,"_loadInfo":"{\n
>   \"connections\": []\n}","wait":0}}]                          @              
>                                                                               
>                       
> Agent log:
> 2013-09-13 17:46:38,637 INFO  [kvm.storage.LibvirtStorageAdaptor] 
> (agentRequest-Handler-2:null) Unprotecting and Removing RBD snapshots of 
> image 6789/07bf47b1-d5da-429f-903a-53517cd0e0fd prior to removing the image
> 2013-09-13 17:46:38,800 WARN  [cloud.agent.Agent] 
> (agentRequest-Handler-2:null) Caught:
> java.lang.ArrayIndexOutOfBoundsException: 0
>         at com.sun.jna.Structure.toArray(Structure.java:1042)
>         at com.sun.jna.Structure.toArray(Structure.java:1065)
>         at com.ceph.rbd.RbdImage.snapList(Unknown Source)
>         at 
> com.cloud.hypervisor.kvm.storage.LibvirtStorageAdaptor.deletePhysicalDisk(LibvirtStorageAdaptor.java:732)
>         at 
> com.cloud.hypervisor.kvm.storage.LibvirtStoragePool.deletePhysicalDisk(LibvirtStoragePool.java:158)
>         at 
> com.cloud.hypervisor.kvm.storage.KVMStorageProcessor.deleteVolume(KVMStorageProcessor.java:1129)
>         at 
> com.cloud.storage.resource.StorageSubsystemCommandHandlerBase.execute(StorageSubsystemCommandHandlerBase.java:114)
>         at 
> com.cloud.storage.resource.StorageSubsystemCommandHandlerBase.handleStorageCommands(StorageSubsystemCommandHandlerBase.java:53)
>         at 
> com.cloud.hypervisor.kvm.resource.LibvirtComputingResource.executeRequest(LibvirtComputingResource.java:1286)
>         at com.cloud.agent.Agent.processRequest(Agent.java:525)
>         at com.cloud.agent.Agent$AgentRequestHandler.doTask(Agent.java:852)
>         at com.cloud.utils.nio.Task.run(Task.java:83)
>         at 
> java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1146)
>         at 
> java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
>         at java.lang.Thread.run(Thread.java:679)
> ~



--
This message was sent by Atlassian JIRA
(v6.2#6252)

Reply via email to