У меня миллионы сообщений в очереди, и первые десять миллионов или около того не имеют значения.Каждое сообщение имеет последовательный ActionId, поэтому в идеале все, что угодно < 10000000
, я могу просто проигнорировать или, что еще лучше, удалить из очереди.Что у меня есть:
let azure = require("azure");
function processMessage(sb, message) {
// Deserialize the JSON body into an object representing the ActionRecorded event
var actionRecorded = JSON.parse(message.body);
console.log(`processing id: ${actionRecorded.ActionId} from ${actionRecorded.ActionTaken.ActionTakenDate}`);
if (actionRecorded.ActionId < 10000000) {
// When done, delete the message from the queue
console.log(`Deleting message: ${message.brokerProperties.MessageId} with ActionId: ${actionRecorded.ActionId}`);
sb.deleteMessage(message, function(deleteError, response) {
if (deleteError) {
console.log("Error deleting message: " + message.brokerProperties.MessageId);
}
});
}
// immediately check for another message
checkForMessages(sb);
}
function checkForMessages(sb) {
// Checking for messages
sb.receiveQueueMessage("my-queue-name", { isPeekLock: true }, function(receiveError, message) {
if (receiveError && receiveError === "No messages to receive") {
console.log("No messages left in queue");
return;
} else if (receiveError) {
console.log("Receive error: " + receiveError);
} else {
processMessage(sb, message);
}
});
}
let connectionString = "Endpoint=sb://<myhub>.servicebus.windows.net/;SharedAccessKeyName=KEYNAME;SharedAccessKey=[mykey]"
let serviceBusService = azure.createServiceBusService(connectionString);
checkForMessages(serviceBusService);
Я пытался просмотреть документы на с помощью фильтра , но, похоже, это не относится к очередям.
IУ меня нет доступа к созданию или изменению базовой очереди, кроме операций, упомянутых выше, поскольку очередь предоставляется клиентом.
Могу ли я либо
- Отфильтровать результаты, которые яполучить из очереди
- ускорить обработку очереди как-нибудь?