Atlassian uses cookies to improve your browsing experience, perform analytics and research, and conduct advertising. Accept all cookies to indicate that you agree to our use of cookies on your device. Atlassian cookies and tracking notice, (opens new window)
if cache cluster is restarted, we will receive an error "ErrorCode<ERRCA0005>:SubStatus<ES0001>:Region referred to does not exist. Use CreateRegion API to fix the error". Open to options on how to resolve that.
Please note: as part of applying this patch, the following files may be removed from lib\net\3.5:
If someone is interested by this, please issue a PR here.
Frantisek Jandos
June 8, 2011 at 4:20 AM
I appreciate there is cache provider for AppFavric Cache, but I think that the usage of locks dictionary in VelocityClient is problematic due to following reasons: The client class is not thread safe (according to ICache comments should be) as distinct Add, Remove, Count may be performed concurrenctly. This could lead to race condions and unexpected dictionary exceptions. (ii) If we are in cluster, each node would have its own locks dictionary, which could again lead to potential unlock by put.
Paul Duran
November 28, 2010 at 6:46 PM
Attaching new version of patch. This version wraps the DataCache operations so that if the cache cluster is restarted, it will trap the RegionDoesNotExist error and recreate the region.
Velocity has been renamed to AppFabric Caching Services. I've taken the suggested updates from this stackoverflow article: http://stackoverflow.com/questions/3233792/appfabric-could-not-contact-the-cache-service and improved them.
Namely:
lock/unlock are fixed.
exceptions are still swallowed but are now logged
item will now remain locked after a Put() operation if it was locked already - see http://social.msdn.microsoft.com/Forums/en/velocity/thread/2b6df3a7-0bf8-4386-ba2d-884fb1a29e0e for explanation
Known limitation:
if cache cluster is restarted, we will receive an error "ErrorCode<ERRCA0005>:SubStatus<ES0001>:Region referred to does not exist. Use CreateRegion API to fix the error". Open to options on how to resolve that.
Please note: as part of applying this patch, the following files may be removed from lib\net\3.5:
CacheBaseLibrary.dll
CacheBaseLibrary.XML
CASBase.dll
CASClient.dll
ClientLibrary.dll
ClientLibrary.XML
FabricCommon.dll