Canvas.Views.Web 4.5.3

There is a newer version of this package available.
See the version list below for details.
dotnet add package Canvas.Views.Web --version 4.5.3                
NuGet\Install-Package Canvas.Views.Web -Version 4.5.3                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Canvas.Views.Web" Version="4.5.3" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Canvas.Views.Web --version 4.5.3                
#r "nuget: Canvas.Views.Web, 4.5.3"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Canvas.Views.Web as a Cake Addin
#addin nuget:?package=Canvas.Views.Web&version=4.5.3

// Install Canvas.Views.Web as a Cake Tool
#tool nuget:?package=Canvas.Views.Web&version=4.5.3                

Distribution - Virtual Actor Framework

There is decent amount of actor-like frameworks, including those that support an idea of Virtual Actors, e.g. Orleans and Proto.Actor

The two mentioned frameworks are the most flexible but have some drawbacks, like extra build step or inability to use different transport protocol. Below is the list of features built in the current framework. Each of them can be considered as an advantage or a disadvantage depending on specific use-case.

Status

For virtual actors and reactive store

Install-Package Distribution

For clusters and interserver communication

Install-Package Distribution.Cluster

GitHub Workflow Status (with event) GitHub GitHub

Features

  • Safe single-threaded execution in a background worker without locks
  • Zero configuration
  • Local actors and store are cross-platform .NET Standard 2.0
  • UDP broadcasting for automatic service discovery without a single point of failure
  • Peer-To-Peer network of independent nodes without consensus leaders
  • Random placement of virtual actors within a cluster
  • Ability to create multiple instances of the same type of actor using unique ID
  • Ability to override any layer, including protocol, actor placement strategy, service discovery, etc
  • No dangerous binary serialization or 3rd party serialization libraries
  • Simple C# POCO structs for messages, no attributes or other decorators
  • Process messages using single or multiple actors with [Subscription] attribute
  • Kestrel server middleware to process message queries
  • Automatic loading and mapping for actors and messages at startup

Sample

This is an example of using actors locally within the same app.

// Define message and response format 

public class DemoMessage { public string Name { get; set; }}
public class DemoResponse { public string Data { get; set; }}

// Define actor processing this particular message   

public class DemoActor
{
  [Processor]
  public virtual Task<DemoResponse> SomeAction(DemoMessage message)
  {
    return Task.FromResult(new DemoResponse { Data = "Response from actor" });
  }
}

// Processing

public class Client
{
  async Task SendMessageToActor()
  {
    var scene = new Scene();
    var message = new DemoMessage { Name = "Message to actor" };
    var response = await scene.Send<DemoResponse>("Custom Actor ID", message);

    Console.WriteLine("Response : " + response.Data);
  }
}

An example with a distributed network of actors in the cluster is a bit more complex and can be found in the Samples directory.

Also, can be used as an alternative to RX.NET.

Disclaimer

In order to keep things simple and flexible, the main focus was on simplicity and scalability rather than performance.

Notes

Practically all parts of this framework use the most basic implementation of each layer meaning that it's a general purpose implementation that may need to be extended to solve more specific problems.

  1. HTTP and JSON are somewhat slow, but were chosen for communication instead of sockets to make it easier to build a network of a million of nodes without a need to manage permanent connections between peers.
  2. UDP broadcasting can detect nodes within the same network segment. To make peer discovery global there will be a need for services like Consul or manual NAT traversing.
  3. There is a heavy use of reflection for mapping between actors and messages. No benchmarks, but switching to compiled delegates may improve latency.

Improvements

Even though existing modules are the most basic at the core, they can be easily extended or overridden to achieve more specific goals.

  1. When there is no requirement to have millions of nodes, it's possible to implement ICommunicator and use sockets with Message Pack or Flat Buffers for lower latency.
  2. Peer discovery is encapsulated inside of the Beacon class. When needed, it's easy to override any of its method or implement IBeacon to use it with Consul or some other service discovery tool.
Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
4.5.6 83 12/10/2024
4.5.5 187 10/26/2024
4.5.4 77 10/26/2024
4.5.3 101 10/25/2024
4.5.2 76 10/24/2024
4.5.1 83 10/24/2024
4.5.0 86 10/24/2024
4.0.0 111 10/9/2024
3.3.0 96 10/6/2024
3.2.9 105 9/28/2024
3.2.8 96 9/25/2024
3.2.7 92 9/25/2024
3.2.6 84 9/25/2024
3.2.5 93 9/24/2024
3.2.4 142 8/27/2024
3.2.3 116 8/24/2024
3.2.2 117 8/19/2024
3.2.1 127 8/18/2024
3.2.0 119 8/16/2024
3.1.5 119 6/24/2024
3.1.4 137 6/2/2024
3.1.3 117 5/29/2024
3.1.2 115 5/26/2024
3.1.1 107 5/23/2024
3.1.0 140 5/21/2024
3.0.9 108 5/21/2024
3.0.8 142 3/25/2024
3.0.7 123 3/24/2024
3.0.6 112 3/20/2024
3.0.5 133 3/18/2024
3.0.4 110 3/18/2024
3.0.3 119 3/18/2024
3.0.1 118 3/17/2024
3.0.0 120 3/15/2024
2.0.7 120 3/14/2024
2.0.6 121 3/14/2024
2.0.5 105 3/7/2024
2.0.3 134 3/3/2024
2.0.2 114 3/3/2024
2.0.1 111 3/1/2024
2.0.0 111 2/26/2024
1.9.9 101 2/25/2024
1.9.8 114 2/24/2024
1.9.6 119 2/17/2024
1.9.5 109 2/17/2024
1.9.4 110 2/15/2024
1.9.3 144 2/11/2024
1.9.2 111 2/11/2024
1.9.1 97 2/11/2024
1.9.0 114 2/9/2024
1.8.9 135 2/8/2024
1.8.8 123 2/8/2024
1.8.7 115 2/5/2024
1.8.6 122 2/5/2024
1.8.5 131 1/28/2024
1.8.4 126 1/26/2024
1.8.3 104 1/26/2024
1.8.2 109 1/25/2024
1.8.1 139 1/18/2024
1.8.0 256 5/29/2023
1.7.9-prerelease 154 3/12/2023
1.7.8-prerelease 169 3/5/2023
1.7.7-prerelease 150 2/24/2023
1.7.6-prerelease 172 2/20/2023
1.7.5-prerelease 151 2/14/2023
1.7.1-prerelease 166 2/9/2023
1.7.0-prerelease 154 2/5/2023
1.6.7-prerelease 169 2/4/2023
1.6.6-prerelease 185 2/1/2023
1.6.5-prerelease 226 1/12/2023
1.6.4-prerelease 156 1/8/2023
1.6.3-prerelease 174 12/18/2022
1.6.2-prerelease 167 12/4/2022
1.6.1-prerelease 185 11/24/2022
1.6.0-prerelease 180 11/19/2022
1.5.9-prerelease 179 11/6/2022
1.5.6-prerelease 190 11/3/2022
1.5.5-prerelease 156 11/2/2022
1.5.3-prerelease 167 10/29/2022
1.5.2-prerelease 173 10/2/2022
1.5.1-prerelease 185 10/2/2022
1.5.0-prerelease 178 9/21/2022
1.4.0-prerelease 184 8/7/2022
1.3.9-prerelease 207 8/7/2022
1.3.8-prerelease 206 8/7/2022
1.3.7-prerelease 176 8/2/2022
1.3.6-prerelease 167 8/1/2022
1.3.5-prerelease 172 8/1/2022
1.3.4-prerelease 175 8/1/2022
1.3.3-prerelease 172 8/1/2022
1.3.2-prerelease 185 7/29/2022
1.3.1-prerelease 203 7/21/2022
1.3.0-prerelease 190 7/13/2022
1.2.9-prerelease 200 7/11/2022
1.2.8-prerelease 181 7/9/2022
1.2.7-prerelease 184 7/9/2022
1.2.6-prerelease 205 7/7/2022
1.2.5-prerelease 191 7/1/2022
1.2.4-prerelease 217 5/8/2022
1.2.3-prerelease 200 4/18/2022
1.2.2-prerelease 187 4/17/2022
1.2.1-prerelease 207 4/16/2022
1.2.0-prerelease 192 4/16/2022
1.1.9-prerelease 203 4/15/2022
1.1.8-prerelease 190 4/15/2022
1.1.7-prerelease 199 4/14/2022
1.1.6-prerelease 201 4/12/2022
1.1.5-prerelease 187 4/9/2022
1.1.4-prerelease 184 4/7/2022
1.1.3-prerelease 215 4/6/2022
1.1.2-prerelease 170 4/5/2022
1.1.1-prerelease 177 4/4/2022
1.1.0-prerelease 195 4/3/2022
1.0.9-prerelease 192 4/3/2022
1.0.8-prerelease 208 4/3/2022
1.0.7-prerelease 186 4/3/2022
1.0.6-prerelease 199 4/3/2022
1.0.5-prerelease 201 3/26/2022
1.0.0-prerelease 199 3/24/2022