Management commands


$ ./ publish_scheduled_pages

This command publishes or unpublishes pages that have had these actions scheduled by an editor. It is recommended to run this command once an hour.


$ ./ fixtree

This command scans for errors in your database and attempts to fix any issues it finds.


$ move_pages from to

This command moves a selection of pages from one section of the tree to another.


  • from This is the id of the page to move pages from. All descendants of this page will be moved to the destination. After the operation is complete, this page will have no children.
  • to This is the id of the page to move pages to.


$ ./ update_index [--backend <backend name>]

This command rebuilds the search index from scratch. It is only required when using Elasticsearch.

It is recommended to run this command once a week and at the following times:

  • whenever any pages have been created through a script (after an import, for example)
  • whenever any changes have been made to models or search configuration

The search may not return any results while this command is running, so avoid running it at peak times.

Specifying which backend to update

By default, update_index will rebuild all the search indexes listed in WAGTAILSEARCH_BACKENDS.

If you have multiple backends and would only like to update one of them, you can use the --backend option.

For example, to update just the default backend:

$ python update_index --backend default

Indexing the schema only

You can prevent the update_index command from indexing any data by using the --schema-only option:

$ python update_index --schema-only


$ ./ search_garbage_collect

Wagtail keeps a log of search queries that are popular on your website. On high traffic websites, this log may get big and you may want to clean out old search queries. This command cleans out all search query logs that are more than one week old (or a number of days configurable through the WAGTAILSEARCH_HITS_MAX_AGE setting).