While working on multi-site Drupal installations, have you ever wanted to run Drush commands on all or multiple sites? Drall is a command-line tool that helps you do exactly that! Drall is what its slogan suggests: One command to Drush them all. In this article we’ll see its uses and how to start using it.

In mid 2021, I started working in a cool Montréal-based agency named Symetris where my first project happened to be a multi-site Drupal 8 installation with over 200 websites. Later, I was assigned many other multi-site projects and I noticed that they all faced a common problem:

How to execute Drush commands on all sites in a multi-site Drupal installation?

Since I love writing CLI tools, I answered this question by writing Drall – a tool built with Symfony Console that helps with running Drush commands on multi-site Drupal installations.

A big shout-out to Symetris for sponsoring the initial development of Drall.
This article is about Drall 4.x or higher. For older versions, please refer to the README file that’s included in the package.

2 minute version

  • Drall helps run Drush on multi-site Drupal installations.
    • One command to Drush them all.
  • Install Drall with composer require jigarius/drall.
  • Run drall list and drall help to get started.
  • Run Drush commands on all sites like:
    • drall exec -- drush core:status.
    • drall exec -- drush @@site.dev core:status.
  • Run non-drush commands like:
    • drall exec -- ls web/sites/@@uri/files.
  • For more documentation, read the rest of the article.
  • If you find Drall useful, consider making a small donation on GitHub.

Installation

Drall must be installed with Composer in a Drupal project.

# In the Drupal project directory.
composer require jigarius/drall

Note: If your Composer’s vendor/bin directory is not in the PATH variable, you’ll have to run it like ./vendor/bin/drall instead of just drall.

Usage

Drall offers a number of commands to simplify working with multi-site Drupal installations. Here’s a list of Drall commands that you might find useful.

exec

This command allows you to execute a Drush or a shell command command on:

  • All sites in the Drupal installation.
  • A pre-defined site group.
  • A list of sites matching a certain filter.

There are a number of ways in which you can to use this command. In general, drall exec works by replacing one of the pre-defined placeholders (discussed below) to generate and execute commands targeting each site in the Drupal installation.

With @@dir

In this method, @@dir is replaced with the values of the $sites array.

$ drall exec -- drush --uri=@@dir core:status
# Equivalent to running the following Drush commands.
drush --uri=site-1 core:status
drush --uri=site-2 core:status
...
drush --uri=site-n core:status

Or simply omit the --uri=@@dir and Drall adds it automatically for drush commands, unless you’ve included @@site in the command, which is discussed next.

With @@key

In this method, @@key is replaced with the keys of the $sites array. These keys usually represent the domain at which the site can be accessed and is useful for use with commands like drush uli.

$ drall exec -- drush --uri=@@key uli
# Equivalent to running the following Drush commands.
drush --uri=site-1.com core:status
drush --uri=site-2.com core:status
...
drush --uri=site-n.com core:status

With @@site

In this method, the @@site part represents the various site aliases you have configured for Drush.

$ drall exec -- drush @@site.prod core:status
# Equivalent to running the following Drush commands.
drush @site-1.prod core:status
drush @site-2.prod core:status
...
drush @site-n.prod core:status

For a Drush alias like @foo.ENV, @@site will only take the @foo part of the alias.

site:directories

The site directories command lists all directories referred to in Drupal’s sites.php. Say, your sites.php looks as follows.

$sites[
  'site-1.com' => 'site-1',
  'site-2.com' => 'site-2',
  // ...
  'site-n.com' => 'site-n',
];

With drall site:directories, you can get a list of the site directory names.

$ drall site:directories
site-1
site-2
...
site-n

You can then use in scripts to do fancy stuff.

for site in $(drall site:directories)
do
  echo "Working on $site";
  # Do something with $site.
done;

site:keys

The site keys command lists all keys (usually hostnames) referred to in Drupal’s sites.php. Say, your sites.php looks as follows.

$sites[
  'site-1.com' => 'site-1',
  'site-2.com' => 'site-2',
  // ...
  'site-n.com' => 'site-n',
];

With drall site:keys, you can get a list of the site URIs.

$ drall site:directories
site-1.com
site-2.com
...
site-n.com

You can then use in scripts to do fancy stuff.

for site in $(drall site:keys)
do
  echo "Working on $site";
  # Do something with $site.
done;

site:aliases

The site aliases command lists all site aliases defined in your Drupal project. Say, you have the following site aliases defined:

# In your Drupal project root. Usually one level above index.php.
drush
└── sites
    ├── site1.site.yml
    ├── site2.site.yml
    ├── ...
    └── siten.site.yml

Say, each of these files defines 2 aliases each for 2 environments: devprod. With drall site:aliases, you can get a list of all aliases.

$ drall site:aliases
@site1.dev
@site1.prod
@site2.dev
@site2.prod
...
@siten.dev
@siten.prod

This behavior is also provided by the drush site:alias command.

Site groups

This is one Drall feature that I really find useful, especially when dealing with a huge number of Drupal sites in a single multi-site installation. Drall allows you to define site groups and then use the --group=GROUP option to run commands on specific site groups. Here’s how you can define site groups for Drall.

With site aliases

If you’re using site aliases in your project, you can assign site aliases to one or more groups by adding a drall.groups key.

# File: tnmt.site.yml
local:
  root: /opt/drupal/web
  # ...
  drall:
    groups:
      - group1
      - group2

With this in place, you can run Drush commands on all group1 sites like this:

$ drall exec --group=group1 -- drush deploy

With sites.*.php files

If you’re not using Drush site aliases, you can still assign your sites to groups by creating sites.*.php files in Drupal’s sites directory. For example,

web/sites/
|-- sites.group1.php
|-- sites.group2.php
|-- ...
|-- sites.php

Each of these files define a $sites variable just like the sites.php file. You can then run Drush commands on all group1 sites like this:

$ drall exec --group=group1 -- drush cron

Site filters

If you want to run a command only on sites that match a certain criteria, you can use --filter to filter placeholder values with an expression.

# Run only on the "leo" site.
drall exec --filter=leo -- drush core:status
# Run only on "leo" and "ralph" sites.
drall exec --filter="leo||ralph" -- drush core:status
For more on using filter expressions, refer to the documentation on consolidation/filter-via-dot-access-data.

Conclusion

By allowing us to run Drush on all or multiple sites, Drall does help a lot in multi-site Drupal installations. It can easily be installed with composer and it is fairly easy to use.

Next steps

On this page

Never miss an article

Follow me on LinkedIn or Twitter and enable notifications.