At times you may want to retrieve all the metadata from your Salesforce Org. This may be required to take a backup before a major deployment or for creating the “master” branch for your Source Control system like Git.
Option 1: Create a Sandbox
Unfortunately, Salesforce does not give you an out of box, straightforward way to retrieve the metadata. For backup, the closest out of the box option will be to create a Sandbox of your production org.
But this will still not give you a way to retrieve and download the metadata. You can create a sandbox as a backup of your production org and then use change sets to move the metadata around.
Option 2: Use package.xml with ANT or SFDX CLI
One of the most common ways to retrieve the metadata is to is to prepare a package.xml listing all the metadata that you want to retrieve and then use one of the following methods to retrieve it.
- Use ANT migration tool with package.xml to retrieve the metdata
- Use SFDX CLI with package.xml to retrieve the metadata
- Use VS Code + Salesforce Extensions for VS Code + SFDX CLI with package.xml to retrieve the metadata
- Use Workbench with package.xml
Option 3: Use a 3rd Party Extension or Tool
Or otherwise use the extensions/tools provided by individuals and/or 3rd parties to retrieve the metadata. For example, one of the VS Code extension that allows you to construct the package.xml file is “Salesforce Package.xml Generator Extension for VS Code“
About this Guide
In this blog post, we will explore how to use VS Code + Salesforce Extensions for VS Code + SFDX CLI with package.xml to retrieve the metadata.
The following guide provides you with all the steps to generate your own package.xml file and important things that you need to be aware of with regards to some of the metadata types
This also contains the following two errors that that you are most likely to encounter and how to work around these errors.
- Missing metadata type definition in registry for id <metadata_type>
- Too many files in retrieve call
If you don’t want to generate your package.xml file, then you can download the package.xml from this GitHub repository and use it as-is.
(We have discontinued our premium membership offering. If you are an existing premium member, you can still download the guides by clicking on “DOWNLOAD PDF [PREMIUM MEMBERS]” button. If you are not a premium member and want to download the guides, please sign up for our “All Access” pass. Complete details about this pass is available at this URL.)
References & Useful URLs
- Blog Post: How To Get Started with Visual Studio Code for Salesforce
- GitHub Repository containing sample package.xml files – https://github.com/asagarwal/salesforce-package-xml
- VS Code Extension – Salesforce Package.xml Generator Extension for VS Code
6 thoughts on “How To Retrieve All Metadata from Your Salesforce Org using package.xml”
Amazing, thorough.. Super step-by-step!
how about on page 19, instead of searching for settings package.xml elements, we filter it out when it’s still in Excel?
Thanks Brian. Yes, it can be done that way also. Filtering it in excel will probably be easier.
You’re welcome Mahesh 🙂
Hi, Great article. The information covered is thorough and clearly explained.