mirror of https://github.com/apache/cloudstack.git
CLOUDSTACK-4234:Dedicated Resources: When multiple dedication groups are chosen for VM deployment, dedicated resources belonging to both groups should be considered
Changes: - Do not add the dedicated resource to avoid list if it is present in the list of resources to consider for the deployment.
This commit is contained in:
parent
644f8173e9
commit
61bd96cb3e
|
|
@ -276,7 +276,7 @@ public class ExplicitDedicationProcessor extends AffinityProcessorBase implement
|
|||
List<HostVO> hostList = _hostDao.findByClusterId(dr.getClusterId());
|
||||
for (HostVO host : hostList) {
|
||||
DedicatedResourceVO dHost = _dedicatedDao.findByHostId(host.getId());
|
||||
if (dHost != null) {
|
||||
if (dHost != null && !dedicatedResources.contains(dHost)) {
|
||||
avoidList.addHost(host.getId());
|
||||
} else {
|
||||
includeList.addHost(host.getId());
|
||||
|
|
@ -291,7 +291,8 @@ public class ExplicitDedicationProcessor extends AffinityProcessorBase implement
|
|||
//add all cluster under this pod in includeList
|
||||
List<ClusterVO> clusterList = _clusterDao.listByPodId(dr.getPodId());
|
||||
for (ClusterVO cluster : clusterList) {
|
||||
if (_dedicatedDao.findByClusterId(cluster.getId()) != null) {
|
||||
DedicatedResourceVO dCluster = _dedicatedDao.findByClusterId(cluster.getId());
|
||||
if (dCluster != null && !dedicatedResources.contains(dCluster)) {
|
||||
avoidList.addCluster(cluster.getId());
|
||||
} else {
|
||||
includeList.addCluster(cluster.getId());
|
||||
|
|
@ -300,7 +301,8 @@ public class ExplicitDedicationProcessor extends AffinityProcessorBase implement
|
|||
//add all hosts inside this pod in includeList
|
||||
List<HostVO> hostList = _hostDao.findByPodId(dr.getPodId());
|
||||
for (HostVO host : hostList) {
|
||||
if (_dedicatedDao.findByHostId(host.getId()) != null) {
|
||||
DedicatedResourceVO dHost = _dedicatedDao.findByHostId(host.getId());
|
||||
if (dHost != null && !dedicatedResources.contains(dHost)) {
|
||||
avoidList.addHost(host.getId());
|
||||
} else {
|
||||
includeList.addHost(host.getId());
|
||||
|
|
@ -313,7 +315,8 @@ public class ExplicitDedicationProcessor extends AffinityProcessorBase implement
|
|||
//add all Pod under this data center in includeList
|
||||
List<HostPodVO> podList = _podDao.listByDataCenterId(dr.getDataCenterId());
|
||||
for (HostPodVO pod : podList) {
|
||||
if (_dedicatedDao.findByPodId(pod.getId()) != null) {
|
||||
DedicatedResourceVO dPod = _dedicatedDao.findByPodId(pod.getId());
|
||||
if (dPod != null && !dedicatedResources.contains(dPod)) {
|
||||
avoidList.addPod(pod.getId());
|
||||
} else {
|
||||
includeList.addPod(pod.getId());
|
||||
|
|
@ -321,7 +324,8 @@ public class ExplicitDedicationProcessor extends AffinityProcessorBase implement
|
|||
}
|
||||
List<ClusterVO> clusterList = _clusterDao.listClustersByDcId(dr.getDataCenterId());
|
||||
for (ClusterVO cluster : clusterList) {
|
||||
if (_dedicatedDao.findByClusterId(cluster.getId()) != null) {
|
||||
DedicatedResourceVO dCluster = _dedicatedDao.findByClusterId(cluster.getId());
|
||||
if (dCluster != null && !dedicatedResources.contains(dCluster)) {
|
||||
avoidList.addCluster(cluster.getId());
|
||||
} else {
|
||||
includeList.addCluster(cluster.getId());
|
||||
|
|
@ -330,7 +334,8 @@ public class ExplicitDedicationProcessor extends AffinityProcessorBase implement
|
|||
//add all hosts inside this in includeList
|
||||
List<HostVO> hostList = _hostDao.listByDataCenterId(dr.getDataCenterId());
|
||||
for (HostVO host : hostList) {
|
||||
if (_dedicatedDao.findByHostId(host.getId()) != null) {
|
||||
DedicatedResourceVO dHost = _dedicatedDao.findByHostId(host.getId());
|
||||
if (dHost != null && !dedicatedResources.contains(dHost)) {
|
||||
avoidList.addHost(host.getId());
|
||||
} else {
|
||||
includeList.addHost(host.getId());
|
||||
|
|
|
|||
Loading…
Reference in New Issue