mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
usage: fix backup usage (#5259)
when creating usage record for backup usages in a period, we need to check if vm offering is changed. if vm offering is changed, create a new cloud usage record, otherwise update existing usage record. This PR fixes #4982
This commit is contained in:
parent
a5e7e08a6b
commit
7a7e449af6
@ -17,15 +17,13 @@
|
||||
|
||||
package com.cloud.usage.parser;
|
||||
|
||||
import java.text.DecimalFormat;
|
||||
import java.util.Date;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import javax.annotation.PostConstruct;
|
||||
import javax.inject.Inject;
|
||||
|
||||
import org.apache.cloudstack.backup.Backup;
|
||||
import org.apache.cloudstack.usage.UsageTypes;
|
||||
import org.apache.log4j.Logger;
|
||||
import org.springframework.stereotype.Component;
|
||||
@ -68,65 +66,33 @@ public class BackupUsageParser {
|
||||
return true;
|
||||
}
|
||||
|
||||
final Map<Long, BackupInfo> vmUsageMap = new HashMap<>();
|
||||
for (final UsageBackupVO usageBackup : usageBackups) {
|
||||
final Long vmId = usageBackup.getVmId();
|
||||
final Long zoneId = usageBackup.getZoneId();
|
||||
final Long offeringId = usageBackup.getBackupOfferingId();
|
||||
if (vmUsageMap.get(vmId) == null) {
|
||||
vmUsageMap.put(vmId, new BackupUsageParser.BackupInfo(new Backup.Metric(0L, 0L), zoneId, vmId, offeringId));
|
||||
Date createdDate = usageBackup.getCreated();
|
||||
Date removedDate = usageBackup.getRemoved();
|
||||
if (createdDate.before(startDate)) {
|
||||
createdDate = startDate;
|
||||
}
|
||||
final Backup.Metric metric = vmUsageMap.get(vmId).getMetric();
|
||||
metric.setBackupSize(metric.getBackupSize() + usageBackup.getSize());
|
||||
metric.setDataSize(metric.getDataSize() + usageBackup.getProtectedSize());
|
||||
}
|
||||
if (removedDate == null || removedDate.after(endDate)) {
|
||||
removedDate = endDate;
|
||||
}
|
||||
final long duration = (removedDate.getTime() - createdDate.getTime()) + 1;
|
||||
final float usage = duration / 1000f / 60f / 60f;
|
||||
DecimalFormat dFormat = new DecimalFormat("#.######");
|
||||
String usageDisplay = dFormat.format(usage);
|
||||
|
||||
for (final BackupInfo backupInfo : vmUsageMap.values()) {
|
||||
final Long vmId = backupInfo.getVmId();
|
||||
final Long zoneId = backupInfo.getZoneId();
|
||||
final Long offeringId = backupInfo.getOfferingId();
|
||||
final Double rawUsage = (double) backupInfo.getMetric().getBackupSize();
|
||||
final Double sizeGib = rawUsage / (1024.0 * 1024.0 * 1024.0);
|
||||
final String description = String.format("Backup usage VM ID: %d", vmId);
|
||||
final String usageDisplay = String.format("%.4f GiB", sizeGib);
|
||||
final Double rawUsage = (double) usageBackup.getSize();
|
||||
final String description = String.format("Backup usage VM ID: %d, backup offering: %d", vmId, offeringId);
|
||||
|
||||
final UsageVO usageRecord =
|
||||
new UsageVO(zoneId, account.getAccountId(), account.getDomainId(), description, usageDisplay,
|
||||
UsageTypes.BACKUP, rawUsage, vmId, null, offeringId, null, vmId,
|
||||
backupInfo.getMetric().getBackupSize(), backupInfo.getMetric().getDataSize(), startDate, endDate);
|
||||
new UsageVO(zoneId, account.getAccountId(), account.getDomainId(), description, usageDisplay + " Hrs",
|
||||
UsageTypes.BACKUP, new Double(usage), vmId, null, offeringId, null, vmId,
|
||||
usageBackup.getSize(), usageBackup.getProtectedSize(), startDate, endDate);
|
||||
s_usageDao.persist(usageRecord);
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
static class BackupInfo {
|
||||
Backup.Metric metric;
|
||||
Long zoneId;
|
||||
Long vmId;
|
||||
Long offeringId;
|
||||
|
||||
public BackupInfo(Backup.Metric metric, Long zoneId, Long vmId, Long offeringId) {
|
||||
this.metric = metric;
|
||||
this.zoneId = zoneId;
|
||||
this.vmId = vmId;
|
||||
this.offeringId = offeringId;
|
||||
}
|
||||
|
||||
public Backup.Metric getMetric() {
|
||||
return metric;
|
||||
}
|
||||
|
||||
public Long getZoneId() {
|
||||
return zoneId;
|
||||
}
|
||||
|
||||
public Long getVmId() {
|
||||
return vmId;
|
||||
}
|
||||
|
||||
public Long getOfferingId() {
|
||||
return offeringId;
|
||||
}
|
||||
}
|
||||
}
|
||||
Loading…
x
Reference in New Issue
Block a user