Over the years, WordPress developers have created and maintained WP-CLI, a robust command-line interface specifically designed for WordPress operations. As a time-saving tool, WP-CLI is particularly well-suited for managing WordPress Multisite networks, which allow multiple sites to run on a single WordPress installation.
To use WP-CLI effectively, it’s essential to understand key components of WordPress: the Admin interface, the file structure, and the database. Without this foundational knowledge, WP-CLI may not be as efficient or beneficial.
While WP-CLI supports standard commands like installing, updating, activating, deactivating, and deleting plugins or themes, its capabilities extend well beyond what’s available in the WordPress Admin dashboard, making it a highly versatile tool for advanced site management.
This article explains how to use WP-CLI to manage WordPress Multisite networks efficiently and provides practical examples to help you get started.
What is WP CLI and why use it?
WP-CLI is a powerful tool for managing WordPress sites via the command line. In a multisite environment, it can significantly simplify the management of a network, enabling you to perform bulk actions and streamline your workflow.
Its true strength lies in its flexibility and extensibility — you can effortlessly execute commands across the entire network or target specific sites while also enhancing its functionality with a variety of WP-CLI packages available on GitHub and other repositories.
Developers often create custom WP-CLI commands to simplify repetitive tasks. For example, you can use WP-CLI to scaffold boilerplate code for themes and plugins, saving time and effort during development.
If you’re hosting with Kinsta, WP-CLI is built-in and accessible via SSH, allowing you to manage WordPress sites effortlessly. For local development, WP-CLI is available in DevKinsta through the devkinsta_fpm
container. Once inside the container, you can navigate to your site folder and run commands. While this requires a bit of setup, it provides a powerful way to manage your local WordPress sites efficiently for debugging, testing, or deploying.
Before you begin
The commands highlighted in this article are carefully chosen for their frequent use by WordPress Multisite developers and administrators.
WP-CLI is a broad and flexible tool, making it impossible to cover every available command. To keep things clear and practical, we’ve focused on simple, actionable examples to help you get started.
Since WP-CLI is based on Unix commands, you might not find a WP-CLI equivalent for commands that already exist in Unix.
Key notes about WP-CLI
WP-CLI’s command structure is flexible, allowing multiple ways to achieve the same outcome. For instance, both of the following examples are valid:
wp user create johndoe [email protected] --display_name="John Doe" --nickname="Johnny"
Or:
wp user create johndoe --display_name="John Doe" [email protected] --nickname="Johnny"
The order of flags, parameters, and values doesn’t matter once the command and subcommand are stated.
Best practices for running WP-CLI commands
Follow these best practices to avoid potential issues:
- Always have a current backup available, especially as some of these commands will permanently alter your site(s).
- Use a staging site wherever possible. If you’re using Kinsta, each WordPress install includes a free staging environment for safe testing. You can easily push changes between staging and live environments.
- Use the
--dry-run
flag to test database changes before applying them.
Essential WP-CLI commands for WordPress Multisite management
WP-CLI commands in a Multisite network can target different levels of action:
- Network-wide: Commands applied across all sites in the network. For example:
wp plugin deactivate --network --all
This command deactivates all plugins across every site in the network.
- Primary site: Commands applied to the main site created during the Multisite setup. For example:
wp plugin list
The command above lists all plugins installed on the primary site only.
- Secondary sites: Commands targeting individual sites within the network, specified by their URLs. For example:
wp plugin update --url=mysite.example.com akismet
This command updates the
akismet
plugin on the sitemysite.example.com
.
To make managing your Multisite network easier, we’ve grouped WP-CLI commands into these sections:
Basic commands
These fundamental commands help with troubleshooting and managing plugins and themes across your network.
Working with lists
WP-CLI makes it easy to retrieve lists of plugins and other components in your Multisite environment.
- Get a list of all plugins in the network:
wp plugin list --network
Output: Displays all network-installed plugins with details like name, status, updates available, and version.
- Filter plugins by status (e.g., active):
wp plugin list --network --status=active
Output: A table of active plugins across the network.
- Get a list of plugins from the primary site:
wp plugin list
Output: A list of plugins for the primary site.
- Get a list of active plugins for a single site:
wp plugin list --url=
--status=active Input example:
wp plugin list --url=blog.example.com --status=active
Output: A table of active plugins for the site
blog.example.com
.
In addition to filtering plugins by status=active
, you can also use the following filters:
inactive
: Plugins that are installed but not active.active-network
: Plugins active across the network.must-use
: Must-use plugins that load automatically.
Deactivate plugins
Deactivating plugins is often necessary when troubleshooting issues or preparing for updates. WP-CLI allows you to deactivate plugins across the network or for specific sites.
- Deactivate all plugins across the network:
wp plugin deactivate --network --all
Result: All plugins in the network are deactivated.
- Deactivate specific plugins for a single site:
wp plugin deactivate
--url= Input example:
wp plugin deactivate akismet hello-dolly --url=blog.example.com
Result: The plugins
akismet
andhello-dolly
are deactivated for the siteblog.example.com
.
Activate plugins
Use these commands to activate plugins either network-wide or for individual sites in your Multisite setup.
- Activate all plugins across the network:
wp plugin activate --network --all
Result: All plugins in the network are activated.
- Activate specific plugins for a single site:
wp plugin activate
--url= Input example:
wp plugin activate akismet hello-dolly --url=blog.example.com
Result: The plugins
akismet
andhello-dolly
are activated for the siteblog.example.com
.
Install plugins
Installing plugins with WP-CLI is quick and efficient. Once installed, plugins can be activated for individual sites or across the network.
The following command can be used to install a plugin for the network:
wp plugin install
Input example:
wp plugin install akismet
Result: The plugin akismet
is installed and ready for activation.
Update plugins
Keep your plugins up-to-date across your network or for specific sites using these commands.
- Update all plugins across the network:
wp plugin update --network --all
Result: All plugins in the network are updated.
- Update specific plugins across the network:
wp plugin update
--network Input example:
wp plugin update akismet jetpack bbpress --network
Result: The plugins
akismet
,jetpack
, andbbpress
are updated across the network. - Update a plugin for a single site:
wp plugin update --url=
Input example:
wp plugin update --url=blog.example.com hello-dolly
Result: The plugin
hello-dolly
is updated for the siteblog.example.com
.
Delete plugins
Removing plugins is straightforward with WP-CLI, whether you’re working on a single site or a Multisite network.
- Delete a plugin from the current WordPress context (network or site):
wp plugin delete
Input example:
wp plugin delete bbpress
Result: The plugin
bbpress
is deleted. - Delete a plugin for a specific site in a Multisite:
wp plugin delete
--url= Input example:
wp plugin delete bbpress --url=blog.example.com
Result: The plugin
bbpress
is deleted from the siteblog.example.com
.
Network management
Managing sites within a WordPress Multisite network is a crucial task. Below are common WP-CLI commands to help you efficiently create, manage, and delete sites, as well as handle caching operations.
Creating sites
Adding new sites to your network is straightforward with WP-CLI.
- Basic command: Create a new site by specifying a unique slug.
wp site create --slug=
Input example:
wp site create --slug=blog
Result: A new site
blog.example.com
orexample.com/blog
, depending on your network setup is created and is automatically active. - Advanced command: Alternatively, flags can be appended to the command. In the example below, a site is added with a specified site title and site administrator.
wp site create --slug=
--title=" " --email= Input example:
wp site create --slug=blog --title="Blog Site" [email protected]
Result: A site titled “Blog Site” is created with
[email protected]
as the administrator. - List all sites: Retrieve a table displaying site IDs, URLs, creation dates, and last updated dates:
wp site list
You can also refine the site list to get only the URLs of all sites in the network:
wp site list --field=url
Output: A list of URLs for each site.
Emptying and deleting sites
- Empty the primary site:
wp site empty
Output: A confirmation prompt appears to delete all content for the primary site.
- Empty a single site (removes all posts, pages, links, and taxonomies):
wp site empty --url=
Input example:
wp site empty --url=blog.example.com
Result: All content from
blog.example.com
is deleted, but the site remains intact. - Empty all sites in the network:
wp site list --field=url | xargs -n1 -I % wp site empty --url=% --yes
Result: This command initiates a loop through all URLs and then proceeds to empty each site’s contents without the need to provide approval for each site.
- Delete a single site by ID:
wp site delete
Input example:
wp site delete 5
Result: Site with ID
5
is deleted. - Delete multiple sites with confirmation bypass:
wp site delete 2 --yes wp site delete 3 --yes
Result: Sites with IDs
2
and3
are deleted. The--yes
flag helps to skip prompts.
Clearing cache
Because many cache types are stored in different ways here, we use the Kinsta Must-Use plugin. It is installed automatically for each WordPress site in our system.
This clears all cache, including site cache, edge cache, CDN cache, and Redis cache.
- Clear all cache (site, edge, CDN, and Redis):
wp kinsta cache purge --all
- Clear only site cache:
wp kinsta cache purge --site
- Purge CDN cache:
wp kinsta cache purge --cdn
- Clear object cache:
wp cache purge
User management
WP-CLI simplifies managing users in a Multisite environment, allowing you to perform tasks quickly and efficiently. This section covers common user management operations:
List users
Listing users in a network or a specific site is straightforward with WP-CLI.
- List all users in the network:
wp user list --network
Output: A table showing User ID, Login, Display Name, Username, Registration Date, and Role for each user or user list query.
- List users for the primary site:
wp user list
Result: Displays a table of users for the primary site.
- List users for a specific site (secondary site):
wp user list --blog_id=
wp user list --url= Input example:
wp user list --blog_id=6
Result: Displays a table of all users for the site with Blog ID
6
.
Create users
In a Multisite network, users are registered to the network by default. Their roles depend on whether they are the first user added to a site or subsequent users. Usernames must be at least four characters long.
- Add a new user to the primary site:
wp user create
Input example:
wp user create johndoe [email protected]
Output: A success message is displayed, including a generated password.
- Add a new user to a specific site with a specified role:
wp user create
--role= --url= Input example:
wp user create janedoe [email protected] --role=editor --url=blog.example.com
Output: The user
janedoe
is added to the siteblog.example.com
as an “Editor”. - Add user account meta during creation:
wp user create
--display_name= --nickname= Input example:
wp user create johndoe [email protected] --display_name="John Doe" --nickname="Johnny"
Result: User
johndoe
is created with a display nameJohn Doe
and nicknameJohnny
.
Update user
Updating user information, such as roles or passwords, is quick with WP-CLI.
- Change (promote or downgrade) user roles:
wp user update
--role= Input example:
wp user update johndoe janedoe adminuser --role=super-administrator
Result: Users
johndoe
,janedoe
, andadminuser
are promoted to Super Administrators. - Reset or change a user password:
wp user update
--user_pass= Input example:
wp user update johndoe --user_pass=securePassword2024
Result: The password for
johndoe
is updated. - Daisy-chained commands: WP-CLI allows you to combine multiple actions in a single command, saving time when editing users. For example, you can simultaneously update a user’s password and role.
wp user update
--user_pass= --role= Input example:
wp user update johndoe --user_pass="newPassword2024" --role=editor
Result: The password for user
johndoe
is updated tonewPassword2024
, and their role is changed to “Editor”.
Manage user meta
User meta allows you to add, retrieve, or delete metadata for user accounts.
- Get user meta:
wp user meta get
Input example:
wp user meta get johndoe nickname
Output: Displays the value of the
nickname
meta key for userjohndoe
. - Add user meta:
wp user meta add
Input example:
wp user meta add johndoe display_name "Mr. John Doe"
Result:
Mr. John Doe
is set as the display name for userjohndoe
. - Delete user meta:
wp user meta delete
Input example:
wp user meta delete johndoe display_name
Result: This command deletes the
display_name
meta key for the userjohndoe
.
Delete users
Removing users from the network or specific sites is efficient with WP-CLI.
- Delete a user from the network:
wp user delete
--network Input example:
wp user delete johndoe --network
Result: The user
johndoe
is removed from the network. - Delete a user from a specific site:
wp user delete
--url= Input example:
wp user delete johndoe --url=mysite.example.com
Result: The user
johndoe
is removed from the sitemysite.example.com
.
Database management
WP-CLI provides a powerful alternative to tools like phpMyAdmin for managing your database. This section covers common database operations you can perform using WP-CLI:
Exporting a database
With WP-CLI, you can export your database as an SQL file. The exported file is saved in the root directory of your WordPress installation.
wp db export
Result: An SQL file is created in the root directory.
If the exported file has an ungainly name, you can rename it using the following command:
wp eval 'if ( rename( "unganglyfilename.sql", "newfilename.sql" ) ) { echo "File renamed successfully."; } else { echo "Failed to rename file."; }'
Input example:
wp eval 'if ( rename( "cilawawugo4504_gTr4kSXUsmJ9FNauVnPb-2024-11-17-9545b3f.sql", "network-db.sql" ) ) { echo "File renamed successfully."; } else { echo "Failed to rename file."; }'
Result: File cilawaw…nPb--9545b3f.sql
is renamed to network-db.sql
.
Downloading a database
To download the exported database file to your local machine, use the curl
command.
curl -o
Input example:
curl example.com/network-db.sql -o ~/Downloads/network-db.sql
Result: The file network-db.sql
is downloaded to your local Downloads
directory.
Uploading a database
You can upload a database file to the root directory of your Multisite installation using the scp
command.
scp @:
Input example:
scp ~/Downloads/network-db.sql [email protected]:/var/www/example.com/public_html
Result: The file network-db.sql
is uploaded to the root directory of your WordPress installation after authentication.
Importing a database
Before importing a database, you may need to reset your existing data tables.
- Reset data tables:
wp db reset
Result: All data tables in the database are emptied.
- Import the database:
wp db import
Input example:
wp db import network-db.sql
Result: The file
network-db.sql
populates the emptied data tables. - Delete the imported SQL file:For security purposes, delete the SQL file after importing:
rm
Practical examples
We can think of many commands that will speed and simplify your workflow. Here are three examples. While some of these commands are more complex, they build upon simpler commands to carry out useful operations.
Install and activate plugins and regenerate thumbnails simultaneously.
This command loops through all sites in the network, installs and activates two plugins, and regenerates image thumbnails for each site.
wp site list --field=url | xargs -n1 -I % sh -c 'wp plugin activate --url=% && wp media regenerate --url=%'
Input example:
wp site list --field=url | xargs -n1 -I % sh -c 'wp plugin install akismet bbpress --activate --url=% && wp media regenerate --url=%'
Result: The plugins Akismet
and BBPress
are installed and activated across all sites, and image thumbnails are regenerated.
Adding a custom meta field for all users
This command loops through all sites, retrieves the list of users, and adds a custom meta field for each user.
wp site list --field=url | xargs -n1 -I % sh -c 'wp user list --fields=ID --url=% --format=csv | tail -n +2 | xargs -n1 -I {} wp user meta add {} --url=%'
Input example:
wp site list --field=url | xargs -n1 -I % sh -c 'wp user list --fields=ID --url=% --format=csv | tail -n +2 | xargs -n1 -I {} wp user meta add {} favorite_color "" --url=%'
Result: A custom meta field, favorite_color
, is added for all users across all sites.
To surface the favorite_color
field, you’ll need to use your functions.php
file or create a custom plugin.
Converting a single site install to a multisite
WP-CLI makes it easy to convert a standalone WordPress site into a Multisite network.
wp core multisite-convert
Result: The single site is converted into a Multisite network.
Before conversion, make sure to deactivate all plugins.
After converting the site, you need to configure the network URLs in the wp-config.php
file. You can choose between using subdomains (e.g., site.example.com) or subdirectories (e.g., example.com/site). Additionally, check the .htaccess
file, as the URL rewrite rules (handled by the mod_rewrite module in Apache) may require manual updates to ensure your permalinks and site structure work correctly.
Summary
This guide highlights the power and flexibility of WP-CLI for managing WordPress Multisite environments, making it an essential tool for developers and administrators seeking efficiency and control. From handling plugins, users, and databases to performing advanced operations like converting single sites to Multisite, WP-CLI simplifies complex tasks with precision and speed.
Kinsta offers an invaluable and extensible WP-CLI tool that enables seamless management of WordPress Multisite networks. Whether you’re working on live or staging environments or using our local development tool, DevKinsta, WP-CLI is readily available to streamline your workflow.
Start creating sites, adding plugins, users, and more with WP CLI!