I am looking to implement a page view counter in azure table storage. If say two users visit the page at the same time, and the current value on PageViews = 100, is it guaranteed that the PageViews = 102 after the update operation?
Share
Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.
Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.
Lost your password? Please enter your email address. You will receive a link and will create a new password via email.
Please briefly explain why you feel this question should be reported.
Please briefly explain why you feel this answer should be reported.
Please briefly explain why you feel this user should be reported.
The answer depends on how you implement your counter. 🙂
Table storage doesn’t have an “increment” operator, so you’d need to read the current value (100) and update it to the new value (101). Table storage employs optimistic concurrency, so if you do what comes naturally when using the .NET storage client library, you’d likely see an exception when two processes tried to do this simultaneously. This would be the flow:
The obvious thing to do when you receive the error is to repeat the process. (Read the current value, which is now 101, and update to 102.) This will always (eventually) result in your counter having the correct value.
There are other possibilities, and we did an entire Cloud Cover episode about how to implement a truly scalable counter: http://channel9.msdn.com/Shows/Cloud+Cover/Cloud-Cover-Episode-43-Scalable-Counters-with-Windows-Azure.
What’s described in that video is probably overkill if collisions are unlikely. I.e., if your hit rate is one-per-second, the normal “read, increment, write” pattern will be safe and efficient. If, on the other hand, you receive 1000 hits per second, you’ll want to do something smarter.
EDIT
Just wanted to clarify for people who read this to understand optimistic concurrency… the conditional operation isn’t really “set PageViews to 101 as long as it’s currently 100.” It’s more like “set PageViews to 101 as long as it hasn’t changed since the last time I looked at it.” (This is accomplished by using the ETag that came back in the HTTP request.)