@InterfaceAudience.Private
 @InterfaceStability.Unstable
public class MemoryTimelineStore
extends org.apache.hadoop.service.AbstractService
TimelineStore. This
 implementation is for test purpose only. If users improperly instantiate it,
 they may encounter reading and writing history data in different memory
 store.
 
 The methods are synchronized to avoid concurrent modification on the memory.TimelineStore.SystemFilterorg.apache.hadoop.service.Service.STATETimelineReader.Field| Modifier and Type | Field and Description | 
|---|---|
| protected org.apache.hadoop.yarn.server.timeline.TimelineStoreMapAdapter<String,org.apache.hadoop.yarn.api.records.timeline.TimelineDomain> | domainById | 
| protected org.apache.hadoop.yarn.server.timeline.TimelineStoreMapAdapter<String,Set<org.apache.hadoop.yarn.api.records.timeline.TimelineDomain>> | domainsByOwner | 
| protected org.apache.hadoop.yarn.server.timeline.TimelineStoreMapAdapter<EntityIdentifier,org.apache.hadoop.yarn.api.records.timeline.TimelineEntity> | entities | 
| protected org.apache.hadoop.yarn.server.timeline.TimelineStoreMapAdapter<EntityIdentifier,Long> | entityInsertTimes | 
DEFAULT_LIMIT| Constructor and Description | 
|---|
| MemoryTimelineStore() | 
| MemoryTimelineStore(String name) | 
| Modifier and Type | Method and Description | 
|---|---|
| org.apache.hadoop.yarn.api.records.timeline.TimelineDomain | getDomain(String domainId)This method retrieves the domain information for a given ID. | 
| org.apache.hadoop.yarn.api.records.timeline.TimelineDomains | getDomains(String owner)This method retrieves all the domains that belong to a given owner. | 
| org.apache.hadoop.yarn.api.records.timeline.TimelineEntities | getEntities(String entityType,
           Long limit,
           Long windowStart,
           Long windowEnd,
           String fromId,
           Long fromTs,
           NameValuePair primaryFilter,
           Collection<NameValuePair> secondaryFilters,
           EnumSet<TimelineReader.Field> fields,
           TimelineDataManager.CheckAcl checkAcl)This method retrieves a list of entity information,  TimelineEntity,
 sorted by the starting timestamp for the entity, descending. | 
| org.apache.hadoop.yarn.api.records.timeline.TimelineEntity | getEntity(String entityId,
         String entityType,
         EnumSet<TimelineReader.Field> fieldsToRetrieve)This method retrieves the entity information for a given entity. | 
| org.apache.hadoop.yarn.api.records.timeline.TimelineEvents | getEntityTimelines(String entityType,
                  SortedSet<String> entityIds,
                  Long limit,
                  Long windowStart,
                  Long windowEnd,
                  Set<String> eventTypes)This method retrieves the events for a list of entities all of the same
 entity type. | 
| boolean | getServiceStopped() | 
| void | put(org.apache.hadoop.yarn.api.records.timeline.TimelineDomain domain)Store domain information to the timeline store. | 
| org.apache.hadoop.yarn.api.records.timeline.TimelinePutResponse | put(org.apache.hadoop.yarn.api.records.timeline.TimelineEntities data)Stores entity information to the timeline store. | 
| protected void | serviceStop() | 
close, getBlockers, getConfig, getFailureCause, getFailureState, getLifecycleHistory, getName, getServiceState, getStartTime, init, isInState, noteFailure, putBlocker, registerGlobalListener, registerServiceListener, removeBlocker, serviceInit, serviceStart, setConfig, start, stop, toString, unregisterGlobalListener, unregisterServiceListener, waitForServiceToStopprotected org.apache.hadoop.yarn.server.timeline.TimelineStoreMapAdapter<EntityIdentifier,org.apache.hadoop.yarn.api.records.timeline.TimelineEntity> entities
protected org.apache.hadoop.yarn.server.timeline.TimelineStoreMapAdapter<EntityIdentifier,Long> entityInsertTimes
protected org.apache.hadoop.yarn.server.timeline.TimelineStoreMapAdapter<String,org.apache.hadoop.yarn.api.records.timeline.TimelineDomain> domainById
public MemoryTimelineStore()
public MemoryTimelineStore(String name)
public boolean getServiceStopped()
protected void serviceStop()
                    throws Exception
serviceStop in class org.apache.hadoop.service.AbstractServiceExceptionpublic org.apache.hadoop.yarn.api.records.timeline.TimelineEntities getEntities(String entityType, Long limit, Long windowStart, Long windowEnd, String fromId, Long fromTs, NameValuePair primaryFilter, Collection<NameValuePair> secondaryFilters, EnumSet<TimelineReader.Field> fields, TimelineDataManager.CheckAcl checkAcl) throws IOException
TimelineReaderTimelineEntity,
 sorted by the starting timestamp for the entity, descending. The starting
 timestamp of an entity is a timestamp specified by the client. If it is not
 explicitly specified, it will be chosen by the store to be the earliest
 timestamp of the events received in the first put for the entity.getEntities in interface TimelineReaderentityType - The type of entities to return (required).limit - A limit on the number of entities to return. If null, defaults to
          TimelineReader.DEFAULT_LIMIT.windowStart - The earliest start timestamp to retrieve (exclusive). If null,
          defaults to retrieving all entities until the limit is reached.windowEnd - The latest start timestamp to retrieve (inclusive). If null,
          defaults to Long.MAX_VALUEfromId - If fromId is not null, retrieve entities earlier than and
          including the specified ID. If no start time is found for the
          specified ID, an empty list of entities will be returned. The
          windowEnd parameter will take precedence if the start time of this
          entity falls later than windowEnd.fromTs - If fromTs is not null, ignore entities that were inserted into the
          store after the given timestamp. The entity's insert timestamp
          used for this comparison is the store's system time when the first
          put for the entity was received (not the entity's start time).primaryFilter - Retrieves only entities that have the specified primary filter. If
          null, retrieves all entities. This is an indexed retrieval, and no
          entities that do not match the filter are scanned.secondaryFilters - Retrieves only entities that have exact matches for all the
          specified filters in their primary filters or other info. This is
          not an indexed retrieval, so all entities are scanned but only
          those matching the filters are returned.fields - Specifies which fields of the entity object to retrieve (see
          TimelineReader.Field). If the set of fields contains
          TimelineReader.Field.LAST_EVENT_ONLY and not TimelineReader.Field.EVENTS, the
          most recent event for each entity is retrieved. If null, retrieves
          all fields.TimelineEntities object.IOExceptionpublic org.apache.hadoop.yarn.api.records.timeline.TimelineEntity getEntity(String entityId, String entityType, EnumSet<TimelineReader.Field> fieldsToRetrieve)
TimelineReadergetEntity in interface TimelineReaderentityId - The entity whose information will be retrieved.entityType - The type of the entity.fieldsToRetrieve - Specifies which fields of the entity object to retrieve (see
          TimelineReader.Field). If the set of fields contains
          TimelineReader.Field.LAST_EVENT_ONLY and not TimelineReader.Field.EVENTS, the
          most recent event for each entity is retrieved. If null, retrieves
          all fields.TimelineEntity object.public org.apache.hadoop.yarn.api.records.timeline.TimelineEvents getEntityTimelines(String entityType, SortedSet<String> entityIds, Long limit, Long windowStart, Long windowEnd, Set<String> eventTypes)
TimelineReadergetEntityTimelines in interface TimelineReaderentityType - The type of entities to retrieve events for.entityIds - The entity IDs to retrieve events for.limit - A limit on the number of events to return for each entity. If
          null, defaults to TimelineReader.DEFAULT_LIMIT events per entity.windowStart - If not null, retrieves only events later than the given time
          (exclusive)windowEnd - If not null, retrieves only events earlier than the given time
          (inclusive)eventTypes - Restricts the events returned to the given types. If null, events
          of all types will be returned.TimelineEvents object.public org.apache.hadoop.yarn.api.records.timeline.TimelineDomain getDomain(String domainId) throws IOException
TimelineReadergetDomain in interface TimelineReaderTimelineDomain object.IOExceptionpublic org.apache.hadoop.yarn.api.records.timeline.TimelineDomains getDomains(String owner) throws IOException
TimelineReadergetDomains in interface TimelineReaderowner - the domain ownerTimelineDomains object.IOExceptionpublic org.apache.hadoop.yarn.api.records.timeline.TimelinePutResponse put(org.apache.hadoop.yarn.api.records.timeline.TimelineEntities data)
TimelineWriterput in interface TimelineWriterdata - a TimelineEntities object.TimelinePutResponse object.public void put(org.apache.hadoop.yarn.api.records.timeline.TimelineDomain domain)
         throws IOException
TimelineWriterput in interface TimelineWriterdomain - a TimelineDomain objectIOExceptionCopyright © 2008–2024 Apache Software Foundation. All rights reserved.