You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@cloudstack.apache.org by we...@apache.org on 2013/11/27 14:48:50 UTC

git commit: updated refs/heads/4.2 to 04adfe4

Updated Branches:
  refs/heads/4.2 e23b10319 -> 04adfe431


CLOUDSTACK-5293: fix issue when collect vm disk statistics from iso
(cherry picked from commit f17f35eeb853ef170ba48d67ddd99d4f91f6a231)


Project: http://git-wip-us.apache.org/repos/asf/cloudstack/repo
Commit: http://git-wip-us.apache.org/repos/asf/cloudstack/commit/04adfe43
Tree: http://git-wip-us.apache.org/repos/asf/cloudstack/tree/04adfe43
Diff: http://git-wip-us.apache.org/repos/asf/cloudstack/diff/04adfe43

Branch: refs/heads/4.2
Commit: 04adfe4317bf36df6cc65bf47204c371b4dbcf2a
Parents: e23b103
Author: Wei Zhou <w....@leaseweb.com>
Authored: Wed Nov 27 14:48:03 2013 +0100
Committer: Wei Zhou <w....@leaseweb.com>
Committed: Wed Nov 27 14:48:03 2013 +0100

----------------------------------------------------------------------
 server/src/com/cloud/server/StatsCollector.java | 5 ++++-
 server/src/com/cloud/vm/UserVmManagerImpl.java  | 5 ++++-
 2 files changed, 8 insertions(+), 2 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/cloudstack/blob/04adfe43/server/src/com/cloud/server/StatsCollector.java
----------------------------------------------------------------------
diff --git a/server/src/com/cloud/server/StatsCollector.java b/server/src/com/cloud/server/StatsCollector.java
index 3be7461..2e836f0 100755
--- a/server/src/com/cloud/server/StatsCollector.java
+++ b/server/src/com/cloud/server/StatsCollector.java
@@ -434,7 +434,10 @@ public class StatsCollector extends ManagerBase implements ComponentMethodInterc
                         for (VmDiskStatsEntry vmDiskStat:vmDiskStats) {
                             SearchCriteria<VolumeVO> sc_volume = _volsDao.createSearchCriteria();
                             sc_volume.addAnd("path", SearchCriteria.Op.EQ, vmDiskStat.getPath());
-                            VolumeVO volume = _volsDao.search(sc_volume, null).get(0);
+                            List<VolumeVO> volumes = _volsDao.search(sc_volume, null);
+                            if ((volumes == null) || (volumes.size() == 0))
+                                break;
+                            VolumeVO volume = volumes.get(0);
                             VmDiskStatisticsVO previousVmDiskStats = _vmDiskStatsDao.findBy(userVm.getAccountId(), userVm.getDataCenterId(), vmId, volume.getId());
                             VmDiskStatisticsVO vmDiskStat_lock = _vmDiskStatsDao.lock(userVm.getAccountId(), userVm.getDataCenterId(), vmId, volume.getId());
 

http://git-wip-us.apache.org/repos/asf/cloudstack/blob/04adfe43/server/src/com/cloud/vm/UserVmManagerImpl.java
----------------------------------------------------------------------
diff --git a/server/src/com/cloud/vm/UserVmManagerImpl.java b/server/src/com/cloud/vm/UserVmManagerImpl.java
index d29d1ec..df11597 100755
--- a/server/src/com/cloud/vm/UserVmManagerImpl.java
+++ b/server/src/com/cloud/vm/UserVmManagerImpl.java
@@ -3554,7 +3554,10 @@ public class UserVmManagerImpl extends ManagerBase implements UserVmManager, Use
 	        for (VmDiskStatsEntry vmDiskStat:vmDiskStats) {
                     SearchCriteria<VolumeVO> sc_volume = _volsDao.createSearchCriteria();
                     sc_volume.addAnd("path", SearchCriteria.Op.EQ, vmDiskStat.getPath());
-                    VolumeVO volume = _volsDao.search(sc_volume, null).get(0);
+                    List<VolumeVO> volumes = _volsDao.search(sc_volume, null);
+                    if ((volumes == null) || (volumes.size() == 0))
+                        break;
+                    VolumeVO volume = volumes.get(0);
 	            VmDiskStatisticsVO previousVmDiskStats = _vmDiskStatsDao.findBy(userVm.getAccountId(), userVm.getDataCenterId(), userVm.getId(), volume.getId());
 	            VmDiskStatisticsVO vmDiskStat_lock = _vmDiskStatsDao.lock(userVm.getAccountId(), userVm.getDataCenterId(), userVm.getId(), volume.getId());