Blog

Software tips, techniques, and news.

Parallel Backups on FileMaker Server

Backups are an integral part of any database system, ensuring your information is safe and up-to-date in the event of system failures and crashes. Until now, Claris FileMaker Server has backed up the files in your solution one-by-one, but FileMaker Server 19.5 has introduced the ability to enable parallel backups, and it's a game-changer, greatly increasing the efficiency of protecting your important information.

youtube-preview

What is a parallel backup?

Traditionally, FileMaker has used a linear, one-by-one approach to perform backups. Now, with parallel backups, the server can backup multiple files at once, greatly speeding up the process. To assign a definition to the process, a parallel backup is the backing up of multiple files simultaneously across multiple processors or CPU threads.

Parallel backups are an example of Task Parallelism, in which a task is broken down into easier-to-handle subtasks to be executed. These tasks are then handled concurrently by the server machine's processor. To use a tangible example, think that a single cashier at a store has a long line of customers that they have to check out one at a time. This would take that one person a considerable amount of time. Now a second cashier comes in and is also able to check customers out.  The first cashier's line sees this new cashier and half of them go to the second's line. These two cashiers are now both handling a customer, meaning two customers are being checked out at a time as opposed to one, saving both cashiers a large amount of time. Applying this to backups, our two threads, or "cashiers", can process one file each, greatly reducing the time and improving the overall efficiency of the backup process.

FileMaker Parallel Backups

To perform a backup in Parallel, FileMaker Server 19.5 makes use of transaction data from FileMaker Pro 19.5 and FileMaker WebDirect to separate related backup files into groups. Each of these groups is then backed up in its own thread during the backup. In progressive backup, the pause and resume steps for each thread are processed in parallel.

Compared to backing up files sequentially, you'll see definite performance improvements. These performance improvements can be even more notable when:

  • Backups are processed on hard drives optimized for parallel write requests

  • Backups are processed while one or more files are in use

Working With Parallel Backups

You can enable Parallel backups on your server by navigating to Backups from the top navigation and selecting "Backup Settings".  There you'll find a toggle for Parallel Backup, this can be enabled and disabled as desired.

enable parallel backups in fm server.

Parallel Backups can also be enabled, disabled, or viewed in the FileMaker Server Admin Console using the commands:

  • View: fmsadmin get serverprefs ParallelBackupEnabled

  • Enable: fmsadmin set serverprefs ParallelBackupEnabled=true

  • Disable: fmsadmin set serverprefs ParallelBackupEnabled=false


The FileMaker Admin API also supports these functionalities with the URL https://host/fmi/admin/api/v2/server/config/parallelbackup

Enabling and disabling Parallel Backups is done using the PATCH method and a boolean value used to toggle the feature, returning a JSON to designate if the change was accepted, as seen below.

-X PATCH https://host/fmi/admin/api/v2/server/config/parallelbackup
--header 'Content-Type: application/json'
--header 'Authorization: Bearer ClarisIDToken'
-d 'parallelBackupEnabled: true'

In the above example "host" will be replaced by your server's address or IP, and ClarisIDToken will be replaced by a Claris ID Authentication token received after authenticating with your admin credentials.

To check if Parallel Backups are enabled, the PATCH method is used, and returns a JSON object designating whether the feature is enabled or disabled.

-X GET https://host/fmi/admin/api/v2/server/config/parallelbackup
--header 'Content-Type: application/json'
--header 'Authorization: Bearer ClarisIDToken'

If you need any further information on the Admin API, you can view our article about it here.

Log Messages

When backups are processed in parallel, a new event log message is created that includes the fileset, a numeric ID for a group of databases backed up together. Below are a few examples of log messages you'll see when performing parallel backups.

  • Start of backup fileset 0, total files 1

  • Starting to back up database DBName1, current status: Normal(fileset: 0)

  • Backup of DBName1 completed, current status: Normal(fileset: 0)

  • End of backup fileset 0, total files 1


You will have strings of messages following these patterns for each file and fileset being backed up, as well as messages indicating any problems that may occur during the backup process.

Conclusion

Parallel Backups are a powerful tool to increase the efficiency of protecting and storing your organization's important data. The ability to backup multiple files at a time is a huge evolutionary step in the world of data protection and recovery, greatly reducing the time needed to ensure the safety of information across multiple databases. If you have any questions about Parallel Backups, please contact DB Services and we'll be glad to help!

Did you know we are an authorized reseller for Claris FileMaker Licensing?
Contact us to discuss upgrading your Claris FileMaker software.

dylan frechette headshot.
Dylan Frechette

Dylan is a logical and methodical application developer who never shies away from a challenge. His attention to detail, precision, and desire to continue growing his skills make him a valuable member of the DB Services team.