Azure Storage Queues and Message Shape
I have looked around and searched, and I cannot find anything addressing this, so if my Google Fu has failed me, please just point me in the right direction.
We are using Azure Storage Queues to trigger execution of Azure Functions (V2). (I don't believe that this usage is relevant, but I'm including it just in case.) Over the course of developing the Function, the "shape" of the input data changed (I'm using C# POCO objects and serializing them to JSON to create the queue message content.)
What I discovered was that after pushing the code changes out to Azure, the Storage Queue was continuing to send the JSON message to the Function in the old object JSON format - even though the JSON provided to the Storage Queue was in the new format.
The fix was simple enough - delete the queue and let the code re-create it. However, there's a lot of confusion here:
- Azure Storage Queues take messages as string values, so why is a "schema" being attached at all? I realize the message is ultimately provided in a
CloudQueueMessage
object, so there is probably some sort of JSON goodness happening behind the scenes. But... - If there is one (and there sure appears to be one), why would the Storage Queue accept and successfully process a message that does not match that format? If anything, I would have expected the message to end up in the poison queue, rather than some attempt to "translate" the incoming message into the schema.
- Is there a way to deal with this "in code" (other than writing a bunch of my own code to "check the schema")?
- What would have happened had I provided a simple string value? (This is really more curiosity for me than anything else...)
Any answers anyone can provide/point me to would be greatly appreciated.
azure azure-storage azure-functions azure-storage-queues
add a comment |
I have looked around and searched, and I cannot find anything addressing this, so if my Google Fu has failed me, please just point me in the right direction.
We are using Azure Storage Queues to trigger execution of Azure Functions (V2). (I don't believe that this usage is relevant, but I'm including it just in case.) Over the course of developing the Function, the "shape" of the input data changed (I'm using C# POCO objects and serializing them to JSON to create the queue message content.)
What I discovered was that after pushing the code changes out to Azure, the Storage Queue was continuing to send the JSON message to the Function in the old object JSON format - even though the JSON provided to the Storage Queue was in the new format.
The fix was simple enough - delete the queue and let the code re-create it. However, there's a lot of confusion here:
- Azure Storage Queues take messages as string values, so why is a "schema" being attached at all? I realize the message is ultimately provided in a
CloudQueueMessage
object, so there is probably some sort of JSON goodness happening behind the scenes. But... - If there is one (and there sure appears to be one), why would the Storage Queue accept and successfully process a message that does not match that format? If anything, I would have expected the message to end up in the poison queue, rather than some attempt to "translate" the incoming message into the schema.
- Is there a way to deal with this "in code" (other than writing a bunch of my own code to "check the schema")?
- What would have happened had I provided a simple string value? (This is really more curiosity for me than anything else...)
Any answers anyone can provide/point me to would be greatly appreciated.
azure azure-storage azure-functions azure-storage-queues
If my explanation did some help, could you accept it to close your question? Any confusion, just ask.
– Jerry Liu
Dec 2 '18 at 12:17
I am not talking about the CloudQueueMessage itself. When I debug my Function and hover over the string parameter that receives the message-queue data, the JSON string I receive is not the shape of the new POCO object - it is the shape of the old POCO object. It's like, internally, the Functions runtime is taking the JSON I pass to the CloudQueueMessage constructor and parsing it into an object - but the object it expects is the shape of the object when the queue was created. So it tried to create that kind of object and then put the JSON I provide into it, which does not work.
– S. McChesney
Dec 3 '18 at 19:46
Sorry for my poor comprehension, could you display the structure of old and new POCO object? IMO once we create a CloudQueueMessage with some string content, the content can only be modified by ourselves. The string parameter in Function method signature is supposed to get exactly the string content with no changes.
– Jerry Liu
Dec 14 '18 at 8:27
add a comment |
I have looked around and searched, and I cannot find anything addressing this, so if my Google Fu has failed me, please just point me in the right direction.
We are using Azure Storage Queues to trigger execution of Azure Functions (V2). (I don't believe that this usage is relevant, but I'm including it just in case.) Over the course of developing the Function, the "shape" of the input data changed (I'm using C# POCO objects and serializing them to JSON to create the queue message content.)
What I discovered was that after pushing the code changes out to Azure, the Storage Queue was continuing to send the JSON message to the Function in the old object JSON format - even though the JSON provided to the Storage Queue was in the new format.
The fix was simple enough - delete the queue and let the code re-create it. However, there's a lot of confusion here:
- Azure Storage Queues take messages as string values, so why is a "schema" being attached at all? I realize the message is ultimately provided in a
CloudQueueMessage
object, so there is probably some sort of JSON goodness happening behind the scenes. But... - If there is one (and there sure appears to be one), why would the Storage Queue accept and successfully process a message that does not match that format? If anything, I would have expected the message to end up in the poison queue, rather than some attempt to "translate" the incoming message into the schema.
- Is there a way to deal with this "in code" (other than writing a bunch of my own code to "check the schema")?
- What would have happened had I provided a simple string value? (This is really more curiosity for me than anything else...)
Any answers anyone can provide/point me to would be greatly appreciated.
azure azure-storage azure-functions azure-storage-queues
I have looked around and searched, and I cannot find anything addressing this, so if my Google Fu has failed me, please just point me in the right direction.
We are using Azure Storage Queues to trigger execution of Azure Functions (V2). (I don't believe that this usage is relevant, but I'm including it just in case.) Over the course of developing the Function, the "shape" of the input data changed (I'm using C# POCO objects and serializing them to JSON to create the queue message content.)
What I discovered was that after pushing the code changes out to Azure, the Storage Queue was continuing to send the JSON message to the Function in the old object JSON format - even though the JSON provided to the Storage Queue was in the new format.
The fix was simple enough - delete the queue and let the code re-create it. However, there's a lot of confusion here:
- Azure Storage Queues take messages as string values, so why is a "schema" being attached at all? I realize the message is ultimately provided in a
CloudQueueMessage
object, so there is probably some sort of JSON goodness happening behind the scenes. But... - If there is one (and there sure appears to be one), why would the Storage Queue accept and successfully process a message that does not match that format? If anything, I would have expected the message to end up in the poison queue, rather than some attempt to "translate" the incoming message into the schema.
- Is there a way to deal with this "in code" (other than writing a bunch of my own code to "check the schema")?
- What would have happened had I provided a simple string value? (This is really more curiosity for me than anything else...)
Any answers anyone can provide/point me to would be greatly appreciated.
azure azure-storage azure-functions azure-storage-queues
azure azure-storage azure-functions azure-storage-queues
edited Nov 16 '18 at 9:59
Jerry Liu
9,5731728
9,5731728
asked Nov 15 '18 at 17:05
S. McChesneyS. McChesney
113
113
If my explanation did some help, could you accept it to close your question? Any confusion, just ask.
– Jerry Liu
Dec 2 '18 at 12:17
I am not talking about the CloudQueueMessage itself. When I debug my Function and hover over the string parameter that receives the message-queue data, the JSON string I receive is not the shape of the new POCO object - it is the shape of the old POCO object. It's like, internally, the Functions runtime is taking the JSON I pass to the CloudQueueMessage constructor and parsing it into an object - but the object it expects is the shape of the object when the queue was created. So it tried to create that kind of object and then put the JSON I provide into it, which does not work.
– S. McChesney
Dec 3 '18 at 19:46
Sorry for my poor comprehension, could you display the structure of old and new POCO object? IMO once we create a CloudQueueMessage with some string content, the content can only be modified by ourselves. The string parameter in Function method signature is supposed to get exactly the string content with no changes.
– Jerry Liu
Dec 14 '18 at 8:27
add a comment |
If my explanation did some help, could you accept it to close your question? Any confusion, just ask.
– Jerry Liu
Dec 2 '18 at 12:17
I am not talking about the CloudQueueMessage itself. When I debug my Function and hover over the string parameter that receives the message-queue data, the JSON string I receive is not the shape of the new POCO object - it is the shape of the old POCO object. It's like, internally, the Functions runtime is taking the JSON I pass to the CloudQueueMessage constructor and parsing it into an object - but the object it expects is the shape of the object when the queue was created. So it tried to create that kind of object and then put the JSON I provide into it, which does not work.
– S. McChesney
Dec 3 '18 at 19:46
Sorry for my poor comprehension, could you display the structure of old and new POCO object? IMO once we create a CloudQueueMessage with some string content, the content can only be modified by ourselves. The string parameter in Function method signature is supposed to get exactly the string content with no changes.
– Jerry Liu
Dec 14 '18 at 8:27
If my explanation did some help, could you accept it to close your question? Any confusion, just ask.
– Jerry Liu
Dec 2 '18 at 12:17
If my explanation did some help, could you accept it to close your question? Any confusion, just ask.
– Jerry Liu
Dec 2 '18 at 12:17
I am not talking about the CloudQueueMessage itself. When I debug my Function and hover over the string parameter that receives the message-queue data, the JSON string I receive is not the shape of the new POCO object - it is the shape of the old POCO object. It's like, internally, the Functions runtime is taking the JSON I pass to the CloudQueueMessage constructor and parsing it into an object - but the object it expects is the shape of the object when the queue was created. So it tried to create that kind of object and then put the JSON I provide into it, which does not work.
– S. McChesney
Dec 3 '18 at 19:46
I am not talking about the CloudQueueMessage itself. When I debug my Function and hover over the string parameter that receives the message-queue data, the JSON string I receive is not the shape of the new POCO object - it is the shape of the old POCO object. It's like, internally, the Functions runtime is taking the JSON I pass to the CloudQueueMessage constructor and parsing it into an object - but the object it expects is the shape of the object when the queue was created. So it tried to create that kind of object and then put the JSON I provide into it, which does not work.
– S. McChesney
Dec 3 '18 at 19:46
Sorry for my poor comprehension, could you display the structure of old and new POCO object? IMO once we create a CloudQueueMessage with some string content, the content can only be modified by ourselves. The string parameter in Function method signature is supposed to get exactly the string content with no changes.
– Jerry Liu
Dec 14 '18 at 8:27
Sorry for my poor comprehension, could you display the structure of old and new POCO object? IMO once we create a CloudQueueMessage with some string content, the content can only be modified by ourselves. The string parameter in Function method signature is supposed to get exactly the string content with no changes.
– Jerry Liu
Dec 14 '18 at 8:27
add a comment |
1 Answer
1
active
oldest
votes
You probably mistake message content with CloudQueueMessage
object.
What we usually handle in code is message content/text/body containing the information we want to process. In your case, i.e. C# POCO and the serialized Json payload.
When we create a queue message in Azure Storage Queue, several properties are populated by Azure. CloudQueueMessage
object is composed of message content and these properties. They are used to control how queue messages behave when we process its content, check the doc for their usage.
public static long MaxMessageSize { get; }
public static TimeSpan MaxVisibilityTimeout { get; }
public static int MaxNumberOfMessagesToPeek { get; }
public string Id { get; }
public string PopReceipt { get; }
public DateTimeOffset? InsertionTime { get; }
public DateTimeOffset? ExpirationTime { get; }
public DateTimeOffset? NextVisibleTime { get; }
public int DequeueCount { get; }
As for the message content itself, it can be a string or byte array. When Azure Function receives the message, we have several options how queue message are populated, the first three take message content only.
- Object - The Functions runtime deserializes a JSON payload into an instance of an arbitrary class defined in your code.
- string
- byte
- CloudQueueMessage
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53324564%2fazure-storage-queues-and-message-shape%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
You probably mistake message content with CloudQueueMessage
object.
What we usually handle in code is message content/text/body containing the information we want to process. In your case, i.e. C# POCO and the serialized Json payload.
When we create a queue message in Azure Storage Queue, several properties are populated by Azure. CloudQueueMessage
object is composed of message content and these properties. They are used to control how queue messages behave when we process its content, check the doc for their usage.
public static long MaxMessageSize { get; }
public static TimeSpan MaxVisibilityTimeout { get; }
public static int MaxNumberOfMessagesToPeek { get; }
public string Id { get; }
public string PopReceipt { get; }
public DateTimeOffset? InsertionTime { get; }
public DateTimeOffset? ExpirationTime { get; }
public DateTimeOffset? NextVisibleTime { get; }
public int DequeueCount { get; }
As for the message content itself, it can be a string or byte array. When Azure Function receives the message, we have several options how queue message are populated, the first three take message content only.
- Object - The Functions runtime deserializes a JSON payload into an instance of an arbitrary class defined in your code.
- string
- byte
- CloudQueueMessage
add a comment |
You probably mistake message content with CloudQueueMessage
object.
What we usually handle in code is message content/text/body containing the information we want to process. In your case, i.e. C# POCO and the serialized Json payload.
When we create a queue message in Azure Storage Queue, several properties are populated by Azure. CloudQueueMessage
object is composed of message content and these properties. They are used to control how queue messages behave when we process its content, check the doc for their usage.
public static long MaxMessageSize { get; }
public static TimeSpan MaxVisibilityTimeout { get; }
public static int MaxNumberOfMessagesToPeek { get; }
public string Id { get; }
public string PopReceipt { get; }
public DateTimeOffset? InsertionTime { get; }
public DateTimeOffset? ExpirationTime { get; }
public DateTimeOffset? NextVisibleTime { get; }
public int DequeueCount { get; }
As for the message content itself, it can be a string or byte array. When Azure Function receives the message, we have several options how queue message are populated, the first three take message content only.
- Object - The Functions runtime deserializes a JSON payload into an instance of an arbitrary class defined in your code.
- string
- byte
- CloudQueueMessage
add a comment |
You probably mistake message content with CloudQueueMessage
object.
What we usually handle in code is message content/text/body containing the information we want to process. In your case, i.e. C# POCO and the serialized Json payload.
When we create a queue message in Azure Storage Queue, several properties are populated by Azure. CloudQueueMessage
object is composed of message content and these properties. They are used to control how queue messages behave when we process its content, check the doc for their usage.
public static long MaxMessageSize { get; }
public static TimeSpan MaxVisibilityTimeout { get; }
public static int MaxNumberOfMessagesToPeek { get; }
public string Id { get; }
public string PopReceipt { get; }
public DateTimeOffset? InsertionTime { get; }
public DateTimeOffset? ExpirationTime { get; }
public DateTimeOffset? NextVisibleTime { get; }
public int DequeueCount { get; }
As for the message content itself, it can be a string or byte array. When Azure Function receives the message, we have several options how queue message are populated, the first three take message content only.
- Object - The Functions runtime deserializes a JSON payload into an instance of an arbitrary class defined in your code.
- string
- byte
- CloudQueueMessage
You probably mistake message content with CloudQueueMessage
object.
What we usually handle in code is message content/text/body containing the information we want to process. In your case, i.e. C# POCO and the serialized Json payload.
When we create a queue message in Azure Storage Queue, several properties are populated by Azure. CloudQueueMessage
object is composed of message content and these properties. They are used to control how queue messages behave when we process its content, check the doc for their usage.
public static long MaxMessageSize { get; }
public static TimeSpan MaxVisibilityTimeout { get; }
public static int MaxNumberOfMessagesToPeek { get; }
public string Id { get; }
public string PopReceipt { get; }
public DateTimeOffset? InsertionTime { get; }
public DateTimeOffset? ExpirationTime { get; }
public DateTimeOffset? NextVisibleTime { get; }
public int DequeueCount { get; }
As for the message content itself, it can be a string or byte array. When Azure Function receives the message, we have several options how queue message are populated, the first three take message content only.
- Object - The Functions runtime deserializes a JSON payload into an instance of an arbitrary class defined in your code.
- string
- byte
- CloudQueueMessage
edited Nov 16 '18 at 10:03
answered Nov 16 '18 at 9:58
Jerry LiuJerry Liu
9,5731728
9,5731728
add a comment |
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53324564%2fazure-storage-queues-and-message-shape%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
If my explanation did some help, could you accept it to close your question? Any confusion, just ask.
– Jerry Liu
Dec 2 '18 at 12:17
I am not talking about the CloudQueueMessage itself. When I debug my Function and hover over the string parameter that receives the message-queue data, the JSON string I receive is not the shape of the new POCO object - it is the shape of the old POCO object. It's like, internally, the Functions runtime is taking the JSON I pass to the CloudQueueMessage constructor and parsing it into an object - but the object it expects is the shape of the object when the queue was created. So it tried to create that kind of object and then put the JSON I provide into it, which does not work.
– S. McChesney
Dec 3 '18 at 19:46
Sorry for my poor comprehension, could you display the structure of old and new POCO object? IMO once we create a CloudQueueMessage with some string content, the content can only be modified by ourselves. The string parameter in Function method signature is supposed to get exactly the string content with no changes.
– Jerry Liu
Dec 14 '18 at 8:27