Skip to content
This repository has been archived by the owner on Sep 3, 2022. It is now read-only.

reuzel/CqlSharp

Folders and files

NameName
Last commit message
Last commit date

Latest commit

aae0ff3 · Sep 7, 2014
Sep 5, 2014
Sep 5, 2014
Sep 7, 2014
Sep 7, 2014
Sep 7, 2014
Sep 7, 2014
Sep 5, 2014
Aug 29, 2014
Mar 12, 2013
Sep 5, 2014
Sep 7, 2014
Sep 7, 2014
Jun 9, 2014
Mar 10, 2013

Repository files navigation

CqlSharp

CqlSharp is a high performance, asynchronous ADO.NET data provider for Cassandra implementing the CQL binary protocol.

Please see the Wiki for more extensive documentation.

Installation

The latest release of CqlSharp can be found as a package on NuGet. Please install from there.

If you would like to have Linq support, please have a look at CqlSharp.Linq, which can be installed via the CqlSharp.Linq NuGet package.

Features

  • The API implements the ADO.NET interfaces. If you are familiar with SqlConnection, SqlCommand, and SqlReader, you should be able to use CqlSharp with no difficulty.
  • Linq-2-CQL support is provided through the seperate CqlSharp.Linq package
  • CqlSharp is an implementation of the (new) CQL Binary Protocol and therefore requires Cassandra 1.2 and up
  • CqlSharp supports all the binary protocol v2 features: batching, paging, bound query variables, result schema caching, check-and-set (CAS) statements, and sasl-authentication
  • Supports fast mapping of objects to query parameters, or query results to objects. Mapping is tunable by decorating your classes via Table and Column attributes.
  • CqlSharp allows for partition/token aware routing of queries. This allows queries to be directly sent to the Cassandra nodes that are the 'owner' of that data.
  • Query timeouts and cancellation is supported
  • Query tracing is supported.
  • CqlSharp supports Snappy compression of queries and responses
  • The API is predominately asynchronous, heavily relying on the System.Threading.Tasks namespace. Synchronous alternatives are available for convenience.
  • CqlSharp is 100% written in C#, and requires .NET 4.5. It has no dependencies on other packages or libraries.
  • Configuration is done through connection strings. The simultaneous use of multiple Cassandra clusters is supported.
  • Rows returned from select queries are read via a pull-model, allowing for large result sets to be processed efficiently. Query results may be buffered in memory as well.
  • Most behavioral aspects of the CqlSharp are configurable: max number of connections, new connection threshold, discovery scope, max connection idle time, etc. etc.
  • Relative Node Discovery: given the 'seed' nodes in your connection string, CqlSharp may find other nodes for you: all nodes in your cluster, nodes in the same data center, or the nodes in the same rack
  • Load balanced connection management: you can give your queries a load 'factor' and the client will take that into account when picking connections to send queries over.
  • Queries will be automatically retried when connections or nodes fail.
  • Node monitoring: Node failure is automatically detected. Recovery checks occur using an exponential back-off algorithm
  • CqlSharp listens to Cassandra events for node up, new node and node removed messages such that Cluster changes are automatically incorporated

Some non-functionals

  • All I/O is done asynchronously using the wonderful TPL and .NET 4.5 async/await support. As a result, the client should be quite efficient in terms of threading. This makes it especially suitable in server environments where all threads are necessary to handle incoming requests.
  • Buffering, MemoryPools and Task result caching reduce GC activity, especially important when doing high volumes of queries in a short time frame
  • CqlSharp uses multiple connections in parallel to execute queries faster. Queries are also multiplexed on single connections, leading to efficient connection usage.
  • Using compiled expressions, mapping rows to objects and vice-versa is very fast

License

CqlSharp and CqlSharp.Linq are both available under the Apache License version 2.0.

Wish list

  • Even better performance, e.g. by creating using more sophisticated memory pools that support multiple buffer sizes.
  • Linq2Cql
  • Alternative retry models (e.g. retry with reduced consistency)