You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
There are times where you are storing specific data types (lists, dictionaries, etc.) as a value in PINCache. The current implementation allows for these types to be values in the cache but to perform any mutation an outside caller would have to read, mutate and re-cache the object which could lead to mutations of stale data (due to thread-safety). The goal of this proposal is to identify a way to add atomic mutation support to power common data-structure mutations within the cache itself.
Example: List append race condition
NSString *key;
NSArray *objectsToAppend = @[......];
// Fetch current list from the cacheNSArray *list = [cache objectForKey:key];
// Compute the new list valueNSArray *updatedList = [list arrayByAddingObjectsFromArray:objectsToAppend];
// Overwrite the cache value for `key` with the updated list.
[cache setObject:updatedList];
This code seems like it would be a reasonable workaround for this use-case but actually has it's own issues with regards to thread-safety and performing two operations on the cache for what should be an atomic operation.
Potential solution
Expanding the PINCache API for discrete mutation events
The append example would have been safe to perform if the mutation was performed when the lock was acquired during the initial fetch of key. It would be more straightforward if there were API additions for performing specific mutations within the cache itself.
For example the above example could have a specific methods for lists:
The advantage in the above proposal is that the append operation is contained within the lock so it is going to be appending values to the current list rather than potentially stale data.
Add a general API method for performing an atomic mutation
If we had a method to mutate the object for key atomically, we would be able to build extensible APIs for various data structures on top of PINCache through Objective-C categories.
The mutation method:
// Ideally we'd be able to constrain this type to have the same input and return values.typedefid (^PINCacheMutationBlock)(id);
- (void)mutateObjectForKey:(nonnull NSString *)key withBlock:(PINCacheMutationBlock)block:
Then the above extensions for lists would be a category on PINCache:
I think this direction of functionality can add a lot of value to the overall uses of PINCache but also comes with the cost of complexity in the API. This kind of idea is what made Redis a popular caching system over Memcached and allowed it to satisfy many use-cases. The above example only goes through one potential API addition (list append) but I would like to get feedback on the proposal before discussing additional API methods.
The text was updated successfully, but these errors were encountered:
Motivation
There are times where you are storing specific data types (lists, dictionaries, etc.) as a value in PINCache. The current implementation allows for these types to be values in the cache but to perform any mutation an outside caller would have to read, mutate and re-cache the object which could lead to mutations of stale data (due to thread-safety). The goal of this proposal is to identify a way to add atomic mutation support to power common data-structure mutations within the cache itself.
Example: List append race condition
This code seems like it would be a reasonable workaround for this use-case but actually has it's own issues with regards to thread-safety and performing two operations on the cache for what should be an atomic operation.
Potential solution
Expanding the PINCache API for discrete mutation events
The append example would have been safe to perform if the mutation was performed when the lock was acquired during the initial fetch of
key
. It would be more straightforward if there were API additions for performing specific mutations within the cache itself.For example the above example could have a specific methods for lists:
An implementation of
@selector(appendObjects:forListWithKey:)
would look like this:The advantage in the above proposal is that the append operation is contained within the lock so it is going to be appending values to the current list rather than potentially stale data.
Add a general API method for performing an atomic mutation
If we had a method to mutate the object for key atomically, we would be able to build extensible APIs for various data structures on top of PINCache through Objective-C categories.
The mutation method:
Then the above extensions for lists would be a category on PINCache:
Conclusion
I think this direction of functionality can add a lot of value to the overall uses of PINCache but also comes with the cost of complexity in the API. This kind of idea is what made Redis a popular caching system over Memcached and allowed it to satisfy many use-cases. The above example only goes through one potential API addition (list append) but I would like to get feedback on the proposal before discussing additional API methods.
The text was updated successfully, but these errors were encountered: