Skip to content
Port of LMAX Disruptor to .NET
Branch: master
Clone or download
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
build Simplify build.cake May 20, 2019
src
tools Add reference to ObjectLayoutInspector Mar 12, 2018
.editorconfig Update editorconfig Mar 8, 2018
.gitignore Ignore launch settings file Mar 8, 2018
Cake-Build.bat Adjust cake script references in README.md May 2, 2017
Cake-Pack.bat Update build scripts to support netcoreapp1.1 May 2, 2017
Cake-Perf.bat Update build scripts to support netcoreapp1.1 May 2, 2017
Cake-Test.bat Adjust cake script references in README.md May 2, 2017
LICENSE Added Apache License Jul 3, 2013
README.md Use azure build status in README May 20, 2019
azure-pipelines.yml Add azure-pipelines.yml May 20, 2019

README.md

.NET port of LMAX Disruptor

Build Status NuGet

This project aims to provide the full functionality of the Disruptor to CLR projects.

Documentation

There is no specific documentation for this project, but most of the information from the Java version is applicable to the .NET version, especially the core concepts.

Roadmap

  • Include latest changes made to the future Java versions
  • Remove exception-based APIs
  • Improve documentation

What's new?

28/04/2018 (v3.4.1):

  • Fix invalid IL code that caused an exception on Mono

28/04/2018 (v3.4.0-alpha):

  • Remove Histogram and MutableLong
  • Remove base type from SingleProducerSequencer and MultiProducerSequencer
  • Fix race between run() and halt() on BatchEventProcessor
  • Make obsolete exception-based TryNext methods
  • (Perf) Use generated struct types to improve BatchEventProcessor and ProcessingSequenceBarrier performance
  • (Perf) Remove unneeded unsafe code from MultiProducerSequencer
  • (Perf) Use custom IL to improve RingBuffer indexer performance

05/02/2018 (v3.3.8):

  • Add exception free overloads to ISequenced.TryNext
  • Revert belt and braces WaitStategy signalling.

02/11/2017 (v3.3.7):

  • All features available in Java Disruptor 3.3.7 have been ported
  • Drop .NET Core 1.1
  • Add .NET Standard 2.0

02/05/2017 (v3.3.6):

  • Support .NET Core 1.1

01/04/2017 (v3.3.6-alpha):

  • All features available in Java Disruptor 3.3.6 have been ported
  • Use an aggressive spin wait in all blocking wait strategies (#25)
  • Add a new blocking low CPU usage wait strategy

02/08/2016 (v3.3.5):

  • All features available in Java Disruptor 3.3.5 have been ported

04/07/2016 (v3.3.4):

  • All features available in Java Disruptor 3.3.4 have been ported by the team at ABC Arbitrage
  • Now targeting the .NET 4.6.1 framework and using C# 6 features

11/7/2013 (v2.10.0):

  • All features available in Java Disruptor 2.10.0 have been ported

Getting Started

The quickest way to get started with the disruptor is by using the NuGet package

Build from source and run tests

You may also build the Disruptor directly from the source:

  • You need Visual Studio 2017
  • run Cake-Build.bat, it will compile, run the tests and output binaries and results into \output\assembly folder

You can also run all the performance tests by running Cake-Perf.bat.

License

Copyright Olivier Deheurles

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this project except in compliance with the License.

You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

You can’t perform that action at this time.