MassTransit
MassTransit is a free, open-source distributed application framework for .NET. MassTransit makes it easy to create applications and services that leverage message-based, loosely-coupled asynchronous communication for higher availability, reliability, and scalability.
MassTransit is Apache 2.0 licensed.
Build Status
Branch | Status |
---|---|
master | |
develop |
MassTransit Nuget Packages
Getting started with MassTransit
In order to get started with MassTransit, you can have a look at the documentation, which is located at http://masstransit-project.com/.
Simplest possible thing:
install-package MassTransit.RabbitMq
and then:
// Message Definition
class MyMessage
{
public string Value { get; set; }
}
// Code Snippet for Console Application
async Task Main()
{
var bus = Bus.Factory.CreateUsingRabbitMq(sbc =>
{
var host = sbc.Host("localhost"), h =>
{
h.Username("guest");
h.Password("guest");
});
sbc.ReceiveEndpoint(host, "my_queue", endpoint =>
{
endpoint.Handler<MyMessage>(async context =>
{
await Console.Out.WriteLineAsync($"Received: {context.Message.Value}");
});
});
});
await bus.StartAsync();
await bus.Publish(new MyMessage { Value = "Hello, World." });
Console.ReadLine();
await bus.StopAsync();
}
You will also need to set up RabbitMQ;
- Install Erlang using the installer. (Next -> Next ...)
- Install RabbitMQ using the installer. (Next -> Next ...) You now have a RabbitMQ broker (look in
services.msc
for it) that you can log into usingguest
,guest
. You can see message rates, routings and active consumers using this interface.
Please note
You need to add the management interface before you can login. First, from an elevated command prompt, change directory to the sbin folder within the RabbitMQ Server installation directory e.g. %PROGRAMFILES%\RabbitMQ Server\rabbitmq_server_3.5.3\sbin\
Next, run the following command to enable the rabbitmq management plugin:
rabbitmq-plugins.bat enable rabbitmq_management
Downloads
Download from NuGet 'MassTransit' Search NuGet for MassTransit
Download the continuously integrated Nuget packages from AppVeyor.
Supported transports
We support RabbitMQ and Azure Service Bus message brokers.
Mailing list
Discord
Get help live at the MassTransit Discord server.
Gitter Chat
While Discord is preferrred, the Gitter chat room is still available:
GitHub Issues
Pay attention
Please do not open an issue on github, unless you have spotted an actual bug in MassTransit. If you are unsure, ask on the mailing list, and if we confirm it's a bug, we'll ask you to create the issue. Issues are not the place for questions, and they'll likely be closed.
This policy is in place to avoid bugs being drowned out in a pile of sensible suggestions for future enhancements and calls for help from people who forget to check back if they get it and so on.
Building from Source
- Install the latest .NET Core 3.1 SDK.
- Clone the source down to your machine.
git clone git://github.com/MassTransit/MassTransit.git
- Run
build.ps1
orbuild.sh
.
Contributing
- Turn off
autocrlf
.git config core.autocrlf false
- Hack!
- Make a pull request.
Builds
MassTransit is built on AppVeyor
REQUIREMENTS
- .Net 4.6.1 or .NET Standard 2.0
CREDITS
Logo Design by The Agile Badger