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;
}