In the Matrix protocol and federated architecture, Homeservers are key components that host 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 also sends events that gets relayed to other networks.
You can choose to install a Homeserver following and of the two methods listed below:
- ****Automated Installation: Install Synapse and Rocket.Chat using a simple setup script.
- ****Manual Installation: Manually install and configure your Homeserver with Rocket.Chat.
{% hint style="success" %} We recommend using automatic installation since this comes with some configurations done. {% endhint %}
- 8GB of RAM
- 2CPU
- 20GB of Storage
- Ubuntu 20.04
{% hint style="info" %} You are required to have a domain available to host your Matrix Homeserver. {% endhint %}
There is an important setting you must be aware of 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 communicaation.
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.
allow_public_rooms_without_auth: true
allow_public_rooms_over_federation: true
- Following the automated installation enables everything by default and can be disabled by editing the generated configuration at
data/matrix/synapse
.
The Automated install makes it simple for you to install a Matrix Homeserver pre-configured with Rocket.Chat.
You are required to have the following on your system before installing.
- Docker
- Docker compose (> 2.3.3)
- 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
bash <(curl -L -s https://go.rocket.chat/i/federation-setup)
- Follow the instructions provided by the script to configure the workspace:
- Server's hostname: Add your domain when asked.
- Create
A
domain records pointing to your server's IP address as requested.synapse.<your-domain>
matrix.<your-domain>
traefik.<your-domain>
- Enter your email address, this is used to issue an SSL certificate for your domain.
- Start the container by running:
docker compose up -d
{% hint style="success" %} Installing with the Automated setup automatically sets the values at Administration > Workspace > Settings > Federation > Matrix Bridge. {% endhint %}
{% hint style="info" %} Rocket.Chat Matrix setup CLI coming soon. {% endhint %}
To test and make sure your Matrix setup is successful,
- In the same directory where the setup was initiated, download and execute the test script.
bash <(curl -L -s https://go.rocket.chat/i/federation-test)
You get a notice about the setup status.
Follow this guide to set up a Matrix Homeserver with Synapse manually.
- Install Synapse.
- Obtain Lets Encrypt Certificate.
- Setup Element (Optional).
- Configure Nginx using the certificates, reverse proxying the requests to Synapse.
- Point all the generated DNS records to your server's IP address (all to the same IP).
- Configure the support for Application Service on the Matrix Homeserver: This can be done by creating a
registration.yaml
file under theapp/matrix-federation-config
directory with the content provided in Workspace > Settings > Federation > Matrix Bridge > Registration File.
App Service Registration File content
- Complete Matrix Bridge Configuration following this guide
{% content-ref url="../matrixbridge-configuration.md" %} matrixbridge-configuration.md {% endcontent-ref %}
To test your manual installation:
- Make sure Synapse is up and running.
- Ensure the federation setup is running, go to Matrix Federation Tester, and paste your Matrix Homeserver name (only the server name, not the full link).