Skip to content

Latest commit

 

History

History
28 lines (26 loc) · 1.93 KB

README.md

File metadata and controls

28 lines (26 loc) · 1.93 KB

Service Bus Scheduler

An Azure Function App that schedules messages to be enqueued in a Azure Service Bus Queue and processes the messages once they are enqueued.

Overview

The Azure Function App consists of two functions: ScheduleMessage and ProcessMessage.

ScheduleMessage

The ScheduleMessage function has an HTTP trigger that takes a body and an interval query param.
It creates a ServiceBusMessage out of the body and sets message.ScheduledEnqueueTime to interval minutes from now before publishing it to a queue.

ProcessMessage

The ProcessMessage function has a ServiceBus trigger on the queue ScheduleMessage publishes to, so once the message is enqueued, it pulls the messages off and logs it.
Where ProcessMessage logs the message would be where additional logic that needed to occur at the scheduled time would be implemented.

Running the app

  1. Create a Service Bus Namespace and a Queue in the Azure Portal.
  2. Create an entry in the local.settings.json file with a key of AzureWebJobsServiceBus and a value of the Service Bus Namespace connection string.
  3. Paste the name of the Service Bus Queue where <queue-name> is used in the ScheduleMessage.cs and ProcessMessage.cs files.
  4. Build and run the app using Visual Studio or Docker.
  5. Send a HTTP request to the ScheduleMessage function with a body to send as the ServiceBusMessage and an interval query parameter.
    The ServiceBusMessage will be scheduled for interval minutes from now.
    The body can contain any properties. For example:
curl --location 'http://localhost:7071/api/ScheduleMessage?interval=1' \
--header 'Content-Type: application/json' \
--data '{
    "message": "Service Bus Scheduler"
}'
  1. Once the interval has passed and the message is enqueued, the ProcessMessage function will pick the message off of the queue and log the key/value pairs of the object sent as the body.