Multiple-Helix server instances

A single Swarm server can be connected one or more Helix Core server (P4D) instances. This section describes how to configure Swarm to connect to multiple Helix servers.

Warning

Issue: Swarm will lose connection to all of the Helix servers if you edit the base_url configurable value in the environment block of <swarm_root>/data/config.php. This will stop your system working.

Fix: Remove the base_url configurable from the environment block of <swarm_root>/data/config.php.

Note

Known limitations, only applies if you want to use Global Dashboard:

  • Issue: If Helix Authentication Service is enabled for Swarm and the Try to login to all available servers with these credentials checkbox or the All available servers option is selected in a login dialog, Swarm will not try to log in to any of the other Helix server instances that are configured for Helix Authentication Service.
  • Workaround: Log in to them individually using the instance Log in button Image of the global dashboard log in button in the sidebar or by including the server instance name in the URL, for example: https://swarm.company.com/serverA.

  • Swarm must be installed in its own virtual host.

Complete the following steps to connect Swarm to multiple-Helix server instances:

Set up the Swarm configuration file for the Helix servers

The Swarm Helix server connection details are configured using the p4 item in the <swarm_root>/data/config.php configuration file.

Tip

If you make a configuration change, Swarm will not use it until the configuration cache has been reloaded, this forces Swarm to use the new configuration. You must be an admin or super user to reload the Swarm config cache. Navigate to the User id dropdown menu, select System Information, click the Cache Info tab, and click the Reload Configuration button.

When Swarm is configured for a single Helix server instance the p4 item looks like this:

<?php
    return array(
        'p4' => array(
            'port'     => 'my-helix-core-server:1666',
            'user'     => 'admin_userid',
            'password' => 'admin user ticket or password',
            'sso'      => 'disabled', // ['disabled'|'optional'|'enabled'] default value is 'disabled' 
         ),
    );

Where:

  • port is the P4PORT for your Helix server.
  • user is a userid that has admin privileges for the Helix server.
  • password is the ticket or password for the Helix server user.
  • sso if the Helix server is configured for the Helix Authentication Service, set to one of the following:
    • enabled all users must use Helix Authentication Service to log in to Swarm.

    • optional Helix Authentication Service is available for users to log in to Swarm but is not enforced.

    • disabled Helix Authentication Service is not available to Swarm. This is the default value.

  • Important

    From Swarm 2021.1, the sso_enabled configurable is deprecated but remains supported. It is replaced with the more flexible sso configurable. If the sso_enabled configurable and sso configurable are both present in the p4 configuration block, Swarm uses the sso configurable value.

Multiple Helix server instances can be added to the p4 item in config.php but each Helix server instance must have a label to identify the server instance. This enables Swarm to connect to the Helix servers in the p4 item.

Tip

The Helix server instances do not have to all be at the same version but they must all be versions that Swarm supports. For a list of Helix server versions supported by Swarm, see Helix Core server requirements.

The first Helix server in the p4 item is the primary Helix server, this instance renders the global dashboard. If Swarm fails to connect to the primary Helix server, Swarm cannot display any of the Helix server instances in the global dashboard. You can still connect directly to the other P4D instances by including the Helix server label in the URL for each instance, for example: https://swarm.company.com/serverA.

Configure the Swarm configuration file for multiple Helix server instances:

Enter a label for each Helix server instance and enter the server connection details under the server label.

For example:

<?php
    return array(
        'p4' => array(
            'serverA' => array(
                'port'     => 'p4d-A:1666',
                'user'     => 'admin_userid_serverA',
                'password' => 'admin user ticket or password for serverA',
                'sso'      => 'disabled', // ['disabled'|'optional'|'enabled'] default value is 'disabled' 
            ),
            'serverB' => array(
                'port'     => 'p4d-B:1666',
                'user'     => 'admin_userid_serverB',
                'password' => 'admin user ticket or password for serverB',
                'sso'      => 'disabled', // ['disabled'|'optional'|'enabled'] default value is 'disabled' 
            ),		
        );

Where:

  • serverA and serverB are labels that identify the individual Helix servers.
    • The labels must be URL-friendly labels.
    • The labels must not contain any spaces or any characters that require URL encoding, and
    • The total length of the server label and Redis namespace combined is limited to ≤ 127 characters. The default namespace is Swarm.
  • The port, user, password, and sso items are specific to the Helix server instance they are nested under.

Set the Swarm trigger token and Swarm host variable for each Helix server

Helix server uses a Swarm trigger token to confirm that trigger requests from Swarm are valid. Each Helix server instance must have a valid Swarm trigger token in its swarm-trigger.conf file. The swarm-trigger.conf file also contains the Swarm host URL for the Helix server instance.

Set the Swarm trigger token and Swarm host variable for each Helix server instance:

  1. Navigate to the Swarm URL for the instance.
  2. For example: https://swarm.company.com/serverA

  3. Log in to Swarm as a super user.
  4. Click your userid, in the main toolbar and select About Swarm.
  5. The About Swarm dialog is displayed with a Trigger Token. Swarm generates the trigger token if it doesn't already exist.

  6. Copy the trigger token value from the dialog.
  7. Open the swarm-trigger.conf file for the Helix server instance.
  8. Tip

    For more information about the location of the swarm-trigger.conf file, see Set up Swarm triggers with a Windows or Linux-hosted Helix server.

  9. In the swarm-trigger.conf file:
    1. Set the SWARM_HOST URL.
    2. Set the SWARM_TOKEN by pasting the Swarm trigger token you copied in the steps above.
  10. For example:

    # SWARM_HOST (required)
    # Hostname of your Swarm instance, with leading "http://" or "https://".
    SWARM_HOST="https://swarm.company.com/serverA"
    
    # SWARM_TOKEN (required)
    # The token used when talking to Swarm to offer some security. To obtain the
    # value, log in to Swarm as a super user and select 'About Swarm' to see the
    # token value.
    SWARM_TOKEN="TRIGGER-TOKEN-FOR-SERVERA"
    

  11. Save the swarm-trigger.conf file.
  12. Repeat these steps for each Helix server.
Tip

Alternatively, you can simply touch a file in each <Swarm root>/data/servers/<serverid>/tokens folder. The file content is ignored, the filename itself is the token.

This allows you to specify a common token that is used by all of the Helix server instances.

However, we recommend that you use a separate token for each Helix server instance. This makes it easier to invalidate a token for a specific Helix server by deleting the file in the tokens folder for that server if you need to.

Configure a cron job for each Helix server instance

To automatically spawn workers for each of the servers connected to Swarm, you must manually configure a cron job for each of the servers.

Swarm package and OVA installations only

The swarm-cron-hosts.conf file specifies the connection type (HTTP or HTTPS), hostname, port number and, server label for Swarm cron jobs.

If you have installed Swarm via packages or you are running the Swarm OVA, you must specify all of the Helix server URLs within /opt/perforce/etc/swarm-cron-hosts.conf.

  1. Edit the swarm-cron-hosts.conf file so that it contains the actual Swarm hostname, ports, and server labels you have configured for Swarm.
  2. The following format is used with one Helix server on each line:

    [http[s]://]<swarm-host>[:<port>][/<base-url>]
    

    Default if value not specified:

    • [http[s]://] http
    • <swarm-host> must be specified
    • [:<port>] 80
    • [/<base-url>] server label, must be specified

    For example, for serverA and serverB configured earlier on a Swarm host of https://swarm.company.com with a default port value of 80. The entries in the swarm-cron-hosts.conf file would be:

    https://swarm.company.com/serverA
    https://swarm.company.com/serverB					
    
  3. Save the swarm-cron-hosts.conf file.
  4. Swarm is now configured to connect to multiple-Helix server instances.
  5. Tip

    To check or modify Swarm worker configuration, see Worker configuration.

Swarm Tarball installation only

If you have installed Swarm from a tarball or configured cron manually, you need create a file called helix-swarm and add all of the Helix server instances connected to Swarm.

  1. Create a file named helix-swarm in /etc/cron.d if it does not already exist.
  2. Edit the helix-swarm file so that it has the following content:
  3. #
    # Cron job to start Swarm workers every minute
    #
    * * * * * nobody [ -x /opt/perforce/swarm/p4-bin/scripts/swarm-cron.sh ] && /opt/perforce/swarm/p4-bin/scripts/swarm-cron.sh

  4. Save the helix-swarm file.
  5. Edit the swarm-cron-hosts.conf file so that it contains the actual Swarm hostname, ports, and server labels you have configured for Swarm.
  6. The following format is used with one Helix server on each line:

    [http[s]://]<swarm-host>[:<port>][/<base-url>]
    

    Default if value not specified:

    • [http[s]://] http
    • <swarm-host> must be specified
    • :<port> 80
    • [/<base-url>] server label, must be specified

    For example, for serverA and serverB configured earlier on a Swarm host of https://swarm.company.com with a default port value of 80. The entries in the swarm-cron-hosts.conf file would be:

    https://swarm.company.com/serverA
    https://swarm.company.com/serverB					
    
  7. Save the swarm-cron-hosts.conf file.
  8. Swarm is now configured to connect to multiple-Helix server instances.
  9. Tip

    To check or modify Swarm worker configuration, see Worker configuration.

Further information

Users

  • To visit the Global Dashboard, enter the basic Swarm URL without a Helix server instance name, for example: https://swarm.company.com.
  • To visit a specific Helix server instance in Swarm without going via the global dashboard, include the server name in the URL, for example: https://swarm.company.com/serverA.

Once you are viewing the Helix server in Swarm, Swarm works as a standard single Helix serverSwarm system.

Tip
  • To browse jobs on serverA, navigate to: https://swarm.company.com/serverA/jobs
  • To browse reviews on serverB, navigate to: https://swarm.company.com/serverB/reviews
  • To view the dashboard for serverB, navigate to https://swarm.company.com/serverB/#actionable-reviews
  • If you don't include the server label in the URL you will be taken to the specified page for the primary Helix server.
  • For example: navigating to https://swarm.company.com/reviews will redirect you to https://swarm.company.com/serverA/reviews because serverA is the Primary Helix server in the p4 configuration item.

Administrators

On the web server hosting Swarm, Swarm automatically creates a data folder for each Helix server instance in <Swarm_root>/data/servers. This is because each Helix server request is a field.

For example:

# ls -la /opt/perforce/swarm/data/servers/serverA
total 362296			
drwx------ 6 apache apache    4096 Sep  8 17:15 .
drwx------ 6 apache apache    4096 Sep  6 15:41 ..
drwx------ 2 apache apache    4096 Sep 20 18:08 cache
drwx------ 3 apache apache    4096 Sep  7 13:25 clients
-rw-r--r-- 1 apache apache 3709543 Sep 26 14:19 log
-r-------- 1 apache apache      84 Sep  6 15:41 p4trust
drwx------ 4 apache apache    4096 Sep 20 14:27 queue
drwx------ 2 apache apache    4096 Sep 20 11:18 sessions
Tip

It is important to understand that there will be a Swarm log file for each Helix server instance.

Developers

To get a list of projects via the Swarm API for serverA, run bash:

  • If you are using wget:

    $ wget -u "apiuser:password" https://swarm.company.com/serverA/api/v10/projects
  • If you are using curl:

    $ curl -u "apiuser:password" https://swarm.company.com/serverA/api/v10/projects

Tip

If you don't include the server label in the URL you will be taken to the projects page for the primary Helix server.

For example: navigating to https://swarm.company.com/api/v10/projects will redirect you to https://swarm.company.com/api/v10/serverA/projects because serverA is the Primary Helix server in the p4 configuration item.