mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	Merge remote-tracking branch 'origin/4.12'
This commit is contained in:
		
						commit
						1c5244a0c5
					
				| @ -37,4 +37,6 @@ public interface DhcpServiceProvider extends NetworkElement { | |||||||
|     boolean removeDhcpSupportForSubnet(Network network) throws ResourceUnavailableException; |     boolean removeDhcpSupportForSubnet(Network network) throws ResourceUnavailableException; | ||||||
| 
 | 
 | ||||||
|     boolean setExtraDhcpOptions(Network network, long nicId, Map<Integer, String> dhcpOptions); |     boolean setExtraDhcpOptions(Network network, long nicId, Map<Integer, String> dhcpOptions); | ||||||
|  | 
 | ||||||
|  |     boolean removeDhcpEntry(Network network, NicProfile nic, VirtualMachineProfile vmProfile) throws ResourceUnavailableException; | ||||||
| } | } | ||||||
|  | |||||||
| @ -35,6 +35,15 @@ public class DhcpEntryCommand extends NetworkElementCommand { | |||||||
|     String duid; |     String duid; | ||||||
|     private boolean isDefault; |     private boolean isDefault; | ||||||
|     boolean executeInSequence = false; |     boolean executeInSequence = false; | ||||||
|  |     boolean remove; | ||||||
|  | 
 | ||||||
|  |     public boolean isRemove() { | ||||||
|  |         return remove; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void setRemove(boolean remove) { | ||||||
|  |         this.remove = remove; | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
|     protected DhcpEntryCommand() { |     protected DhcpEntryCommand() { | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -35,7 +35,7 @@ public class DhcpEntryConfigItem extends AbstractConfigItemFacade { | |||||||
|         final DhcpEntryCommand command = (DhcpEntryCommand) cmd; |         final DhcpEntryCommand command = (DhcpEntryCommand) cmd; | ||||||
| 
 | 
 | ||||||
|         final VmDhcpConfig vmDhcpConfig = new VmDhcpConfig(command.getVmName(), command.getVmMac(), command.getVmIpAddress(), command.getVmIp6Address(), command.getDuid(), command.getDefaultDns(), |         final VmDhcpConfig vmDhcpConfig = new VmDhcpConfig(command.getVmName(), command.getVmMac(), command.getVmIpAddress(), command.getVmIp6Address(), command.getDuid(), command.getDefaultDns(), | ||||||
|                 command.getDefaultRouter(), command.getStaticRoutes(), command.isDefault()); |                 command.getDefaultRouter(), command.getStaticRoutes(), command.isDefault(), command.isRemove()); | ||||||
| 
 | 
 | ||||||
|         return generateConfigItems(vmDhcpConfig); |         return generateConfigItems(vmDhcpConfig); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -30,12 +30,15 @@ public class VmDhcpConfig extends ConfigBase { | |||||||
|     private String staticRoutes; |     private String staticRoutes; | ||||||
|     private boolean defaultEntry; |     private boolean defaultEntry; | ||||||
| 
 | 
 | ||||||
|  |     // Indicate if the entry should be removed when set to true | ||||||
|  |     private boolean remove; | ||||||
|  | 
 | ||||||
|     public VmDhcpConfig() { |     public VmDhcpConfig() { | ||||||
|         super(VM_DHCP); |         super(VM_DHCP); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public VmDhcpConfig(String hostName, String macAddress, String ipv4Address, String ipv6Address, String ipv6Duid, String dnsAddresses, String defaultGateway, |     public VmDhcpConfig(String hostName, String macAddress, String ipv4Address, String ipv6Address, String ipv6Duid, String dnsAddresses, String defaultGateway, | ||||||
|             String staticRoutes, boolean defaultEntry) { |             String staticRoutes, boolean defaultEntry, boolean remove) { | ||||||
|         super(VM_DHCP); |         super(VM_DHCP); | ||||||
|         this.hostName = hostName; |         this.hostName = hostName; | ||||||
|         this.macAddress = macAddress; |         this.macAddress = macAddress; | ||||||
| @ -46,6 +49,7 @@ public class VmDhcpConfig extends ConfigBase { | |||||||
|         this.defaultGateway = defaultGateway; |         this.defaultGateway = defaultGateway; | ||||||
|         this.staticRoutes = staticRoutes; |         this.staticRoutes = staticRoutes; | ||||||
|         this.defaultEntry = defaultEntry; |         this.defaultEntry = defaultEntry; | ||||||
|  |         this.remove = remove; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public String getHostName() { |     public String getHostName() { | ||||||
| @ -64,6 +68,14 @@ public class VmDhcpConfig extends ConfigBase { | |||||||
|         this.macAddress = macAddress; |         this.macAddress = macAddress; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public boolean isRemove() { | ||||||
|  |         return remove; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void setRemove(boolean remove) { | ||||||
|  |         this.remove = remove; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     public String getIpv4Address() { |     public String getIpv4Address() { | ||||||
|         return ipv4Address; |         return ipv4Address; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -309,4 +309,8 @@ public interface NetworkOrchestrationService { | |||||||
|      */ |      */ | ||||||
|     boolean areRoutersRunning(final List<? extends VirtualRouter> routers); |     boolean areRoutersRunning(final List<? extends VirtualRouter> routers); | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * Remove entry from /etc/dhcphosts and /etc/hosts on virtual routers | ||||||
|  |      */ | ||||||
|  |     void cleanupNicDhcpDnsEntry(Network network, VirtualMachineProfile vmProfile, NicProfile nicProfile); | ||||||
| } | } | ||||||
|  | |||||||
| @ -2999,6 +2999,34 @@ public class NetworkOrchestrator extends ManagerBase implements NetworkOrchestra | |||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     /** | ||||||
|  |      * Cleanup entry on VR file specified by type | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public void cleanupNicDhcpDnsEntry(Network network, VirtualMachineProfile vmProfile, NicProfile nicProfile) { | ||||||
|  | 
 | ||||||
|  |         final List<Provider> networkProviders = getNetworkProviders(network.getId()); | ||||||
|  |         for (final NetworkElement element : networkElements) { | ||||||
|  |             if (networkProviders.contains(element.getProvider())) { | ||||||
|  |                 if (!_networkModel.isProviderEnabledInPhysicalNetwork(_networkModel.getPhysicalNetworkId(network), element.getProvider().getName())) { | ||||||
|  |                     throw new CloudRuntimeException("Service provider " + element.getProvider().getName() + " either doesn't exist or is not enabled in physical network id: " | ||||||
|  |                             + network.getPhysicalNetworkId()); | ||||||
|  |                 } | ||||||
|  |                 if (vmProfile.getType() == Type.User && element.getProvider() != null) { | ||||||
|  |                     if (_networkModel.areServicesSupportedInNetwork(network.getId(), Service.Dhcp) | ||||||
|  |                             && _networkModel.isProviderSupportServiceInNetwork(network.getId(), Service.Dhcp, element.getProvider()) && element instanceof DhcpServiceProvider) { | ||||||
|  |                         final DhcpServiceProvider sp = (DhcpServiceProvider) element; | ||||||
|  |                         try { | ||||||
|  |                             sp.removeDhcpEntry(network, nicProfile, vmProfile); | ||||||
|  |                         } catch (ResourceUnavailableException e) { | ||||||
|  |                             s_logger.error("Failed to remove dhcp-dns entry due to: ", e); | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     /** |     /** | ||||||
|      * rollingRestartRouters performs restart of routers of a network by first |      * rollingRestartRouters performs restart of routers of a network by first | ||||||
|      * deploying a new VR and then destroying old VRs in rolling fashion. For |      * deploying a new VR and then destroying old VRs in rolling fashion. For | ||||||
|  | |||||||
| @ -185,4 +185,9 @@ public class BaremetalDhcpElement extends AdapterBase implements DhcpServiceProv | |||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     @Override | ||||||
|  |     public boolean removeDhcpEntry(Network network, NicProfile nic, VirtualMachineProfile vmProfile) throws ResourceUnavailableException { | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -379,4 +379,9 @@ public class ContrailElementImpl extends AdapterBase | |||||||
|     public boolean setExtraDhcpOptions(Network network, long nicId, Map<Integer, String> dhcpOptions) { |     public boolean setExtraDhcpOptions(Network network, long nicId, Map<Integer, String> dhcpOptions) { | ||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public boolean removeDhcpEntry(Network network, NicProfile nic, VirtualMachineProfile vmProfile) { | ||||||
|  |         return false; | ||||||
|  |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -2078,12 +2078,12 @@ public class JuniperSrxResource implements ServerResource { | |||||||
|                         xml = replaceXmlValue(xml, "rule-set", _privateZone); |                         xml = replaceXmlValue(xml, "rule-set", _privateZone); | ||||||
|                         xml = replaceXmlValue(xml, "from-zone", _privateZone); |                         xml = replaceXmlValue(xml, "from-zone", _privateZone); | ||||||
|                         xml = replaceXmlValue(xml, "rule-name", ruleName_private); |                         xml = replaceXmlValue(xml, "rule-name", ruleName_private); | ||||||
|                     } |  | ||||||
| 
 | 
 | ||||||
|                         if (!sendRequestAndCheckResponse(command, xml, "name", ruleName_private)) |                         if (!sendRequestAndCheckResponse(command, xml, "name", ruleName_private)) | ||||||
|                         { |                         { | ||||||
|                             throw new ExecutionException("Failed to delete trust static NAT rule from public IP " + publicIp + " to private IP " + privateIp); |                             throw new ExecutionException("Failed to delete trust static NAT rule from public IP " + publicIp + " to private IP " + privateIp); | ||||||
|                         } |                         } | ||||||
|  |                     } | ||||||
|                     return true; |                     return true; | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
| @ -3568,6 +3568,7 @@ public class JuniperSrxResource implements ServerResource { | |||||||
| 
 | 
 | ||||||
|             case CHECK_IF_EXISTS: |             case CHECK_IF_EXISTS: | ||||||
|             case CHECK_IF_IN_USE: |             case CHECK_IF_IN_USE: | ||||||
|  |             case CHECK_PRIVATE_IF_EXISTS: | ||||||
|                 assert (keyAndValue != null && keyAndValue.length == 2) : "If the SrxCommand is " + command + ", both a key and value must be specified."; |                 assert (keyAndValue != null && keyAndValue.length == 2) : "If the SrxCommand is " + command + ", both a key and value must be specified."; | ||||||
| 
 | 
 | ||||||
|                 key = keyAndValue[0]; |                 key = keyAndValue[0]; | ||||||
|  | |||||||
| @ -946,6 +946,34 @@ NetworkMigrationResponder, AggregatedCommandExecutor, RedundantResource, DnsServ | |||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     @Override | ||||||
|  |     public boolean removeDhcpEntry(Network network, NicProfile nic, VirtualMachineProfile vmProfile) throws ResourceUnavailableException { | ||||||
|  |         boolean result = true; | ||||||
|  |         if (canHandle(network, Service.Dhcp)) { | ||||||
|  |             if (vmProfile.getType() != VirtualMachine.Type.User) { | ||||||
|  |                 return false; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             final List<DomainRouterVO> routers = _routerDao.listByNetworkAndRole(network.getId(), VirtualRouter.Role.VIRTUAL_ROUTER); | ||||||
|  | 
 | ||||||
|  |             if (CollectionUtils.isEmpty(routers)) { | ||||||
|  |                 throw new ResourceUnavailableException("Can't find at least one router!", DataCenter.class, network.getDataCenterId()); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             final DataCenterVO dcVO = _dcDao.findById(network.getDataCenterId()); | ||||||
|  |             final NetworkTopology networkTopology = networkTopologyContext.retrieveNetworkTopology(dcVO); | ||||||
|  | 
 | ||||||
|  |             for (final DomainRouterVO domainRouterVO : routers) { | ||||||
|  |                 if (domainRouterVO.getState() != VirtualMachine.State.Running) { | ||||||
|  |                     continue; | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 result = result && networkTopology.removeDhcpEntry(network, nic, vmProfile, domainRouterVO); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     @Override |     @Override | ||||||
|     public boolean removeDnsSupportForSubnet(Network network) throws ResourceUnavailableException { |     public boolean removeDnsSupportForSubnet(Network network) throws ResourceUnavailableException { | ||||||
|         // Ignore if virtual router is already dhcp provider |         // Ignore if virtual router is already dhcp provider | ||||||
|  | |||||||
| @ -211,7 +211,7 @@ public class CommandSetupHelper { | |||||||
|         cmds.addCommand("users", cmd); |         cmds.addCommand("users", cmd); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public void createDhcpEntryCommand(final VirtualRouter router, final UserVm vm, final NicVO nic, final Commands cmds) { |     public void createDhcpEntryCommand(final VirtualRouter router, final UserVm vm, final NicVO nic, boolean remove, final Commands cmds) { | ||||||
|         final DhcpEntryCommand dhcpCommand = new DhcpEntryCommand(nic.getMacAddress(), nic.getIPv4Address(), vm.getHostName(), nic.getIPv6Address(), |         final DhcpEntryCommand dhcpCommand = new DhcpEntryCommand(nic.getMacAddress(), nic.getIPv4Address(), vm.getHostName(), nic.getIPv6Address(), | ||||||
|                 _networkModel.getExecuteInSeqNtwkElmtCmd()); |                 _networkModel.getExecuteInSeqNtwkElmtCmd()); | ||||||
| 
 | 
 | ||||||
| @ -229,6 +229,7 @@ public class CommandSetupHelper { | |||||||
|         dhcpCommand.setDefaultDns(ipaddress); |         dhcpCommand.setDefaultDns(ipaddress); | ||||||
|         dhcpCommand.setDuid(NetUtils.getDuidLL(nic.getMacAddress())); |         dhcpCommand.setDuid(NetUtils.getDuidLL(nic.getMacAddress())); | ||||||
|         dhcpCommand.setDefault(nic.isDefaultNic()); |         dhcpCommand.setDefault(nic.isDefaultNic()); | ||||||
|  |         dhcpCommand.setRemove(remove); | ||||||
| 
 | 
 | ||||||
|         dhcpCommand.setAccessDetail(NetworkElementCommand.ROUTER_IP, _routerControlHelper.getRouterControlIp(router.getId())); |         dhcpCommand.setAccessDetail(NetworkElementCommand.ROUTER_IP, _routerControlHelper.getRouterControlIp(router.getId())); | ||||||
|         dhcpCommand.setAccessDetail(NetworkElementCommand.ROUTER_NAME, router.getInstanceName()); |         dhcpCommand.setAccessDetail(NetworkElementCommand.ROUTER_NAME, router.getInstanceName()); | ||||||
| @ -622,7 +623,7 @@ public class CommandSetupHelper { | |||||||
|             final NicVO nic = _nicDao.findByNtwkIdAndInstanceId(guestNetworkId, vm.getId()); |             final NicVO nic = _nicDao.findByNtwkIdAndInstanceId(guestNetworkId, vm.getId()); | ||||||
|             if (nic != null) { |             if (nic != null) { | ||||||
|                 s_logger.debug("Creating dhcp entry for vm " + vm + " on domR " + router + "."); |                 s_logger.debug("Creating dhcp entry for vm " + vm + " on domR " + router + "."); | ||||||
|                 createDhcpEntryCommand(router, vm, nic, cmds); |                 createDhcpEntryCommand(router, vm, nic, false, cmds); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -36,6 +36,8 @@ public class DhcpEntryRules extends RuleApplier { | |||||||
|     private final VirtualMachineProfile _profile; |     private final VirtualMachineProfile _profile; | ||||||
|     private final DeployDestination _destination; |     private final DeployDestination _destination; | ||||||
| 
 | 
 | ||||||
|  |     private boolean remove; | ||||||
|  | 
 | ||||||
|     private NicVO _nicVo; |     private NicVO _nicVo; | ||||||
|     private UserVmVO _userVM; |     private UserVmVO _userVM; | ||||||
| 
 | 
 | ||||||
| @ -77,4 +79,12 @@ public class DhcpEntryRules extends RuleApplier { | |||||||
|     public UserVmVO getUserVM() { |     public UserVmVO getUserVM() { | ||||||
|         return _userVM; |         return _userVM; | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     public boolean isRemove() { | ||||||
|  |         return remove; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void setRemove(boolean remove) { | ||||||
|  |         this.remove = remove; | ||||||
|  |     } | ||||||
| } | } | ||||||
| @ -4432,10 +4432,16 @@ public class UserVmManagerImpl extends ManagerBase implements UserVmManager, Vir | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         List<NicVO> nics = _nicDao.listByVmId(vm.getId()); |         final List<NicVO> nics = _nicDao.listByVmId(vm.getId()); | ||||||
|         for (NicVO nic : nics) { |         for (final NicVO nic : nics) { | ||||||
|             NetworkVO network = _networkDao.findById(nic.getNetworkId()); |             final NetworkVO network = _networkDao.findById(nic.getNetworkId()); | ||||||
|             if (network.getTrafficType() == TrafficType.Guest) { |             if (network != null && network.getTrafficType() == TrafficType.Guest) { | ||||||
|  |                 final String nicIp = Strings.isNullOrEmpty(nic.getIPv4Address()) ? nic.getIPv6Address() : nic.getIPv4Address(); | ||||||
|  |                 if (!Strings.isNullOrEmpty(nicIp)) { | ||||||
|  |                     NicProfile nicProfile = new NicProfile(nic.getIPv4Address(), nic.getIPv6Address(), nic.getMacAddress()); | ||||||
|  |                     nicProfile.setId(nic.getId()); | ||||||
|  |                     _networkMgr.cleanupNicDhcpDnsEntry(network, profile, nicProfile); | ||||||
|  |                 } | ||||||
|                 if (nic.getBroadcastUri() != null && nic.getBroadcastUri().getScheme().equals("pvlan")) { |                 if (nic.getBroadcastUri() != null && nic.getBroadcastUri().getScheme().equals("pvlan")) { | ||||||
|                     NicProfile nicProfile = new NicProfile(nic, network, nic.getBroadcastUri(), nic.getIsolationUri(), 0, false, "pvlan-nic"); |                     NicProfile nicProfile = new NicProfile(nic, network, nic.getBroadcastUri(), nic.getIsolationUri(), 0, false, "pvlan-nic"); | ||||||
|                     setupVmForPvlan(false, vm.getHostId(), nicProfile); |                     setupVmForPvlan(false, vm.getHostId(), nicProfile); | ||||||
|  | |||||||
| @ -172,6 +172,21 @@ public class AdvancedNetworkTopology extends BasicNetworkTopology { | |||||||
|         return applyRules(network, router, typeString, isPodLevelException, podId, failWhenDisconnect, new RuleApplierWrapper<RuleApplier>(dhcpRules)); |         return applyRules(network, router, typeString, isPodLevelException, podId, failWhenDisconnect, new RuleApplierWrapper<RuleApplier>(dhcpRules)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     @Override | ||||||
|  |     public boolean removeDhcpEntry(Network network, NicProfile nic, VirtualMachineProfile profile, VirtualRouter virtualRouter) throws ResourceUnavailableException { | ||||||
|  |         s_logger.debug("REMOVE VPC DHCP ENTRY RULES"); | ||||||
|  | 
 | ||||||
|  |         final String typeString = "dhcp entry"; | ||||||
|  |         final Long podId = null; | ||||||
|  |         final boolean isPodLevelException = false; | ||||||
|  |         final boolean failWhenDisconnect = false; | ||||||
|  | 
 | ||||||
|  |         final DhcpEntryRules dhcpRules = new DhcpEntryRules(network, nic, profile, null); | ||||||
|  |         dhcpRules.setRemove(true); | ||||||
|  | 
 | ||||||
|  |         return applyRules(network, virtualRouter, typeString, isPodLevelException, podId, failWhenDisconnect, new RuleApplierWrapper<RuleApplier>(dhcpRules)); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     @Override |     @Override | ||||||
|     public boolean associatePublicIP(final Network network, final List<? extends PublicIpAddress> ipAddresses, final VirtualRouter router) |     public boolean associatePublicIP(final Network network, final List<? extends PublicIpAddress> ipAddresses, final VirtualRouter router) | ||||||
|             throws ResourceUnavailableException { |             throws ResourceUnavailableException { | ||||||
|  | |||||||
| @ -80,8 +80,9 @@ public class AdvancedNetworkVisitor extends BasicNetworkVisitor { | |||||||
|         final Commands commands = new Commands(Command.OnError.Stop); |         final Commands commands = new Commands(Command.OnError.Stop); | ||||||
|         final NicVO nicVo = dhcp.getNicVo(); |         final NicVO nicVo = dhcp.getNicVo(); | ||||||
|         final UserVmVO userVM = dhcp.getUserVM(); |         final UserVmVO userVM = dhcp.getUserVM(); | ||||||
|  |         final boolean remove = dhcp.isRemove(); | ||||||
| 
 | 
 | ||||||
|         _commandSetupHelper.createDhcpEntryCommand(router, userVM, nicVo, commands); |         _commandSetupHelper.createDhcpEntryCommand(router, userVM, nicVo, remove, commands); | ||||||
| 
 | 
 | ||||||
|         return _networkGeneralHelper.sendCommandsToRouter(router, commands); |         return _networkGeneralHelper.sendCommandsToRouter(router, commands); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -442,4 +442,25 @@ public class BasicNetworkTopology implements NetworkTopology { | |||||||
|         } |         } | ||||||
|         return result; |         return result; | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public boolean removeDhcpEntry(Network network, NicProfile nic, VirtualMachineProfile profile, VirtualRouter virtualRouter) throws ResourceUnavailableException { | ||||||
|  |         s_logger.debug("REMOVING DHCP ENTRY RULE"); | ||||||
|  | 
 | ||||||
|  |         final String typeString = "dhcp entry"; | ||||||
|  |         final Long podId = profile.getVirtualMachine().getPodIdToDeployIn(); | ||||||
|  |         boolean isPodLevelException = false; | ||||||
|  | 
 | ||||||
|  |         if (podId != null && profile.getVirtualMachine().getType() == VirtualMachine.Type.User && network.getTrafficType() == TrafficType.Guest | ||||||
|  |                 && network.getGuestType() == Network.GuestType.Shared) { | ||||||
|  |             isPodLevelException = true; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         final boolean failWhenDisconnect = false; | ||||||
|  | 
 | ||||||
|  |         final DhcpEntryRules dhcpRules = new DhcpEntryRules(network, nic, profile, null); | ||||||
|  |         dhcpRules.setRemove(true); | ||||||
|  | 
 | ||||||
|  |         return applyRules(network, virtualRouter, typeString, isPodLevelException, podId, failWhenDisconnect, new RuleApplierWrapper<RuleApplier>(dhcpRules)); | ||||||
|  |     } | ||||||
| } | } | ||||||
| @ -196,9 +196,10 @@ public class BasicNetworkVisitor extends NetworkTopologyVisitor { | |||||||
|         final NicVO nicVo = dhcp.getNicVo(); |         final NicVO nicVo = dhcp.getNicVo(); | ||||||
|         final UserVmVO userVM = dhcp.getUserVM(); |         final UserVmVO userVM = dhcp.getUserVM(); | ||||||
|         final DeployDestination destination = dhcp.getDestination(); |         final DeployDestination destination = dhcp.getDestination(); | ||||||
|  |         final boolean remove = dhcp.isRemove(); | ||||||
| 
 | 
 | ||||||
|         if (router.getPodIdToDeployIn().longValue() == destination.getPod().getId()) { |         if (router.getPodIdToDeployIn().longValue() == destination.getPod().getId()) { | ||||||
|             _commandSetupHelper.createDhcpEntryCommand(router, userVM, nicVo, commands); |             _commandSetupHelper.createDhcpEntryCommand(router, userVM, nicVo, remove, commands); | ||||||
| 
 | 
 | ||||||
|             return _networkGeneralHelper.sendCommandsToRouter(router, commands); |             return _networkGeneralHelper.sendCommandsToRouter(router, commands); | ||||||
|         } |         } | ||||||
|  | |||||||
| @ -87,4 +87,6 @@ public interface NetworkTopology { | |||||||
| 
 | 
 | ||||||
|     boolean applyRules(final Network network, final VirtualRouter router, final String typeString, final boolean isPodLevelException, final Long podId, |     boolean applyRules(final Network network, final VirtualRouter router, final String typeString, final boolean isPodLevelException, final Long podId, | ||||||
|             final boolean failWhenDisconnect, RuleApplierWrapper<RuleApplier> ruleApplier) throws ResourceUnavailableException; |             final boolean failWhenDisconnect, RuleApplierWrapper<RuleApplier> ruleApplier) throws ResourceUnavailableException; | ||||||
|  | 
 | ||||||
|  |     boolean removeDhcpEntry(final Network network, final NicProfile nic, final VirtualMachineProfile profile, final VirtualRouter virtualRouter) throws ResourceUnavailableException; | ||||||
| } | } | ||||||
| @ -925,6 +925,10 @@ public class MockNetworkManagerImpl extends ManagerBase implements NetworkOrches | |||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     @Override | ||||||
|  |     public void cleanupNicDhcpDnsEntry(Network network, VirtualMachineProfile vmProfile, NicProfile nicProfile) { | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     @Override |     @Override | ||||||
|     public void finalizeUpdateInSequence(Network network, boolean success) { |     public void finalizeUpdateInSequence(Network network, boolean success) { | ||||||
|         return; |         return; | ||||||
|  | |||||||
| @ -16,6 +16,7 @@ | |||||||
| # under the License. | # under the License. | ||||||
| import CsHelper | import CsHelper | ||||||
| import logging | import logging | ||||||
|  | import os | ||||||
| from netaddr import * | from netaddr import * | ||||||
| from random import randint | from random import randint | ||||||
| from CsGuestNetwork import CsGuestNetwork | from CsGuestNetwork import CsGuestNetwork | ||||||
| @ -46,8 +47,8 @@ class CsDhcp(CsDataBag): | |||||||
|         for item in self.dbag: |         for item in self.dbag: | ||||||
|             if item == "id": |             if item == "id": | ||||||
|                 continue |                 continue | ||||||
|  |             if not self.dbag[item]['remove']: | ||||||
|                 self.add(self.dbag[item]) |                 self.add(self.dbag[item]) | ||||||
|         self.write_hosts() |  | ||||||
| 
 | 
 | ||||||
|         self.configure_server() |         self.configure_server() | ||||||
| 
 | 
 | ||||||
| @ -64,6 +65,8 @@ class CsDhcp(CsDataBag): | |||||||
|         if restart_dnsmasq: |         if restart_dnsmasq: | ||||||
|             self.delete_leases() |             self.delete_leases() | ||||||
| 
 | 
 | ||||||
|  |         self.write_hosts() | ||||||
|  | 
 | ||||||
|         if not self.cl.is_redundant() or self.cl.is_master(): |         if not self.cl.is_redundant() or self.cl.is_master(): | ||||||
|             if restart_dnsmasq: |             if restart_dnsmasq: | ||||||
|                 CsHelper.service("dnsmasq", "restart") |                 CsHelper.service("dnsmasq", "restart") | ||||||
| @ -114,10 +117,28 @@ class CsDhcp(CsDataBag): | |||||||
|             idx += 1 |             idx += 1 | ||||||
| 
 | 
 | ||||||
|     def delete_leases(self): |     def delete_leases(self): | ||||||
|  |         macs_dhcphosts = [] | ||||||
|  |         interfaces = filter(lambda x: x.startswith('eth'), os.listdir('/sys/class/net')) | ||||||
|         try: |         try: | ||||||
|             open(LEASES, 'w').close() |             logging.info("Attempting to delete entries from dnsmasq.leases file for VMs which are not on dhcphosts file") | ||||||
|         except IOError: |             for host in open(DHCP_HOSTS): | ||||||
|             return |                 macs_dhcphosts.append(host.split(',')[0]) | ||||||
|  | 
 | ||||||
|  |             removed = 0 | ||||||
|  |             for leaseline in open(LEASES): | ||||||
|  |                 lease = leaseline.split(' ') | ||||||
|  |                 mac = lease[1] | ||||||
|  |                 ip = lease[2] | ||||||
|  |                 if mac not in macs_dhcphosts: | ||||||
|  |                     for interface in interfaces: | ||||||
|  |                         cmd = "dhcp_release %s %s %s" % (interface, ip, mac) | ||||||
|  |                         logging.info(cmd) | ||||||
|  |                         CsHelper.execute(cmd) | ||||||
|  |                     removed = removed + 1 | ||||||
|  |                     self.del_host(ip) | ||||||
|  |             logging.info("Deleted %s entries from dnsmasq.leases file" % str(removed)) | ||||||
|  |         except Exception as e: | ||||||
|  |             logging.error("Caught error while trying to delete entries from dnsmasq.leases file: %s" % e) | ||||||
| 
 | 
 | ||||||
|     def preseed(self): |     def preseed(self): | ||||||
|         self.add_host("127.0.0.1", "localhost %s" % CsHelper.get_hostname()) |         self.add_host("127.0.0.1", "localhost %s" % CsHelper.get_hostname()) | ||||||
| @ -170,3 +191,7 @@ class CsDhcp(CsDataBag): | |||||||
| 
 | 
 | ||||||
|     def add_host(self, ip, hosts): |     def add_host(self, ip, hosts): | ||||||
|         self.hosts[ip] = hosts |         self.hosts[ip] = hosts | ||||||
|  | 
 | ||||||
|  |     def del_host(self, ip): | ||||||
|  |         if ip in self.hosts: | ||||||
|  |             self.hosts.pop(ip) | ||||||
|  | |||||||
| @ -15,6 +15,7 @@ | |||||||
| # specific language governing permissions and limitations | # specific language governing permissions and limitations | ||||||
| # under the License. | # under the License. | ||||||
| 
 | 
 | ||||||
|  | import logging | ||||||
| from netaddr import * | from netaddr import * | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @ -36,6 +37,9 @@ def merge(dbag, data): | |||||||
|                 remove_keys.add(key) |                 remove_keys.add(key) | ||||||
|                 break |                 break | ||||||
| 
 | 
 | ||||||
|  |         if data['remove'] and key not in remove_keys: | ||||||
|  |             remove_keys.add(key) | ||||||
|  | 
 | ||||||
|         for remove_key in remove_keys: |         for remove_key in remove_keys: | ||||||
|             del(dbag[remove_key]) |             del(dbag[remove_key]) | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user