This repository to contains a set of providers for running Microsoft Orleans using Couchbase as the storage layer.
Currently supports:
- Storage Provider
- Membership Provider
- Document expiry per grain type
- Reminders
The storage provider can be registered like this:
config.Globals.RegisterStorageProvider<Orleans.Storage.OrleansCouchBaseStorage>("default", new Dictionary<string, string>
{
{ "Server", "http://localhost:8091" },
{ "UserName", "" },
{ "Password", "" },
{ "BucketName", "default" }
});
Password can be left blank if the bucket is not password protected. For using multiple buckets register multiple ones with different names and then use them with the [StorageProvider(ProviderName = "provider name")]
attribute on top of grains with state.
The membership provider can be used like this:
config.Globals.DeploymentId = "";
config.Globals.LivenessType = GlobalConfiguration.LivenessProviderType.Custom;
config.Globals.MembershipTableAssembly = "CouchBaseProviders";
config.Globals.RegisterStorageProvider<Orleans.Storage.OrleansCouchBaseStorage>("default", new Dictionary<string, string>
{
{ "Server", "http://localhost:8091" },
{ "UserName", "" },
{ "Password", "" },
{ "BucketName", "default" }
});
config.Globals.RegisterStorageProvider<Orleans.Storage.OrleansCouchBaseStorage>("PubSubStore", new Dictionary<string, string>
{
{ "Server", "http://localhost:8091" },
{ "UserName", "" },
{ "Password", "" },
{ "BucketName", "default" }
});
config.Globals.DataConnectionString = "http://localhost:8091";
config.PrimaryNode = null;
config.Globals.SeedNodes.Clear();
NOTE: The membership provider requires a bucket called membership
.
By default documents written to Couchbase will not have an expiry value set.
Support has now been added to allow expiry values to be configured per grain type.
To use this feature you need to update your app.config or web.config file;
Add the following under the element:
<section name="orleans" type="CouchBaseProviders.Configuration.CouchbaseOrleansDocumentExpiry.CouchbaseOrleansConfigurationSection, CouchbaseProviders" />
<orleans>
<grainExpiry>
<add grainType="grainX" expiresIn="0:0:1:0"></add>
</grainExpiry>
</orleans>
The expiresIn value must be a valid TimeSpan format. Examples include:
- 10 seconds: 00:00:10
- 10 minutes: 00:10:00
- 10 hours: 10:00:00
- 10 days: 10:00:00:00
Refer to the app.confg provided in the CouchBaseStorageTests project for more information.
Take a look at the current issues and report any issues you find. The providers have been tested with CouchBase Community 4.1.
The MIT license.