Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How does Azure check the WorkerRole's status?

I see how Azure checks the status of my worker role periodically, but how?

There is no method in RoleEntryPoint to do that, and I'm taking a look on Microsoft.WindowsAzure.ServiceRuntime's classes with ILSpy but I don't see anything relevant.

like image 815
vtortola Avatar asked Mar 21 '11 17:03

vtortola


2 Answers

Here's a blog post that describes how the Windows Azure Fabric Controller monitors instance health.

Aside from that, the controller calls a StatusCheck event, every 15 seconds, that you can handle. If you want to pull yourself out of the load balancer (maybe based on some internal data your instance has), you just call SetBusy() on the RoleEnvironmentStatusCheckEventArgs object. This takes you out of the load balancer until the next check.

like image 174
David Makogon Avatar answered Sep 24 '22 01:09

David Makogon


I think the mechanism is the same as the one used for WebRoles

the Azure RoleEnvironment performs a StatusCheck - see http://msdn.microsoft.com/en-us/library/microsoft.windowsazure.serviceruntime.roleenvironment.statuscheck.aspx

If you want to tell the service you are busy then call SetBusy() when this event fires

like image 29
Stuart Avatar answered Sep 22 '22 01:09

Stuart