orleans-on-containers is a console-based instant messaging application that explores the features of Microsoft Orleans, in particular, the different methods that can be used for clustering.
This project consists of two main parts: the Client and the Silo. The Client is an interactive .NET console application that sends messages to and receives messages from other connected Clients. The Silo is a .NET console application that hosts an Orleans silo. Clients send messages to each other via a grain managed by the Silo. Both the Client and the Silo contain Dockerfiles that allow images to be created for each application, enabling the use of containerisation tools to easily deploy a working instance of orleans-on-containers.
As stated earlier, the aim of this project is to explore the clustering features of Microsoft Orleans and to see how clustering behaves in different hosting configurations. There are currently two supported clustering providers:
- Development (managed by a grain)
- ADO.NET (PostgreSQL)
In addition to the Client and the Silo, a Docker file exists to create an extended Postgres instance that contains the database artifacts required to support Orleans clustering. As part of the creation of the Postgres clustering provider, a special database role called 'orleans_on_containers' is created with reduced access permissions. Further information on accessing the database is listed below.
The simplest way to run orleans-on-containers is to use docker compose
and the yaml files located in src/OrleansOnContainers
. Instructions for running orleans-on-containers are broken down by clustering provider.
An instance of orleans-on-containers configured to use development clustering can be deployed by running docker compose up -d
. The docker attach
command can then be used to attach to a Client instance to interact with the application.
An instance of orleans-on-containers configured to use ADO.NET clustering can be deployed using the compose.postgres.yaml
file. As well as the Silo and the Client, this compose file also builds and runs the extended Postgres instance.
Several options are required to configure ADO.NET clustering. The compose.postgres.yaml
file makes use of the POSTGRES_PASSWORD_FILE
environment variable used by the base Postgres image. The password should be stored in /secrets/postgres_password.txt
.
Important
The /secrets
directory must be placed at the root of the repository.
The following environment variables are also required:
Variable Name | Description |
---|---|
PostgresVersion | A valid postgres Docker image tag used to specify the base image for the postgres service. |
NpgsqlVersion | A vaild Npgsql nuget package version. This package provides Orleans with the capability to interact with the postgres database. |
ConnectionString | The connection string for the postgres database. |
Note
The specialised orleans_on_containers user should be used to connect to the database instead of the postgres superuser. To do so, use the following connection string:
Host=postgres;Port=5432;Database=orleans_on_containers;Username=orleans_on_containers;Password=orleans_on_containers;
To deploy orleans-on-containers with ADO.NET clustering, the above mentioned environment variables must be provided. By placing a file called .env.postgres
in a directory called /env
at the root of the repository, the following command can be used to deploy the services:
docker compose -f compose.postgres.yaml --env-file ../../env/.env.postgres up -d
Both the client
and silo
services depend on the postgres
service being healthy, so you should allow time for that condition to be met.
Upon starting the application you will be greeted by a welcome message. From this lobby area you can join a chat using the command join {chat} as {screen name}
. chat
identifies the chat that you would like to join and screen name
is the identifier that you will appear under when in that chat. If the selected screen name is not available then you will be asked to choose another one.
Once in a chat session you can interact with a chat in the following ways:
- Messages are composed by typing into the console (the client supports alphanumeric and special characters).
- Characters can be removed by using the backspace key.
- Pressing the Enter key will send a message.
- Pressing Ctrl + q, or Esc will quit the current chat session and return you to the lobby.
Messages from other users will appear in the terminal as they arrive and are displayed above your current input.
To terminate the application, type quit
when in the lobby.