mirror of https://github.com/apache/cloudstack.git
214 lines
8.4 KiB
Java
214 lines
8.4 KiB
Java
/**
|
|
* Copyright (C) 2010 Cloud.com, Inc. All rights reserved.
|
|
*
|
|
* This software is licensed under the GNU General Public License v3 or later.
|
|
*
|
|
* It is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or any later version.
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
*/
|
|
package com.cloud.network.guru;
|
|
|
|
import java.util.Map;
|
|
|
|
import javax.ejb.Local;
|
|
import javax.naming.ConfigurationException;
|
|
|
|
import org.apache.log4j.Logger;
|
|
|
|
import com.cloud.configuration.Config;
|
|
import com.cloud.configuration.dao.ConfigurationDao;
|
|
import com.cloud.dc.DataCenter.NetworkType;
|
|
import com.cloud.dc.DataCenterVO;
|
|
import com.cloud.dc.dao.DataCenterDao;
|
|
import com.cloud.deploy.DeployDestination;
|
|
import com.cloud.deploy.DeploymentPlan;
|
|
import com.cloud.exception.InsufficientAddressCapacityException;
|
|
import com.cloud.exception.InsufficientVirtualNetworkCapcityException;
|
|
import com.cloud.hypervisor.Hypervisor.HypervisorType;
|
|
import com.cloud.network.Network;
|
|
import com.cloud.network.NetworkProfile;
|
|
import com.cloud.network.NetworkVO;
|
|
import com.cloud.network.Networks.AddressFormat;
|
|
import com.cloud.network.Networks.BroadcastDomainType;
|
|
import com.cloud.network.Networks.Mode;
|
|
import com.cloud.network.Networks.TrafficType;
|
|
import com.cloud.offering.NetworkOffering;
|
|
import com.cloud.offerings.dao.NetworkOfferingDao;
|
|
import com.cloud.user.Account;
|
|
import com.cloud.utils.component.ComponentLocator;
|
|
import com.cloud.utils.component.Inject;
|
|
import com.cloud.utils.exception.CloudRuntimeException;
|
|
import com.cloud.utils.net.NetUtils;
|
|
import com.cloud.vm.Nic;
|
|
import com.cloud.vm.NicProfile;
|
|
import com.cloud.vm.ReservationContext;
|
|
import com.cloud.vm.VirtualMachine;
|
|
import com.cloud.vm.VirtualMachineProfile;
|
|
|
|
@Local(value={NetworkGuru.class})
|
|
public class ControlNetworkGuru extends PodBasedNetworkGuru implements NetworkGuru {
|
|
private static final Logger s_logger = Logger.getLogger(ControlNetworkGuru.class);
|
|
@Inject DataCenterDao _dcDao;
|
|
@Inject NetworkOfferingDao _networkOfferingDao;
|
|
String _cidr;
|
|
String _gateway;
|
|
|
|
protected boolean canHandle(NetworkOffering offering) {
|
|
if (offering.isSystemOnly() && offering.getTrafficType() == TrafficType.Control) {
|
|
return true;
|
|
} else {
|
|
s_logger.trace("We only care about System only Control network");
|
|
return false;
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public Network design(NetworkOffering offering, DeploymentPlan plan, Network specifiedConfig, Account owner) {
|
|
if (!canHandle(offering)) {
|
|
return null;
|
|
}
|
|
|
|
NetworkVO config = new NetworkVO(offering.getTrafficType(), offering.getGuestType(), Mode.Static, BroadcastDomainType.LinkLocal, offering.getId(), plan.getDataCenterId(), Network.State.Setup);
|
|
config.setCidr(_cidr);
|
|
config.setGateway(_gateway);
|
|
|
|
return config;
|
|
}
|
|
|
|
protected ControlNetworkGuru() {
|
|
super();
|
|
}
|
|
|
|
@Override
|
|
public NicProfile allocate(Network config, NicProfile nic, VirtualMachineProfile<? extends VirtualMachine> vm) throws InsufficientVirtualNetworkCapcityException,
|
|
InsufficientAddressCapacityException {
|
|
|
|
NetworkOffering offering = _networkOfferingDao.findByIdIncludingRemoved(config.getNetworkOfferingId());
|
|
if (!canHandle(offering)) {
|
|
return null;
|
|
}
|
|
|
|
if(vm.getHypervisorType() == HypervisorType.VMware && vm.getType() != VirtualMachine.Type.DomainRouter) {
|
|
NicProfile nicProf = new NicProfile(Nic.ReservationStrategy.Create, null, null, null, null);
|
|
String mac = _networkMgr.getNextAvailableMacAddressInNetwork(config.getId());
|
|
nicProf.setMacAddress(mac);
|
|
return nicProf;
|
|
}
|
|
|
|
if (nic != null) {
|
|
throw new CloudRuntimeException("Does not support nic specification at this time: " + nic);
|
|
}
|
|
|
|
return new NicProfile(Nic.ReservationStrategy.Start, null, null, null, null);
|
|
}
|
|
|
|
@Override
|
|
public void deallocate(Network config, NicProfile nic, VirtualMachineProfile<? extends VirtualMachine> vm) {
|
|
}
|
|
|
|
@Override
|
|
public void reserve(NicProfile nic, Network config, VirtualMachineProfile<? extends VirtualMachine> vm, DeployDestination dest, ReservationContext context) throws InsufficientVirtualNetworkCapcityException,
|
|
InsufficientAddressCapacityException {
|
|
assert nic.getTrafficType() == TrafficType.Control;
|
|
|
|
if (dest.getHost().getHypervisorType() == HypervisorType.VMware && vm.getType() == VirtualMachine.Type.DomainRouter) {
|
|
if(dest.getDataCenter().getNetworkType() != NetworkType.Basic) {
|
|
super.reserve(nic, config, vm, dest, context);
|
|
|
|
String mac = _networkMgr.getNextAvailableMacAddressInNetwork(config.getId());
|
|
nic.setMacAddress(mac);
|
|
return;
|
|
} else {
|
|
// in basic mode and in VMware case, control network will be shared with guest network
|
|
String mac = _networkMgr.getNextAvailableMacAddressInNetwork(config.getId());
|
|
nic.setMacAddress(mac);
|
|
nic.setIp4Address("0.0.0.0");
|
|
nic.setNetmask("0.0.0.0");
|
|
nic.setFormat(AddressFormat.Ip4);
|
|
nic.setGateway("0.0.0.0");
|
|
return;
|
|
}
|
|
}
|
|
|
|
String ip = _dcDao.allocateLinkLocalIpAddress(dest.getDataCenter().getId(), dest.getPod().getId(), nic.getId(), context.getReservationId());
|
|
nic.setIp4Address(ip);
|
|
nic.setMacAddress(NetUtils.long2Mac(NetUtils.ip2Long(ip) | (14l << 40)));
|
|
nic.setNetmask("255.255.0.0");
|
|
nic.setFormat(AddressFormat.Ip4);
|
|
nic.setGateway(NetUtils.getLinkLocalGateway());
|
|
}
|
|
|
|
@Override
|
|
public boolean release(NicProfile nic, VirtualMachineProfile<? extends VirtualMachine> vm, String reservationId) {
|
|
assert nic.getTrafficType() == TrafficType.Control;
|
|
|
|
if (vm.getHypervisorType() == HypervisorType.VMware && vm.getType() == VirtualMachine.Type.DomainRouter) {
|
|
long dcId = vm.getVirtualMachine().getDataCenterIdToDeployIn();
|
|
DataCenterVO dcVo = _dcDao.findById(dcId);
|
|
if(dcVo.getNetworkType() != NetworkType.Basic) {
|
|
super.release(nic, vm, reservationId);
|
|
return true;
|
|
} else {
|
|
nic.deallocate();
|
|
return true;
|
|
}
|
|
}
|
|
|
|
_dcDao.releaseLinkLocalIpAddress(nic.getId(), reservationId);
|
|
|
|
nic.deallocate();
|
|
|
|
return true;
|
|
}
|
|
|
|
@Override
|
|
public Network implement(Network config, NetworkOffering offering, DeployDestination destination, ReservationContext context) throws InsufficientVirtualNetworkCapcityException {
|
|
assert config.getTrafficType() == TrafficType.Control : "Why are you sending this configuration to me " + config;
|
|
return config;
|
|
}
|
|
|
|
@Override
|
|
public void shutdown(NetworkProfile config, NetworkOffering offering) {
|
|
assert false : "Destroying a link local...Either you're out of your mind or something has changed.";
|
|
}
|
|
|
|
@Override
|
|
public boolean configure(String name, Map<String, Object> params) throws ConfigurationException {
|
|
super.configure(name, params);
|
|
|
|
ComponentLocator locator = ComponentLocator.getCurrentLocator();
|
|
|
|
ConfigurationDao configDao = locator.getDao(ConfigurationDao.class);
|
|
Map<String, String> dbParams = configDao.getConfiguration(params);
|
|
|
|
_cidr = dbParams.get(Config.ControlCidr);
|
|
if (_cidr == null) {
|
|
_cidr = "169.254.0.0/16";
|
|
}
|
|
|
|
_gateway = dbParams.get(Config.ControlGateway);
|
|
if (_gateway == null) {
|
|
_gateway = NetUtils.getLinkLocalGateway();
|
|
}
|
|
|
|
s_logger.info("Control network setup: cidr=" + _cidr + "; gateway = " + _gateway);
|
|
|
|
return true;
|
|
}
|
|
|
|
@Override
|
|
public boolean trash(Network config, NetworkOffering offering, Account owner) {
|
|
return true;
|
|
}
|
|
|
|
}
|