-
Notifications
You must be signed in to change notification settings - Fork 0
Scheduling
The Priority Operation Processing (POP) Brain is responsible for authentication, data submission (CRUD), data storage, client callbacks and scheduling workflows.
-
Authorized Customer Data Visibility
-
API Endpoints
-
Scheduling
-
Data Management
-
Metrics, Alerts
-
linkId for connecting all Data Objects
-
Agenda Retries
-
Configurable
-
Retries at the point of failure
-
-
API Gateway
-
AWS Authorizer
-
Lambda
-
SQS
-
Dynamo
-
CloudFormation
-
CloudWatch
A ResourcePool (Kubernetes farm consuming work) will identify the type of work the resource pool can consume based on a set of agenda insights / queue definitions.
Priority Operation Processing (POP) will schedule pending work for each Insight / Queue.
A puller to pull for work and resources to process the work (typically a Kubernetes farm)
A queue definition for the type of work to be pulled
-
Gather next customers in line that have work for each Resource Pool's insight
-
Add list of customers to the appropriate queue defined by insight
-
Watch for work exhaustion and refill queue
Insight Key | Value |
---|---|
Execute | operationType="mediaInfo" |
{
"operations":
[
{
"payload":"xyz",
"type":"transcode"
}
]
}
The Agenda in the above example with map to the Insight "Execute" defined for the Resource Pool above. The puller will get next Agendas from the queue by insightId once they are scheduled.
-
Customer submits either a payload with an AgendaTemplate.id or a ready to run Agenda
-
The agenda is mapped to an Insight for the Resource Pool.
-
A new Ready Agenda entry is created with the AgendaId, CustomerId, InsightId, and a state of available
-
The Agenda is considered available and is idle
-
Queues are monitored for item counts (if low/empty)
-
Fairness is used to select which customers with items in Ready Agenda will be given a chance to queue
-
The filter for the given customer and insight is applied to select which Agendas should be queued for the customer
-
All selected items are queued (within the limits of the queue/fairness)
-
Items in Ready Agenda are moved to queue
-
Puller requests work by insightId
-
The next Agenda in queue for that Insight is returned (or more if more were requested)
- Submission
- Scheduling
-
Execution
the ResourcePool
Agenda
the workflow
Agenda Template
the workflow definition
Customer
Insight
the scheduling queue definition
Operation Progress
the state of the running Agenda operations
Progress
the state of the running Agendas
ResourcePool
the processing resources
Agenda Service
the workflow submission
Progress Service
rolled up agenda progress summary
ResourcePool Service
getting work and updating progress
AgendaReclaimer
restarting stuck Agendas
AgendaRetry
retrying failed Agendas
DataObjectReaper
reaping expired data objects
PodReaper
reaping stuck Kubernetes pods