Class MicroserviceInstance
java.lang.Object
desmoj.core.simulator.NamedObject
desmoj.core.simulator.ModelComponent
desmoj.core.simulator.Schedulable
desmoj.core.simulator.Entity
cambio.simulator.entities.NamedEntity
cambio.simulator.entities.networking.RequestSender
cambio.simulator.entities.microservice.MicroserviceInstance
- All Implemented Interfaces:
IRequestUpdateListener,Comparable<IRequestUpdateListener>
A
MicroserviceInstance (in the following just called instance) represents an actual, running instance of a
Microservice.
An instance has responsibility to handle incoming requests. This is done by either:
1. Sending an answer back to
the requester, if the request is completed
2. Creating child requests for satisfying the dependencies of a
request
3. Submitting the request to its CPU for handling of its computational demand.
During its lifetime an instances is aware of all requests it currently handles and of all dependencies it is currently waiting for.
An instance can have different states, which are defined and described by the enum InstanceState.
- Author:
- Lion Wagner
- See Also:
-
Field Summary
FieldsModifier and TypeFieldDescriptionprotected final List<ServiceDependencyInstance>protected final List<ServiceDependencyInstance>protected final CPUprotected final Set<RequestAnswer>protected final Set<InternalRequest>protected final Set<ServiceDependencyInstance>protected final intprotected longprotected final Microserviceprotected Set<InstanceOwnedPattern>protected final MultiDataPointReporterprotected InstanceStateprotected longFields inherited from class cambio.simulator.entities.networking.RequestSender
updateListenerProxyFields inherited from class desmoj.core.simulator.Schedulable
_schedule -
Constructor Summary
ConstructorsConstructorDescriptionMicroserviceInstance(desmoj.core.simulator.Model model, String name, boolean showInTrace, Microservice microservice, int instanceID) Creates a newMicroserviceInstancefor the givenMicroserviceparent. -
Method Summary
Modifier and TypeMethodDescriptionvoidactivatePatterns(InstanceOwnedPatternConfiguration[] patterns) Activates the patterns that are owned by this instance.booleancheckIfCanHandle(Request request) Checks whether this Instance can handle the Request.final voiddie()Immediately kills this instance.final voidCompletes the shutdown and transitions the instance into theInstanceState.SHUTDOWNstate.getCpu()final intfinal MicroservicegetOwner()doubleGets the relative work demand.getState()Gets the state of the instance.doublegetUsage()Gets the current usage of the instance.voidSubmits aRequestat this instance for handling.protected voidhandleIncomingRequest(Request request) protected voidhandleRequestAnswer(RequestAnswer answer) booleanonRequestArrivalAtTarget(Request request, desmoj.core.simulator.TimeInstant when) Listener for the successful completion of the sending process.booleanonRequestFailed(Request request, desmoj.core.simulator.TimeInstant when, RequestFailedReason reason) Listener for the failure of the sending process.booleanonRequestResultArrivedAtRequester(Request request, desmoj.core.simulator.TimeInstant when) Listener for the successful receiving of the answer of a request.booleanonRequestSend(Request request, desmoj.core.simulator.TimeInstant when) Listener for the send-off of a request.voidsetState(InstanceState state) voidstart()Starts this instance, reading it to receive requests.final voidStarts the shutdown sequence of this instance.protected voidsubmitProcessToCPU(CPUProcess newProcess) Methods inherited from class cambio.simulator.entities.networking.RequestSender
addUpdateListener, addUpdateListeners, sendRequest, sendRequest, sendRequest, sendRequestMethods inherited from class cambio.simulator.entities.NamedEntity
getPlainName, getQuotedName, getQuotedPlainName, renameMethods inherited from class desmoj.core.simulator.Entity
clone, generateTraceForScheduling, getIdentNumber, getQueueingPriority, getQueues, getScheduledEvents, isEqual, isLarger, isLargerOrEqual, isNotEqual, isQueued, isSimProcess, isSmaller, isSmallerOrEqual, schedule, schedule, schedule, schedule, schedule, schedule, schedule, schedule, schedule, scheduleAfter, scheduleAfter, scheduleAfter, scheduleBefore, scheduleBefore, scheduleBefore, schedulePreempt, schedulePreempt, schedulePreempt, setQueueingPriorityMethods inherited from class desmoj.core.simulator.Schedulable
assignReporter, cancel, getCorrespondingReportable, isCurrent, isScheduled, reSchedule, reSchedule, reSchedulePreempt, scheduledNext, setCorrespondingReportableMethods inherited from class desmoj.core.simulator.ModelComponent
current, currentEntity, currentEntityAll, currentEvent, currentlySendDebugNotes, currentlySendTraceNotes, currentModel, currentSimProcess, debugIsOn, debugOff, debugOn, getModel, isExperimentCompatible, isModelCompatible, presentTime, sendDebugNote, sendMessage, sendTraceNote, sendWarning, skipTraceNote, skipTraceNote, traceIsOn, traceOff, traceOnMethods inherited from class desmoj.core.simulator.NamedObject
getName, toStringMethods inherited from class java.lang.Object
equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface cambio.simulator.entities.networking.IRequestUpdateListener
compareTo, getListeningPriority
-
Field Details
-
owner
-
cpu
-
instanceID
protected final int instanceID -
currentRequestsToHandle
-
currentlyOpenDependencies
-
currentAnswers
-
currentInternalSends
-
reporter
-
closedDependencies
-
abortedDependencies
-
state
-
patterns
-
notComputed
protected long notComputed -
waiting
protected long waiting
-
-
Constructor Details
-
MicroserviceInstance
public MicroserviceInstance(desmoj.core.simulator.Model model, String name, boolean showInTrace, Microservice microservice, int instanceID) Creates a newMicroserviceInstancefor the givenMicroserviceparent.- Parameters:
model- Base model of the simulation.name- Name of the instance.showInTrace- Whether the instance outputs should be shown in the trace.microservice- Parent microservice of the instance.instanceID- ID of the instance.
-
-
Method Details
-
activatePatterns
Activates the patterns that are owned by this instance. This will call registersIRequestUpdateListeners on this instance and call theIPatternLifeCycleHooks.start()method on each pattern instance. -
getUsage
public double getUsage()Gets the current usage of the instance.- See Also:
-
getRelativeWorkDemand
public double getRelativeWorkDemand()Gets the relative work demand.- Returns:
- the relative work demand.
- See Also:
-
getState
Gets the state of the instance. -
handle
Submits aRequestat this instance for handling.- Parameters:
request-Requestthat should be handled by this instance.
-
checkIfCanHandle
Checks whether this Instance can handle the Request.- Parameters:
request- request that may should be handled by this instance.- Returns:
- true if this request will be handled, false otherwise
-
handleRequestAnswer
-
handleIncomingRequest
-
submitProcessToCPU
-
start
public void start()Starts this instance, reading it to receive requests.Currently, the startup process completes immediately.
-
startShutdown
public final void startShutdown()Starts the shutdown sequence of this instance. The service will not accept new requests, but will complete open requests. -
endShutdown
public final void endShutdown()Completes the shutdown and transitions the instance into theInstanceState.SHUTDOWNstate. The instance will not handle any requests in this state. -
die
public final void die()Immediately kills this instance. All currently active requests (computed and cascading) will be canceled. -
getOwner
-
getInstanceID
public final int getInstanceID() -
onRequestFailed
public boolean onRequestFailed(Request request, desmoj.core.simulator.TimeInstant when, RequestFailedReason reason) Description copied from interface:IRequestUpdateListenerListener for the failure of the sending process. This could for example be due to the receiving service not being available, the request being canceled or timed out. Provides a reference to the failed request.- Specified by:
onRequestFailedin interfaceIRequestUpdateListener- Parameters:
request- request that triggered this eventwhen- time of this eventreason- reason why the request failed- Returns:
- true if the request was terminally handled (consumed) by this instance
-
onRequestArrivalAtTarget
Description copied from interface:IRequestUpdateListenerListener for the successful completion of the sending process. Provides a reference to the successfully arrived request.- Specified by:
onRequestArrivalAtTargetin interfaceIRequestUpdateListener- Parameters:
request- request that triggered this eventwhen- time of this event- Returns:
- true if the request was terminally handled (consumed) by this instance
-
onRequestSend
Description copied from interface:IRequestUpdateListenerListener for the send-off of a request. Provides the send request.- Specified by:
onRequestSendin interfaceIRequestUpdateListener- Parameters:
request- request that triggered this eventwhen- time of this event- Returns:
- true if the request was terminally handled (consumed) by this instance
-
onRequestResultArrivedAtRequester
public boolean onRequestResultArrivedAtRequester(Request request, desmoj.core.simulator.TimeInstant when) Description copied from interface:IRequestUpdateListenerListener for the successful receiving of the answer of a request.- Specified by:
onRequestResultArrivedAtRequesterin interfaceIRequestUpdateListener- Parameters:
request- request that triggered this eventwhen- time of this event- Returns:
- true if the request was terminally handled (consumed) by this instance
-
getCpu
-
getPatterns
-
setState
-