Matrix Homeserver Setup

Homeservers are key components that hosts user accounts and other data related to communication. It also facilitates communication between users on different servers by relaying messages through a network of matrix servers until it reaches the destination. Rocket.Chat listens to events happening in the homeserver and sends events relayed to other networks.

You can set up your federated Rocket.Chat workspace using any of the following methods:

System Requirements

  • 8GB of RAM

  • 2CPU

  • 20GB of Storage

  • Ubuntu 20.04

Important warning about the installation

You must be aware of this vital setting before proceeding with the installation.

  • Enabling ephemeral events like user typing indicator can affect the performance of your Matrix Homeserver and Rocket.Chat server for federated communication. This can be enabled by adding the following property in your Application Service configuration file:

de.sorunome.msc2409.push_ephemeral: true
  • Add and enable the following properties to make public rooms visible and searchable on other Matrix networks.

  • Following the automated installation enables everything by default and can be disabled by editing the generated configuration at data/matrix/synapse.

Automated Installation

The automated install offers a simple option to install a matrix homeserver pre-configured with Rocket.Chat.

Prerequisites

You are required to have the following on your system before installing.

If you don't have them installed, you can conveniently set them up using Docker's official helper script:

  • To run Docker commands without using sudo, add the current user to the Docker group and then reboot using the following commands:

  • A domain pointing to your server's IP.

Installation Steps

  • Open your terminal in any directory of your choice.

  • Download and execute the script by running the following command. This creates a docker-compose and a .env file that can be edited as needed

  • Follow the instructions provided by the script to configure the workspace:

    • Server's hostname: Add your domain name.

    • Create A domain records pointing to your server's IP address as requested.

      • synapse.<your-domain>

      • element.<your-domain>

      • traefik.<your-domain>

    • Enter your email address. This is used to issue an SSL certificate for your domain.

Update your Rocket.Chat version

If you want to install a specific version Rocket.Chat, navigate to the .env file, and modify the RELEASE variable to point to the docker image tag of that version.

  • Start the container by running the following command:

Rocket.Chat Matrix setup CLI is coming soon!

Testing the Setup

To test and ensure your Matrix setup is successful,

  • Download and execute the test script in the same directory where the setup was initiated.

  • You get a notice about the setup status.

Standalone Manual installation

Prerequisites

If you don't have it installed, you can conveniently set it up using Docker's official helper script:

  • To run Docker commands without using sudo, add the current user to the Docker group and then reboot using the following commands:

  • Your domain records and SSL certificates. For example, if your domain is ps-rocketchat.com, you can create subdomains under it like matrix2.ps-rocketchat.com.

  • All the generated DNS records pointed to your server's IP address (the same IP address).

Installation Steps

To set up a Matrix Homeserver with Synapse manually,

  • Set up the docker network with this command:

  • To set up a Synapse server, run this command to set up the Synapse environment:

The homeserver.yaml configuration file is stored in the "data" directory of your current working directory. To start the Synapse Docker, use this command:

  • Next, set up MongoDB with this command:

  • To start Rocket.Chat , execute this command:

Set up Reverse Proxy

Before accessing your Rocket.Chat workspace, set up the reverse proxy following the next steps:

  • Obtain SSL certificates for your domain records, if you don't have any. You can use Lets Encrypt.

  • Create an nginx.conf file containing forwarding rules for each domain. Create the file in the same folder where you intend to start your docker instance and paste the following contents:

  • Start the reverse proxy mapping the nginx.conf and the certificate and private key for SSL by running this command:

  • Visit your domain URL in a web browser to access your Rocket.Chat workspace. Complete the Rocket.Chat Setup Wizard and your workspace will be set up and ready to use.

Configure Rocket.Chat Matrix Bridge

See Matrix Bridge Configuration to learn more about the configurations and their definitions.

Now that your workspace is set up, navigate to Administration > Workspace > Settings > Federation > Matrix Bridge and follow these steps:

  • Enable Matrix Bridge.

  • Update the following fields with these values:

    • Homeserver URL: http://synapse:8008

    • Homeserver Domain: <your domain>

    • Bridge URL: http://rocketchat:3300

  • Save your changes and copy the contents of your registration file.

App Service Registration File content
  • Configure the support for Application Service on the matrix home server by creating a registration.yaml file in the data directory that was created for synapse earlier and paste the contents of the registration file.

  • Add the following content at the end of the homeserver.yaml file in that same data directory and save:

  • Now restart the rocketchat and synapse containers with these commands:

To run multiple Rocket.Chat instances, see Clustered Manual Installation.

Testing your setup

For testing the Matrix setup, you can use the Matrix Federation Tester if your certificates are from a “standard” CA recognized by Linux distros, etc.

For more real-time testing, visit Element and complete these steps:

  • Create a user using matrix.org as a homeserver (assuming the default whitelisted matrix.org is still set on your matrix homeserver)

  • Start a direct message from your Rocket.Chat workspace with the user you just created using their matrixId (@username:matrix.org).

  • Check Element to confirm that you received the DM from your Rocket.Chat user. You can choose to respond to the message from Element and confirm that you can receive the response in your Rocket.Chat workspace.

Use your own federation-tester

You can decide to use your own federation tester if you're in an air-gapped environment or if you use non-standard certificates.

  • Download the GitHub project locally and run the test yourself from (supposing you have the CA in your keychain) using these commands:

  • Now, execute this command:

Clustered Manual Installation

To distribute the work on Rocket.Chat, you run two identical Rocket.Chat applications ( can be named rocketchat1 and rocketchat2) that both connect to the same MongoDB. To make this setup accessible externally, you use an NGINX load balancer. This load balancer acts as a single entry point, and internally it distributes the workload between the two Rocket.Chat instances.

  • Start the second Rocket.Chat with this command:

  • Update the nginx.conf file with these contents

  • Restart nginx with this command:

  • Navigate to Administration > Workspace > Settings > Federation > Matrix Bridge and update these configurations:

Matrix Bridge configurations
  • Save your changes and copy the contents of your registration file.

Registration File
  • Paste the contents in the data/registration.yaml file .

  • Now restart the rocketchat and synapse containers with these commands:

Reset your environment and Restart your setup

Execute the following commands to clean up your files, reset your environment, and restart your setup:

If you had a cluster set, you also need to stop/remove the rocketchat2 docker instance.

Last updated