Skip to content

OpenVidu Elastic: AWS Configuration and Administration#

The deployment of OpenVidu Elastic on AWS is automated using AWS CloudFormation, with Media Nodes managed within an Auto Scaling Group. This group dynamically adjusts the number of instances based on a target average CPU utilization. Internally, the AWS deployment mirrors the on-premises setup, allowing you to follow the same administration and configuration guidelines provided in the On Premises Elastic documentation. However, there are specific considerations unique to the AWS environment that are worth taking into account.

Cluster Shutdown and Startup#

The Master Node is an EC2 instance, while the Media Nodes are part of an Auto Scaling Group. The process for starting and stopping these components differs. The following sections detail the procedures.

To shut down the cluster, you need to stop the Media Nodes first and then stop the Master Node. This way, any ongoing session will not be interrupted.

  1. Navigate to the CloudFormation Dashboard on AWS.
  2. Select the CloudFormation Stack that you used to deploy OpenVidu Elastic.
  3. In the "Resources" tab, locate the resource with the logical ID: OpenViduMediaNodeASG, and click on it to go to the Auto Scaling Group Dashboard with the Auto Scaling Group of the Media Nodes selected.
    Select Auto Scaling Group
  4. Click on "Actions > Edit".
    Edit Auto Scaling Group
  5. Set the "Desired capacity", "Min desired capacity", and "Max desired capacity" to 0, and click on "Update".
    Set Desired Capacity to 0
  6. Wait until the "Instance Management" tab shows that there are no instances in the Auto Scaling Group.

    Instance Management

    Warning

    It may happen that some instances are still in the "Terminating:Wait" lifecycle state after setting the desired capacity to 0. This is because the Auto Scaling Group waits for the instances to finish processing any ongoing room, ingress, or egress operations before terminating them. This can take a few minutes. If you want to force the termination of the instances, you can manually terminate them from the EC2 Dashboard.

  7. After confirming that all Media Node instances are terminated, go back to the CloudFormation Stack and locate the resource with the logical ID: OpenViduMasterNode. Click on it to go to the EC2 Dashboard with the Master Node instance selected.

    Delete CloudFormation Stack

  8. Right-click on the instance and select "Stop instance".
    Stop instance

To start the cluster, we recommend starting the Master Node first and then the Media Nodes.

  1. Navigate to the CloudFormation Dashboard on AWS.
  2. Select the CloudFormation Stack that you used to deploy OpenVidu Elastic.
  3. Locate the resource with the logical ID: OpenViduMasterNode. Click on it to go to the EC2 Dashboard with the Master Node instance selected.
    Select CloudFormation Stack
  4. Right-click on the instance and select "Start instance".
    Start instance
  5. Wait until the instance is running.
  6. Go back to the CloudFormation Stack and locate the resource with the logical ID: OpenViduMediaNodeASG. Click on it to go to the Auto Scaling Group Dashboard with the Auto Scaling Group of the Media Nodes selected.
    Select Auto Scaling Group
  7. Click on "Actions > Edit".
    Edit Auto Scaling Group
  8. Set the "Desired capacity", "Min desired capacity", and "Max desired capacity" to the desired number of Media Nodes, and click on "Update". In this example, we set the desired capacity to 2.
    Set Desired Capacity to 2
  9. Wait until the "Instance Management" tab shows that there are the desired number of instances in the Auto Scaling Group.
    Instance Management

Change the instance type#

It is possible to change the instance type of both the Master Node and the Media Nodes. However, since the Media Nodes are part of an Auto Scaling Group, the process differs. The following section details the procedures.

Warning

This procedure requires downtime, as it involves stopping the Master Node.

  1. Shutdown the cluster.

    Info

    You can stop only the Master Node instance to change its instance type, but it is recommended to stop the whole cluster to avoid any issues.

  2. Go to the CloudFormation Stack and locate the resource with the logical ID: OpenViduMasterNode. Click on it to go to the EC2 Dashboard with the Master Node instance selected.

    Select CloudFormation Stack

  3. Right-click on the instance and select "Instance Settings > Change Instance Type".
    Change instance type
  4. Select the new instance type and click on "Apply".
  5. Start the cluster.
  1. Go to the CloudFormation Dashboard on AWS.
  2. Select the CloudFormation Stack that you used to deploy OpenVidu Elastic.
  3. Locate the resource with the logical ID: OpenViduMediaNodeLaunchTemplate. Click on it to go to the Launch Template Dashboard with the Launch Template of the Media Nodes selected.
    Select Launch Template
  4. Click on "Actions > Modify template (Create new version)".
    Edit Launch Template
  5. In the "Instance type" section, select the new instance type and click on "Create template version".
    Change instance type
  6. Go to the CloudFormation Stack and locate the resource with the logical ID: OpenViduMediaNodeASG. Click on it to go to the Auto Scaling Group Dashboard with the Auto Scaling Group of the Media Nodes selected.
    Select Auto Scaling Group
  7. Click on "Actions > Edit".
    Edit Auto Scaling Group
  8. In the Launch Template section, select the new version of the launch template we just created at step 5, which is the highest version number.

    Then, click on "Update".

    Info

    By configuring "Latest" as the launch template version, you no longer need to update the Auto Scaling Group every time you modify the launch template. The Auto Scaling Group will automatically use the latest version of the launch template.

    Change launch template version

  9. Terminate the old instances manually from the EC2 Dashboard if you want to force the termination of the instances. New instances will be launched with the new instance type.

    Info

    If you want to avoid downtime, you can wait until the Auto Scaling Group replaces the old instances with the new ones. But you will need to increase the desired capacity to force the replacement of the instances and then decrease it to the desired number of instances.

Media Nodes Autoscaling Configuration#

To configure the Auto Scaling settings for the Media Nodes, follow the steps outlined below. This configuration allows you to set the parameters that control how the Auto Scaling Group will scale based on the target average CPU utilization.

  1. Navigate to the CloudFormation Dashboard on AWS.
  2. Select the CloudFormation Stack that you used to deploy OpenVidu Elastic.
  3. In the "Resources" tab, locate the resource with the logical ID: OpenViduMediaNodeASG and click on it to go to the Auto Scaling Group Dashboard.
    Select Auto Scaling Group
  4. Click on "Actions > Edit".
    Edit Auto Scaling Group
  5. To configure scaling policies, navigate to the "Automatic scaling" tab within the Auto Scaling Group Dashboard, select the unique "Target tracking scaling" autoscaling policy, and click on "Actions > Edit".
    Scaling Policies
  6. It will open a panel where you can configure multiple parameters. In this example, we set the target average CPU utilization to 30%. Then, click on "Update".

    Edit Scaling Policies

    Info

    OpenVidu Elastic is by default configured with a "Target tracking scaling" policy that scales based on the target average CPU utilization, however, you can configure different autoscaling policies according to your needs. For more information on the various types of autoscaling policies and how to implement them, refer to the AWS Auto Scaling documentation.

Fixed Number of Media Nodes#

If you need to maintain a fixed number of Media Nodes instead of allowing the Auto Scaling Group to dynamically adjust based on CPU utilization, you can configure the desired capacity settings accordingly. Follow the steps below to set a fixed number of Media Nodes:

  1. Navigate to the CloudFormation Dashboard on AWS.
  2. Select the CloudFormation Stack that you used to deploy OpenVidu Elastic.
  3. In the "Resources" tab, locate the resource with the logical ID: OpenViduMediaNodeASG and click on it to go to the Auto Scaling Group Dashboard.
    Select Auto Scaling Group
  4. Click on "Actions > Edit".
    Edit Auto Scaling Group
  5. Set the "Desired capacity", "Min desired capacity", and "Max desired capacity" to the fixed number of Media Nodes you require, and click on "Update". In this example, we set the desired capacity to 2.
    Set Fixed Desired Capacity
  6. Wait until the "Instance Management" tab shows that the Auto Scaling Group has the fixed number of instances running.
    Instance Management

Configuration Management#

This section explains how to manage and update the configuration settings for your OpenVidu Elastic deployment. It is divided into three parts:

  1. Configuring CloudFormation YAML for Node Services Configuration: Details how to pre-configure settings in the CloudFormation template to avoid manual interventions post-deployment.
  2. Global Configuration: Covers parameters that affect the entire cluster when the CloudFormation stack is already deployed.
  3. Node Services Configuration: Focuses on settings specific to Master and Media Nodes services when the CloudFormation stack is already deployed.

Configuring CloudFormation YAML for Node Services Configuration#

To avoid manual intervention after deployment, you can pre-configure the node services configuration directly in the CloudFormation YAML template. This ensures that the necessary configurations are applied automatically upon deployment.

  1. Get the CloudFormation YAML template used to deploy OpenVidu Elastic on AWS.
  2. Locate the section defining the Launch Template for the Master Node and update the UserData property with the required configuration parameters. The section looks like this:

    OpenViduMasterNode:
        Type: AWS::EC2::Instance
        Properties:
            UserData:
                Fn::Base64: !Sub |
                    #!/bin/bash
                    ...
                    ...
                    # Install OpenVidu
                    /usr/local/bin/install.sh || { echo "[OpenVidu] error installing OpenVidu"; exit 1; }
    
                    ######### APPLY CUSTOM CONFIGURATIONS #########
                    # If you want to apply any modification to the configuration files
                    # of the OpenVidu services at /opt/openvidu, you can do it here.
                    # Examples:
                    #
                    # - Change minio public port
                    # yq eval '.apps.http.servers.minio.listen[0] = ":9001"' -i /opt/openvidu/config/caddy.yaml
                    #
                    # - Disable dashboard access
                    # yq eval 'del(.apps.http.servers.public.routes[] | \
                    #  select(.handle[]?.handler == "subroute" and \
                    #  .handle[].routes[].handle[].strip_path_prefix == "/dashboard"))' \
                    #  -i /opt/openvidu/config/caddy.yaml
    
    
    
                    ######### END CUSTOM CONFIGURATIONS #########
    
                    # Start OpenVidu
                    systemctl start openvidu || { echo "[OpenVidu] error starting OpenVidu"; exit 1; }
                    ...
                    ...
    

    The area between APPLY CUSTOM CONFIGURATIONS and END CUSTOM CONFIGURATIONS is where you can add your custom configuration commands. You can use yq to modify the configuration files of the OpenVidu services. The example shows how to change the minio public port and how to disable dashboard access in the caddy.yaml configuration file.

  3. Save the YAML file and use it to deploy your CloudFormation stack. This will apply the Master Node configuration automatically during the deployment process.

  1. Get the CloudFormation YAML template used to deploy OpenVidu Elastic on AWS.
  2. Locate the section defining the Launch Template for the Media Nodes and update the UserData property with the required configuration parameters. The section looks like this:

    OpenViduMediaNodeLaunchTemplate:
        Type: "AWS::EC2::LaunchTemplate"
        Properties:
        LaunchTemplateData:
            UserData:
                Fn::Base64: !Sub |
                    #!/bin/bash
                    ...
                    ...
                    # Install OpenVidu #
                    /usr/local/bin/install.sh || { echo "[OpenVidu] error installing OpenVidu"; /usr/local/bin/set_as_unhealthy.sh; exit 1; }
    
                    ######### APPLY CUSTOM CONFIGURATIONS #########
                    # If you want to apply any modification to the configuration files
                    # of the OpenVidu services at /opt/openvidu, you can do it in this section.
                    # Examples:
                    #
                    # - Announce specific IP address for the Media Node
                    # yq eval '.rtc.node_ip = 1.2.3.4' -i /opt/openvidu/config/livekit.yaml
                    #
                    # - Add webhooks to livekit
                    # yq eval '.webhook.urls += ["http://new-endpoint.example.com/webhook"]' -i /opt/openvidu/config/livekit.yaml
    
    
    
                    ######### END CUSTOM CONFIGURATIONS #########
    
                    # Start OpenVidu
                    systemctl start openvidu || { echo "[OpenVidu] error starting OpenVidu"; /usr/local/bin/set_as_unhealthy.sh; exit 1; }
    

    The area between APPLY CUSTOM CONFIGURATIONS and END CUSTOM CONFIGURATIONS is where you can add your custom configuration commands. You can use yq to modify the configuration files of the OpenVidu services. The example shows how to change the rtc.node_ip parameter and how to add a webhook to the livekit.yaml configuration file.

  3. Save the YAML file and use it to deploy your CloudFormation stack. This will apply the node services configuration automatically during the deployment process.

By pre-configuring the CloudFormation template, you streamline the deployment process and reduce the need for post-deployment manual configuration.

Global Configuration#

The global configuration parameters for the OpenVidu Elastic deployment are stored in a secret resource deployed by the CloudFormation stack. These parameters can affect the configuration of all the nodes in the cluster. To update any of these parameters, follow the steps below:

  1. Navigate to the CloudFormation Dashboard on AWS.
  2. Select the CloudFormation Stack that you used to deploy OpenVidu Elastic.
  3. In the "Resources" tab, locate the resource with the logical ID: OpenViduSharedInfo and click on it to view the secret in AWS Secrets Manager.
    View Global Configuration Parameters
  4. Click on "Retrieve secret value" to view the parameters.
    Retrieve Secret Value
  5. Edit the desired parameters within the secret. For example, you can change the RTC_ENGINE parameter to pion or mediasoup depending on the WebRTC engine you want to use. Just click on "Edit", modify the value, and click on "Save".
    Edit Global Configuration Parameters
  6. To apply the changes, stop the cluster and then start it again following the procedures outlined in the Cluster Shutdown and Startup section.

Node Services Configuration#

The configuration for individual node services can be managed through different methods depending on the node type.

The Master Node's configuration can be directly modified on the internal machine since it is an EC2 instance. To update the configuration:

  1. Connect to the Master Node EC2 instance using SSH.
  2. Edit the configuration files as necessary. Check the On Premises Elastic documentation related to the Master Node configuration.

Once the changes are made, restart the OpenVidu Server to apply the new configuration.

sudo systemctl restart openvidu

Warning

Take into account that some changes may require modifying the Master Nodes configuration as well. Check the On Premises Elastic Advanced Configuration for more information.

Media Node configurations require changes to be made in the Launch Template "User Data" section. To update the configuration:

  1. Navigate to the CloudFormation Dashboard on AWS.
  2. Select the CloudFormation Stack that you used to deploy OpenVidu Elastic.
  3. Locate the resource with the logical ID: OpenViduMediaNodeLaunchTemplate. Click on it to go to the Launch Template Dashboard with the Launch Template of the Media Nodes selected.
    Select Launch Template
  4. Click on "Actions > Modify template (Create new version)".
    Edit Launch Template
  5. Go to the "Advanced details" section and modify the "User data" field with the new configuration. You can modify the configuration parameters of the services running on the Media Nodes following the same script structure as the one used in the Automatic installation and configuration of nodes for the Media Nodes. When you finish, click on "Create template version".
    Edit User Data
  6. Go to the CloudFormation Stack and locate the resource with the logical ID: OpenViduMediaNodeASG. Click on it to go to the Auto Scaling Group Dashboard with the Auto Scaling Group of the Media Nodes selected.
    Select Auto Scaling Group
  7. Click on "Actions > Edit".
    Edit Auto Scaling Group
  8. In the Launch Template section, select the new version of the launch template we just created at step 5, which is the highest version number. Then, click on "Update".

    Info

    By configuring "Latest" as the launch template version, you no longer need to update the Auto Scaling Group every time you modify the launch template. The Auto Scaling Group will automatically use the latest version of the launch template.

    Change launch template version

  9. Terminate the old instances manually from the EC2 Dashboard if you want to force the termination of the instances. New instances will be launched with the new configuration.

    Warning

    This process requires downtime, as it involves terminating the old instances and launching new ones with the updated configuration.