Skip to content

Installing LiveKit on an Existing Self Hosted Foundry Server

DAMO238 edited this page Sep 27, 2022 · 5 revisions

Assumptions

These instructions assume that you have an existing self-hosted Foundry server that was set up behind an NGINX reverse proxy like this, and that you want to install and run LiveKit on the same server. In all example commands below, replace example.com with your server's FQDN.

Prepare LiveKit subdomains

Assuming that there is an existing DNS A or CNAME record pointing at foundry.example.com:

  • Create a DNS CNAME record for livekit.example.com pointing to the same IP address as foundry.example.com
  • Create a DNS CNAME record for livekit-turn.example.com pointing to the same IP address as foundry.example.com

Prepare the Server

  • Update existing server software: sudo apt update && sudo apt dist-upgrade -y

  • Open ports on the firewall

sudo ufw allow 22/tcp
sudo ufw allow 80/tcp
sudo ufw allow 443/tcp
sudo ufw allow 7881/tcp
sudo ufw allow 443/udp
sudo ufw allow 50000:60000/udp
sudo ufw enable

Configure Reverse Proxy for LiveKit

  • Create log directories
sudo mkdir /var/log/nginx/livekit
sudo mkdir /var/log/nginx/livekit-turn
  • Save the following text in a file named livekit.example.com.conf in the folder /etc/nginx/sites-available/.
server {
    listen 80;
    listen [::]:80;
    server_name                 livekit.example.com;

    access_log                  /var/log/nginx/livekit/access.log;
    error_log                   /var/log/nginx/livekit/error.log;

    location / {
        proxy_set_header        Host $host;
        proxy_set_header        X-Real-IP $remote_addr;
        proxy_set_header        X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header        X-Forwarded-Proto $scheme;

        proxy_pass              http://127.0.0.1:7880;

        proxy_http_version      1.1;
        proxy_set_header        Upgrade $http_upgrade;
        proxy_set_header        Connection "Upgrade";
        proxy_read_timeout      90;

        proxy_redirect          http://127.0.0.1:7880 http://livekit.example.com;
    }
}
  • Save the following text in a file named livekit-turn.example.com.conf in the folder /etc/nginx/sites-available/.
server {
    listen 80;
    listen [::]:80;
    server_name                 livekit-turn.example.com;

    access_log                  /var/log/nginx/livekit-turn/access.log;
    error_log                   /var/log/nginx/livekit-turn/error.log;

    location / {
        proxy_set_header        Host $host;
        proxy_set_header        X-Real-IP $remote_addr;
        proxy_set_header        X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header        X-Forwarded-Proto $scheme;

        proxy_pass              http://127.0.0.1:5349;

        proxy_http_version      1.1;
        proxy_set_header        Upgrade $http_upgrade;
        proxy_set_header        Connection "Upgrade";
        proxy_read_timeout      90;

        proxy_redirect          http://127.0.0.1:5349 http://livekit-turn.example.com;
    }
}
  • Make links to enable the new configuration files:
sudo ln -s /etc/nginx/sites-available/livekit.example.com.conf /etc/nginx/sites-enabled/livekit.example.com.conf
sudo ln -s /etc/nginx/sites-available/livekit-turn.example.com.conf /etc/nginx/sites-enabled/livekit-turn.example.com.conf
  • Test nginx configuration: sudo nginx -t

  • Restart reverse proxy: sudo service nginx restart

Create SSL certificates

  • Use certbot to generate Let's Encrypt SSL certificates for the new subdomains: sudo certbot --nginx

  • Test nginx configuration: sudo nginx -t

  • Restart reverse proxy: sudo service nginx restart

  • Test Let's Encrypt autorenewal: sudo certbot renew --dry-run

Install LiveKit

  • (Optional) Run this if you don't have docker on your server yet: sudo apt install docker.io

  • Generate configuration and installation files: sudo docker run --rm -it -v$PWD:/output livekit/generate

    • Input primary domain name: livekit.example.com
    • Input TURN server domain name: livekit-turn.example.com
    • Select latest version of LiveKit
    • Select no to use bundled copy of Redis
    • Select Startup Shell Script
    • Copy down the API Key and API Secret displayed on screen. You will need these in order to connect to the LiveKit server. You can also find the Key and Secret in the file livekit.yaml in the generated installation directory.
  • Change to the generated installation directory: cd livekit.example.com

  • Make install script executable: sudo chmod +x init_script.sh

  • Install LiveKit using the generated installation script: sudo ./init_script.sh
    The script will install docker again. This is probably okay. YMMV.

  • Run sudo -e /opt/livekit/docker-compose.yaml to open the file in your favourite text editor using root priviledges and comment out the entire caddy block. The file should now look something like this:

# LiveKit requires host networking, which is only available on Linux
# This compose will not function correctly on Mac or Windows
version: "3.9"
services:
  #  caddy:
  #    image: livekit/caddyl4
  #    command: run --config /etc/caddy.yaml --adapter yaml
  #    restart: unless-stopped
  #    network_mode: "host"
  #    volumes:
  #      - ./caddy.yaml:/etc/caddy.yaml
  #      - ./caddy_data:/data
  livekit:
    image: livekit/livekit-server:latest
    command: --config /etc/livekit.yaml
    restart: unless-stopped
    network_mode: "host"
    volumes:
      - ./livekit.yaml:/etc/livekit.yaml
  redis:
    image: redis:6-alpine
    command: redis-server /etc/redis.conf
    network_mode: "host"
    volumes:
      - ./redis.conf:/etc/redis.conf
  • Restart livekit using service livekit-docker restart for Debian or systemctl restart livekit-docker for Ubuntu.

Install LiveKit Module for Foundry

  • Install the LiveKit AVClient module from the Add-on Modules Tab in Foundry

  • Open a world file and enable the LiveKit AVClient module

  • Open the Core Configuration Settings and click on Configure Audio/Video

  • Click on the Server tab and input the following settings:

LiveKit Server Address:  livekit.example.com
LiveKit API Key:         <value from livekit.yaml file>
LiveKit API Secret:      <value from livekit.yaml file>
  • Enable Audio/Video on the General tab to connect to LiveKit