All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.opencastproject.serviceregistry.api.ServiceRegistry Maven / Gradle / Ivy

/**
 * Licensed to The Apereo Foundation under one or more contributor license
 * agreements. See the NOTICE file distributed with this work for additional
 * information regarding copyright ownership.
 *
 *
 * The Apereo Foundation licenses this file to you under the Educational
 * Community License, Version 2.0 (the "License"); you may not use this file
 * except in compliance with the License. You may obtain a copy of the License
 * at:
 *
 *   http://opensource.org/licenses/ecl2.txt
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  See the
 * License for the specific language governing permissions and limitations under
 * the License.
 *
 */

package org.opencastproject.serviceregistry.api;

import org.opencastproject.job.api.Job;
import org.opencastproject.job.api.Job.Status;
import org.opencastproject.serviceregistry.api.SystemLoad.NodeLoad;
import org.opencastproject.util.NotFoundException;

import java.util.List;

/** Manages clustered services and the {@link Job}s they may create to enable asynchronous job handling. */
public interface ServiceRegistry {

  /**
   * Registers a host as a provider of Opencast services.
   *
   * @param host
   *          The base URL for this server
   * @param address
   *          The IP address of this host
   * @param nodeName
   *          Human readable description of this node
   * @param memory
   *          The allocated memory of this host
   * @param cores
   *          The available cores of this host
   * @param maxLoad
   *          the maximum load this host can support
   * @throws ServiceRegistryException
   *           if communication with the service registry fails
   */
  void registerHost(String host, String address, String nodeName, long memory, int cores, float maxLoad)
          throws ServiceRegistryException;

  /**
   * Removes an Opencast server from service.
   *
   * @param host
   *          The base URL for this server
   * @throws ServiceRegistryException
   *           if communication with the service registry fails
   */
  void unregisterHost(String host) throws ServiceRegistryException;

  /**
   * Enable an inactive host as a provider of Opencast services.
   *
   * @param host
   *          The base URL for this server
   * @throws NotFoundException
   *           if the host does not exist
   * @throws ServiceRegistryException
   *           if communication with the service registry fails
   */
  void enableHost(String host) throws ServiceRegistryException, NotFoundException;

  /**
   * Disables a Opencast server from service.
   *
   * @param host
   *          The base URL for this server
   * @throws NotFoundException
   *           if the host does not exist
   * @throws ServiceRegistryException
   *           if communication with the service registry fails
   */
  void disableHost(String host) throws ServiceRegistryException, NotFoundException;

  /**
   * Returns the maximum load that can be handled by the currently registered hosts.
   * Note that this load is *not* 1-to-1 equivalent with number of jobs.  A job may take up more than one load.
   *
   * @return the total load that can be processed concurrently
   * @throws ServiceRegistryException
   *           if communication with the service registry fails
   */
  SystemLoad getMaxLoads() throws ServiceRegistryException;

  /**
   * Returns the maximum load that can be handled by a given node.
   * Note that this load is *not* 1-to-1 equivalent with number of jobs.  A job may take up more than one load.
   *
   * @param host
   *          The base URL for this server
   *
   * @return the total load that can be processed concurrently on that node
   * @throws ServiceRegistryException
   *           if communication with the service registry fails
   */
  NodeLoad getMaxLoadOnNode(String host) throws ServiceRegistryException, NotFoundException;

  /**
   * Gets a map of hosts to the number of jobs currently loading that host
   *
   * @return the map of hosts to job counts
   */
  SystemLoad getCurrentHostLoads() throws ServiceRegistryException;

  /**
   * Gets the load value for the current host (ie, the host this service registry lives on
   *
   * @return the load value for this host
   */
  float getOwnLoad() throws ServiceRegistryException;

  /**
   * Registers a host to handle a specific type of job
   *
   * @param serviceType
   *          The job type
   * @param host
   *          The base URL where the service that can handle this service type can be found
   * @param path
   *          The path to the service endpoint
   * @return the service registration
   * @throws ServiceRegistryException
   *           if communication with the service registry fails
   */
  ServiceRegistration registerService(String serviceType, String host, String path) throws ServiceRegistryException;

  /**
   * Registers a host to handle a specific type of job
   *
   * @param serviceType
   *          The service type
   * @param host
   *          The base URL where the service that can handle this job type can be found
   * @param path
   *          The path to the service endpoint
   * @param jobProducer
   *          Whether this service registration produces {@link Job}s to track long running operations
   * @return the service registration
   * @throws ServiceRegistryException
   *           if communication with the service registry fails
   */
  ServiceRegistration registerService(String serviceType, String host, String path, boolean jobProducer)
          throws ServiceRegistryException;

  /**
   * Unregisters a host from handling a specific type of job
   *
   * @param serviceType
   *          The service type
   * @param host
   *          The base URL where the service that can handle this job type can be found
   * @throws ServiceRegistryException
   *           if communication with the service registry fails
   */
  void unRegisterService(String serviceType, String host) throws ServiceRegistryException;

  /**
   * Sets a registered host's maintenance status
   *
   * @param host
   *          The base URL where the service that can handle this service type can be found
   * @param maintenance
   *          the new maintenance status for this service
   * @throws ServiceRegistryException
   *           if communication with the service registry fails
   * @throws NotFoundException
   *           if the host does not exist
   */
  void setMaintenanceStatus(String host, boolean maintenance) throws ServiceRegistryException, NotFoundException;

  /**
   * Create and store a new job that will be dispatched as soon as possible. This is equivalent to calling
   * {@link #createJob(String, String, List, String, boolean)} with an empty argument list.
   * 

* Note that this job will be linked to the current job as its parent. Use * {@link #createJob(String, String, List, String, boolean, Job)} and pass null as the job if you don't * need the link. *

* * @param type * the type of service responsible for this job * @param operation * the operation for this service to run * @return the job * @throws ServiceRegistryException * if there is a problem creating the job */ Job createJob(String type, String operation) throws ServiceRegistryException; /** * Create and store a new job that will be dispatched as soon as possible. This is equivalent to calling * {@link #createJob(String, String, List, String, boolean)} with an empty argument list. *

* Note that this job will be linked to the current job as its parent. Use * {@link #createJob(String, String, List, String, boolean, Job)} and pass null as the job if you don't * need the link. *

* * @param type * the type of service responsible for this job * @param operation * the operation for this service to run * @param jobLoad * the load caused by this job, roughly equivalent to the number of cores used this job * @return the job * @throws ServiceRegistryException * if there is a problem creating the job */ Job createJob(String type, String operation, Float jobLoad) throws ServiceRegistryException; /** * Create and store a new job that will be dispatched as soon as possible. This is equivalent to calling * {@link #createJob(String, String, List, String, boolean)}. *

* Note that this job will be linked to the current job as its parent. Use * {@link #createJob(String, String, List, String, boolean, Job)} and pass null as the job if you don't * need the link. *

* * @param type * the type of service responsible for this job * @param operation * the operation for this service to run * @param arguments * the arguments to the operation * @return the job * @throws ServiceRegistryException * if there is a problem creating the job */ Job createJob(String type, String operation, List arguments) throws ServiceRegistryException; /** * Create and store a new job that will be dispatched as soon as possible. This is equivalent to calling * {@link #createJob(String, String, List, String, boolean)}. *

* Note that this job will be linked to the current job as its parent. Use * {@link #createJob(String, String, List, String, boolean, Job)} and pass null as the job if you don't * need the link. *

* * @param type * the type of service responsible for this job * @param operation * the operation for this service to run * @param arguments * the arguments to the operation * @param jobLoad * the load caused by this job, roughly equivalent to the number of cores used this job * @return the job * @throws ServiceRegistryException * if there is a problem creating the job */ Job createJob(String type, String operation, List arguments, Float jobLoad) throws ServiceRegistryException; /** * Create and store a new job that will be dispatched as soon as possible. This is equivalent to calling * {@link #createJob(String, String, List, String, boolean)}. The job will carry the given payload from the beginning. *

* Note that this job will be linked to the current job as its parent. Use * {@link #createJob(String, String, List, String, boolean, Job)} and pass null as the job if you don't * need the link. *

* * @param type * the type of service responsible for this job * @param operation * the operation for this service to run * @param arguments * the arguments to the operation * @param payload * an optional initial payload * @return the job * @throws ServiceRegistryException * if there is a problem creating the job */ Job createJob(String type, String operation, List arguments, String payload) throws ServiceRegistryException; /** * Create and store a new job that will be dispatched as soon as possible. This is equivalent to calling * {@link #createJob(String, String, List, String, boolean)}. The job will carry the given payload from the beginning. *

* Note that this job will be linked to the current job as its parent. Use * {@link #createJob(String, String, List, String, boolean, Job)} and pass null as the job if you don't * need the link. *

* * @param type * the type of service responsible for this job * @param operation * the operation for this service to run * @param arguments * the arguments to the operation * @param payload * an optional initial payload * @param jobLoad * the load caused by this job, roughly equivalent to the number of cores used this job * @return the job * @throws ServiceRegistryException * if there is a problem creating the job */ Job createJob(String type, String operation, List arguments, String payload, Float jobLoad) throws ServiceRegistryException; /** * Create and store a new job. If enqueueImmediately is true, the job will be in the * {@link Status#QUEUED} state and will be dispatched as soon as possible. Otherwise, it will be * {@link Status#INSTANTIATED}. *

* Note that this job will be linked to the current job as its parent. Use * {@link #createJob(String, String, List, String, boolean, Job)} and pass null as the job if you don't * need the link. *

* * @param type * the type of service responsible for this job * @param operation * the operation for this service to run * @param arguments * the arguments to the operation * @param payload * an optional initial payload * @param queueable * whether the job can be enqueued for dispatch. If false, the job's initial state will be * {@link Status#INSTANTIATED} and will not be dispatched. * @return the job * @throws ServiceRegistryException * if there is a problem creating the job */ Job createJob(String type, String operation, List arguments, String payload, boolean queueable) throws ServiceRegistryException; /** * Create and store a new job. If enqueueImmediately is true, the job will be in the * {@link Status#QUEUED} state and will be dispatched as soon as possible. Otherwise, it will be * {@link Status#INSTANTIATED}. *

* Note that this job will be linked to the current job as its parent. Use * {@link #createJob(String, String, List, String, boolean, Job)} and pass null as the job if you don't * need the link. *

* * @param type * the type of service responsible for this job * @param operation * the operation for this service to run * @param arguments * the arguments to the operation * @param payload * an optional initial payload * @param queueable * whether the job can be enqueued for dispatch. If false, the job's initial state will be * {@link Status#INSTANTIATED} and will not be dispatched. * @param jobLoad * the load caused by this job, roughly equivalent to the number of cores used this job * @return the job * @throws ServiceRegistryException * if there is a problem creating the job */ Job createJob(String type, String operation, List arguments, String payload, boolean queueable, Float jobLoad) throws ServiceRegistryException; /** * Create and store a new job. If enqueueImmediately is true, the job will be in the * {@link Status#QUEUED} state and will be dispatched as soon as possible. Otherwise, it will be * {@link Status#INSTANTIATED}. * * @param type * the type of service responsible for this job * @param operation * the operation for this service to run * @param arguments * the arguments to the operation * @param payload * an optional initial payload * @param queueable * whether the job can be enqueued for dispatch. If false, the job's initial state will be * {@link Status#INSTANTIATED} and will not be dispatched. * @param parentJob * the parent job * @return the job * @throws ServiceRegistryException * if there is a problem creating the job */ Job createJob(String type, String operation, List arguments, String payload, boolean queueable, Job parentJob) throws ServiceRegistryException; /** * Create and store a new job. If enqueueImmediately is true, the job will be in the * {@link Status#QUEUED} state and will be dispatched as soon as possible. Otherwise, it will be * {@link Status#INSTANTIATED}. * * @param type * the type of service responsible for this job * @param operation * the operation for this service to run * @param arguments * the arguments to the operation * @param payload * an optional initial payload * @param queueable * whether the job can be enqueued for dispatch. If false, the job's initial state will be * {@link Status#INSTANTIATED} and will not be dispatched. * @param parentJob * the parent job * @param jobLoad * the load caused by this job, roughly equivalent to the number of cores used this job * @return the job * @throws ServiceRegistryException * if there is a problem creating the job */ Job createJob(String type, String operation, List arguments, String payload, boolean queueable, Job parentJob, Float jobLoad) throws ServiceRegistryException; /** * Update the job in the database * * @param job * @return the updated job * @throws NotFoundException * if the job does not exist * @throws ServiceRegistryException * if there is a problem updating the job */ Job updateJob(Job job) throws NotFoundException, ServiceRegistryException; /** * Gets a receipt by its ID, or null if not found * * @param id * the job id * @return the job or null */ Job getJob(long id) throws NotFoundException, ServiceRegistryException; /** * Deletes the given jobs from the service registry * * @param ids * the job ids */ void removeJobs(List ids) throws NotFoundException, ServiceRegistryException; /** * Removes all jobs which do not have a parent job (except workflow instance jobs) and which have passed their * lifetime. * * @param lifetime * lifetime in days * @throws ServiceRegistryException * if removing the jobs fails */ void removeParentlessJobs(int lifetime) throws ServiceRegistryException; /** * Gets the current running job * * @return the current job */ Job getCurrentJob(); /** * Sets the current running job * * @param job * the current job */ void setCurrentJob(Job job); /** * Gets the list of jobs that match the specified parameters. * * @param serviceType * The jobs run by this type of service. If null, jobs from all hosts will be returned. * @param status * The status of the jobs. If null, jobs in all status will be returned. * @return the jobs matching these criteria * @throws ServiceRegistryException * if there is a problem accessing the service registry */ List getJobs(String serviceType, Status status) throws ServiceRegistryException; /** * Return the payload of all jobs for a specified operation type. * * @param operation * Operation type to get payload for * @return Serialized workflows * @throws ServiceRegistryException * if there is a problem accessing the service registry */ List getJobPayloads(String operation) throws ServiceRegistryException; /** * Return the payload of a specified number of jobs for a specified operation type. * * @param operation * Operation type to get payload for * @param limit * How many results to return * @param offset * Offset for the set of returned results * @return Serialized workflows * @throws ServiceRegistryException * if there is a problem accessing the service registry */ List getJobPayloads(String operation, int limit, int offset) throws ServiceRegistryException; /** * Return the number of jobs for a specified operation type. * * @param operation * Operation type to check for * @return Number of jobs for the specified operation type. * @throws ServiceRegistryException */ int getJobCount(String operation) throws ServiceRegistryException; /** * Get the list of active jobs. * * @return list of active jobs * @throws ServiceRegistryException if there is a problem accessing the service registry */ List getActiveJobs() throws ServiceRegistryException; /** * Get all child jobs from a job * * @param id * the parent job id * @return a list of the child jobs ordered by execution * @throws ServiceRegistryException * if there is a problem accessing the service registry */ List getChildJobs(long id) throws ServiceRegistryException; /** * Return a facility to record job incidents. * * @see org.opencastproject.job.api.Incident */ Incidents incident(); /** * Finds the service registrations for this kind of job, ordered by load (lightest to heaviest). * * @param serviceType * The type of service that must be handled by the hosts * @return A list of hosts that handle this job type, in order of their running and queued job load * @throws ServiceRegistryException * if there is a problem accessing the service registry */ List getServiceRegistrationsByLoad(String serviceType) throws ServiceRegistryException; /** * Finds the service registrations for this kind of job, including offline services and those in maintenance mode. * * @param serviceType * The type of service that must be handled by the hosts * @return A list of hosts that handle this job type * @throws ServiceRegistryException * if there is a problem accessing the service registry */ List getServiceRegistrationsByType(String serviceType) throws ServiceRegistryException; /** * Finds the service registrations on the given host, including offline services and those in maintenance mode. * * @param host * The host * @return A list of service registrations on a single host * @throws ServiceRegistryException * if there is a problem accessing the service registry */ List getServiceRegistrationsByHost(String host) throws ServiceRegistryException; /** * Finds a single service registration by host and type, even if the service is offline or in maintenance mode. * * @param serviceType * The type of service * @param host * the base URL of the host * @return The service registration, or null * @throws ServiceRegistryException * if there is a problem accessing the service registry */ ServiceRegistration getServiceRegistration(String serviceType, String host) throws ServiceRegistryException; /** * Finds all service registrations, including offline services and those in maintenance mode. * * @return A list of service registrations * @throws ServiceRegistryException * if there is a problem accessing the service registry */ List getServiceRegistrations() throws ServiceRegistryException; /** * Returns the service regstry's hostname. This can be used to fetch the list of services on the local host. * * @return The hostname that the service registry is running on. */ String getRegistryHostname(); /** * Finds all host registrations, including offline hosts and those in maintenance mode. * * @return A list of host registrations * @throws ServiceRegistryException * if there is a problem accessing the service registry */ List getHostRegistrations() throws ServiceRegistryException; /** * Finds host registration for the given hostname. * * @param hostname to lookup * @return host registrations * @throws ServiceRegistryException * if there is a problem accessing the service registry or the hostname is not found */ HostRegistration getHostRegistration(String hostname) throws ServiceRegistryException; /** * Gets performance and runtime statistics for each known service registration. * * @return the service statistics * @throws ServiceRegistryException * if there is a problem accessing the service registry */ List getServiceStatistics() throws ServiceRegistryException; /** * Gets the count of the number of abnormal services across the whole system. * * @return the count of abnormal services * @throws ServiceRegistryException */ long countOfAbnormalServices() throws ServiceRegistryException; /** * Count the number of jobs that match the specified parameters. * * @param serviceType * The jobs run by this type of service. If null, the returned count will refer to all types of jobs. * @param status * The status of the receipts. If null, the returned count will refer to jobs in any status. * @return the number of jobs * @throws ServiceRegistryException * if there is a problem accessing the service registry */ long count(String serviceType, Status status) throws ServiceRegistryException; /** * Count the number of jobs running the given operation in this {@link Status}. * * @param serviceType * The jobs run by this type of service * @param operation * the operation * @param status * The status of the jobs * @return the number of jobs * @throws ServiceRegistryException * if there is a problem accessing the service registry */ long countByOperation(String serviceType, String operation, Status status) throws ServiceRegistryException; /** * Count the number of jobs in this {@link Status} on this host * * @param serviceType * The jobs run by this type of service * @param host * The server that created and will be handling the job * @param status * The status of the jobs * @return the number of jobs * @throws ServiceRegistryException * if there is a problem accessing the service registry */ long countByHost(String serviceType, String host, Status status) throws ServiceRegistryException; /** * Count the number of jobs executing the given operation in this {@link Status} on this host. * * @param serviceType * The jobs run by this type of service * @param host * The server that created and will be handling the job * @param operation * the operation * @param status * The status of the jobs * @return the number of jobs * @throws ServiceRegistryException * if there is a problem accessing the service registry */ long count(String serviceType, String host, String operation, Status status) throws ServiceRegistryException; /** * Sets the given service to NORMAL state * * @param serviceType * the service type * @param host * the host * @throws NotFoundException * if the service does not exist */ void sanitize(String serviceType, String host) throws NotFoundException; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy