/* * RHQ Management Platform * Copyright (C) 2005-2008 Red Hat, Inc. * All rights reserved. * * This program 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 version 2 of the License. * * 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, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ package org.rhq.enterprise.server.cloud; import java.util.List; import java.util.Map; import javax.ejb.Local; import org.rhq.core.domain.cloud.PartitionEvent; import org.rhq.core.domain.cloud.Server; import org.rhq.core.domain.cloud.composite.FailoverListComposite; import org.rhq.core.domain.resource.Agent; /** * @author Joseph Marques * @author Jay Shaughnessy */ @Local public interface FailoverListManagerLocal { /** * For an agent being deleted it is necessary to remove server lists for the agent. * <p> * This is primarily a test entry point as of 1.1.0 since we currently never delete agents from the database.<p> * * @param agent */ public void deleteServerListsForAgent(Agent agent); /** * For a server being deleted it is necessary to remove server lists details referencing the server. This may create a gap * in the server list ordinal values but that shouldn't matter, ordering is still preserved and we never access a specific * server by ordinal. * @param server */ public void deleteServerListDetailsForServer(int serverId); /** * Returns the existing server list for the specified agent, if it exists. * * @param agentName * @return the existing server list. Null if for any reason the list is not found. * @throws IllegalArgumentException if the agent is not registered */ FailoverListComposite getExistingForSingleAgent(String agentName); /** * Note that load is balanced as best as possible without a full refresh. * * @param event the partition event prompting this get/create. * @param agentName * @return the existing server list for the specified agent, if it exists, otherwise a newly generated server list is returned. * @throws IllegalArgumentException if the agent is not registered */ FailoverListComposite getForSingleAgent(PartitionEvent event, String agentName); /** * <p>Performs a full repartition, re-balancing the agent load on available servers and generating new server lists * for every agent. Previous server lists are deleted from the database and the new server lists are persisted.</p> * * <p> Currently assigns to all known agents. This seems right even though some "down" agents may be dead and never come back * online. That is really a separate design decision and is subject to change.</p> * * @return */ Map<Agent, FailoverListComposite> refresh(PartitionEvent event); /** * Primarily a testing entry point. In general use refresh(). * @param servers * @param agents * @return */ Map<Agent, FailoverListComposite> refresh(PartitionEvent event, List<Server> servers, List<Agent> agents); }