Skip to content

Releases: dotnet/orleans

v1.4.0-beta

01 Feb 23:41
Compare
Choose a tag to compare
  • Major new features
    • Revamped JournaledGrain for event sourcing with support for geo-distributed log-based consistency providers.
    • Abstraction of Grain Services with fixed-placed per-silo application components with their workload partitioned via cluster consistency ring.
    • Support for heterogeneous silos with non-uniform distribution of available grain classes.
    • Cluster membership provider for Service Fabric.
  • Improvements
    • IL-based fallback serializer #2162
    • IncomingMessageAcceptor sockets change from APM to EAP #2275
    • Show clearer error when ADO.NET provider fails to init #2303, #2306
    • In client, when a gateway connection close reroute not yet sent message to another gateway #2298
    • MySQL Script: Minor syntax tweak to support previous server versions #2342
    • Azure Queue provider message visibility config #2401
    • Propagate exceptions during message body deserialization #2364
    • Check IAddressable before DeepCopy #2383
    • Modified stream types to not use fallback serializer and allow external #2330
    • Add "Custom/" prefix for NewRelic metrics #2453
    • Ignore named EventWaitHandle when not available in platform #2462
    • Heterogenous silos support #2443
    • Update to Consul 0.7.0.3 nuget package, because of breaking change in Consul API. #2498
    • Grain Services by @jamescarter-le #2531
    • Expose IMembershipOracle & related interfaces #2557
    • Trigger registration of clients connected to the gateways in the directory when a silo is dead #2587
    • Log Consistency Providers #1854
    • In XML config, if SystemStoreType set to Custom but no ReminderTableAssembly are specified, assume that ReminderServiceProviderType is set to Disabled #2589
    • In config XML, when SystemStoreType is set to MembershipTableGrain, set ReminderServiceType to ReminderTableGrain #2590
    • Service Fabric cluster membership providers #2542
    • Adds optional native JSON support to MySQL #2288
    • Azure table storage throws InconsistentStateException #2630
    • Allow serializers to have multiple [Serializer(...)] attributes #2611
    • Removed GrainStateStorageBridge from GrainCreator to allow better control of the IStorage used when using non-silo unit tests. #2243
    • Failsafe Exception serialization #2633
    • Added a data adapter to azure queue stream provider #2658
    • Client cluster disconnection #2628
  • Performance
  • Bug fixes
    • Empty deployment Id in Azure #2230
    • Remove zero length check in Protobuf serializer #2251
    • Make PreferLocalPlacement activate in other silos when shutting down #2276
    • Reset GrainClient.ClientInvokeCallback when uninitializing GrainClient #2299
    • Fix ObjectDisposedException in networking layer #2302
    • Reset client gateway reciever buffer on socket reset. #2316
    • Removed calling Trace.Close() from TelemetryConsumer.Close() #2396
    • Removes deadlocking and corrupted hashing in SQL storage provider #2395
    • Fix #2358: Invoke interceptor broken for generic grains #2502
    • Only a hard coded set of statistics were going to telemetry consumers. Now all non-string statistics are tracked. #2513
    • Fix invocation interception for grain extensions #2514
    • Fix type assertion in AdaptiveDirectoryCacheMaintainer #2525
    • MembershipTableFactory should call InitializeMembershipTable on membership table. #2537
    • CodeGen: fix check on parameters to generic types with serializers #2575
    • EventHubQueueCache failing to write checkpoints on purge #2613
    • Fix code copy-paste errors discovered by Coverity #2639
    • GrainServices are now Started by the Silo on Startup #2642

v1.3.1

15 Nov 22:32
Compare
Choose a tag to compare

Improvements and bug fixes since 1.3.0.

  • Improvements
    • Ability to specify interleaving per message type (was needed for Orleankka) #2246
    • Support serialization of enums backed by non-Int32 fields #2237
    • Add TGrainState constraints to document clearly what is needed by folks implementing stateful grains. #1923
    • Serialization fixes #2295
    • Update OrleansConfiguration.xsd with DI info #2314
    • Reroute client messages via a different gateway upon a gateway disconnection #2298
    • Add helper methods to ease ADO.NET configuration #2291
    • EventHubStreamProvider improvements #2377
    • Add queue flow controller that is triggered by silo load shedding. #2378
    • Modify JenkinsHash to be stateless. #2403
    • EventHub flow control customization knobs #2408
  • Performance
    • Invoker codegen: methods returning Task do not need Box() calls #2221
    • CodeGen: Avoid wrapping IGrainMethodInvoker.Invoke body in try/catch #2220
    • Remove contention point in GrainDirectoryPartition #2170
    • Optimize the scheduler, remove redundant semaphore and interlocked exchange. #2218
    • Remove delegate allocation #2312
    • Release BinaryTokenStreamWriter buffers after use in more cases. #2326
    • Provide better handling in Grain when the GrainRuntime or GrainIdentity is null #2338
    • Bug fixes
      • Reset client gateway reciever buffer on socket reset. #2316
      • Removes potential deadlocking and corrupted hashing in ADO.NET storage provider #2395
      • LoadShedQueueFlowControl cast fix #2405

v1.3.0

12 Oct 15:31
Compare
Choose a tag to compare

NB: There is a subtle breaking change in this release, which is unfortunately easy to miss.
If you are using AzureSilo.Start(ClusterConfiguration config, string deploymentId) in your code, that overload has been removed, but the new one that replaced it has the same argument signature with a different second argument: (ClusterConfiguration config, string connectionString). Deployment ID now has to be passed as part of the config argument: config.Globals.DeploymentId. This removed the ambiguous possibility of passing two different Deployment IDs, but unfortunately at the cost of the breaking API change.

  • Bug fixes
    • Empty deployment Id in Azure #2230
    • Remove zero length check in Protobuf serializer #2251
    • Make PreferLocalPlacement revert to RandomPlacement on non-active silos #2276
  • Streaming
    • Updated MemoryStreamProvider to support custom message serialization #2271

v1.2.4

05 Oct 22:25
Compare
Choose a tag to compare

Bug fix: Prevent null reference exception after clearing PubSubRendezvousGrain state #2040

v1.3.0-beta2

27 Sep 21:06
Compare
Choose a tag to compare

NB: There is a subtle breaking change in this release, which is unfortunately easy to miss.
If you are using AzureSilo.Start(ClusterConfiguration config, string deploymentId) in your code, that overload has been removed, but the new one that replaced it has the same argument signature with a different second argument: (ClusterConfiguration config, string connectionString). Deployment ID now has to be passed as part of the config argument: config.Globals.DeploymentId. This removed the ambiguous possibility of passing two different Deployment IDs, but unfortunately at the cost of the breaking API change.

  • Notable new features
    • Support for geo-distributed multi-cluster deployments #1108 #1109 #1800
    • Added new Amazon AWS basic Orleans providers #2006
    • Support distributed cancellation tokens in grain methods #1599
  • Providers
    • Remove confusing parameter from AzureSilo.Start #2109
    • Minimal Service Fabric integration #2120
    • Update blob storage provider to throw on storage exceptions #1902
    • Decode protobuf using MessageParser, not dynamic #2136
    • Service Provider is no longer required by EventHubAdapter #2044
    • Preliminary relational persistence queries #1682
    • Add a function that checks the connection string for use during initialization #1987
    • A new ADO.NET storage provider that is significantly easier to setup, which replaces the the previous one. This change is not backwards compatible and does not support sharding
      (likely be replaced later with Orleans sharding provider). The most straightforward migration plan is likely to persist the state classes from Orleans application code.
      More information in #1682 and in #1682 (comment).
    • Support for PostgreSql #2113
    • Memory Storage eTag enforcement less strict. #1885
    • Added option to perform provider commands quietly #1762
    • CreateOrleansTables_SqlServer.sql: Removed support for SQL Server 2000 and 2005 #1779
  • Streaming
    • EventHub stream provider made more extensible #1861 1714
    • EventHub stream provider with improved monitoring logging #1857 #2146
    • EventHub stream provider time based message purge #2093
    • Add Memory Stream Provider #2063
    • Persistent stream pulling agent now uses exponential backoff #2078
    • Add dynamic adding / removing stream providers functionality. #1966
    • Consistent implicit subscription Id generation. #1828
    • Event hub stream provider EventData to cached data mapping #1727
  • Bug fixes
    • CodeGen: fix generated DeepCopy method to call RecordObject earlier #2135
    • Fix support for serializing SByte[] #2140
    • Fix synchronization bug in Orleans/Async/BatchWorker #2133
    • Fix #2119 by allowing full uninitialization in SiloHost #2127
    • Persistent Stream Provider initialization timeout fix. #2065
    • Fix null reference in StreamPubSub grain. #2040
    • Some EventHub stream provider bug fixes #1760 #1935 #1921 #1922
    • Allow comments in configuration XML #1994
    • Fixed null MethodInfo in Interceptors #1938
    • EventHub stream provider Object Pools not pooling fix. #1937
    • Harden explicit subscription pubsub system #1884
    • Fix #1869. Grain Extensions + method interception should function correctly #1874
    • Fix bug with generic state parameter caused by inconsistent use of grainClassName / genericArgument / genericInterface #1897
    • Throw meaningful exception if grain timer is created outside grain context #1858
    • Do not deactivate Stateless Workers upon grain directory partition shutdown. #1838
    • Fixed a NullReferenceException bug in ClientObserverRegistrar. #1823
  • Test
    • Allow liveness config in TestCluster #1818
    • Fix for strange bug in BondSerializer #1790
    • Some improvements for unit testing #1792 #1802
  • Other
    • Move JSON serialization methods into OrleansJsonSerializer #2206
    • Updated package dependencies for Azure Storage, ServiceBus, ZooKeeperNetEx, Protobuf and codegen related
    • Remove UseStandardSerializer and UseJsonFallbackSerializer options #2193 #2204
    • Make IGrainFactory injectable #2192
    • Recover types from ReflectionTypeLoadException #2164
    • Moved Orleans Performance Counters into its own Telemetry Consumer. Now you need to explicitly register the OrleansPerfCounterTelemetryConsumer either by code or XML. More information in #2122 and docs will come later. Microsoft.Orleans.CounterControl can still be used to install the performance counters or you can use InstallUtil.exe OrleansTelemetryConsumers.Counters.dll to install it without depending on OrleansCounterControl.exe
    • New PowerShell client Module #1990
    • Expose property IsLongKey for IAddressable #1939
    • Removed OrleansDependencyInjection package and instead Orleans references Microsoft.Extensions.DepedencyInjection #1911 #1901 #1878
    • Now using Microsoft.Extensions.DepedencyInjection.ServiceProvider as the default service provider if the user does not override it. Grains are still not being injected automatically unless the user opts in by specifying his own Startup configuration that returns a service provider.
    • Do not require explicitly registering grains in ServiceCollection #1901
    • ClusterConfiguration extension for setting Startup class #1842
    • Log more runtime statistics on the client. #1778
    • Added ManagementGrain.GetDetailedHosts() #1794
    • Can get a list of active grains in Orleans for monitoring #1772
    • Rename InstanceName to SiloName. #1740
    • Reworked documentation to use DocFX #1970

v1.3.0-beta1

30 Jul 00:33
Compare
Choose a tag to compare
v1.3.0-beta1 Pre-release
Pre-release

Beta1 release of Microsoft Orleans v1.3.0
It does not yet include all the features that will go into the final 1.3.0 release. Most notably, the Global Single Instance protocol for Multi-Clusters (#1800).

See #1972 for pending work that should go into the final release of 1.3.0

v1.2.3

12 Jul 18:47
Compare
Choose a tag to compare
  • Ability to force creation of Orleans serializers for types not marked with [Serializable] by using GenerateSerializer, KnownType or KnownAssembly.TreatTypesAsSerializable #1888 #1864 #1855
  • Troubleshooting improvements:
    • Fixed stacktrace preservation in exceptions from grain calls (bug introduced in 1.2.0) #1879 #1808
    • Better messaging when silo fails to join due to initial connectivity problems #1866 #1933
    • Throw meaningful exception if grain timer is created outside grain context #1858
  • Bug fixes:
    • Do not deactivate Stateless Workers upon grain directory partition shutdown #1838
    • interception works with Streams and grain extensions #1874
    • Memory Storage provider properly enforces etags for any state that has been added or removed, but does not enforce etags for newly added state. #1885
    • Other minor bug fixes #1884 #1823

v1.2.2

14 Jun 20:22
Compare
Choose a tag to compare
  • Bugfix: Remote stacktrace is once again being included in the exception that bubbles up to the caller (bug introduced in 1.2.0). #1808
  • Bugfix: Memory Storage provider no longer throws NullReferenceException after the grain state is cleared. #1804
  • Microsoft.Orleans.OrleansCodeGenerator.Build package updated to not add the empty orleans.codegen.cs content file at install time, and instead create it at build time (should be more compatible with NuGet Transitive Restore). #1720
  • Added GrainCreator abstraction to enable some unit testing scenarios.#1802 #1792
  • ServiceBus package dependency upgraded to 3.2.2 #1758

v1.2.1

18 May 21:51
Compare
Choose a tag to compare

Bug fixes:

  • SupressDuplicateDeads: Use SiloAddress.Endpoint instead of InstanceName. #1728
  • Added support for complex generic grain parameters #1732
  • Fix race condition bugs in LocalReminderService #1757

v1.2.0

02 May 23:48
Compare
Choose a tag to compare

In addition to all the changes in 1.2.0-beta.

  • Azure storage 7.0 compatibility #1704.
  • Updated to latest version of Consul and ZooKeeper NuGets.
  • Added ability to throw exceptions that occur when starting silo #1711.