Neon's protected branches feature implements a series of protections:
- Protected branches cannot be deleted.
- Protected branches cannot be reset.
- Projects with protected branches cannot be deleted.
- Computes associated with a protected branch cannot be deleted.
- New passwords are automatically generated for Postgres roles on branches created from protected branches. See below.
- With additional configuration steps, you can apply IP Allow restrictions to protected branches only. The IP Allow feature is available on the Neon Scale plan. See below.
- Protected branches are not archived due to inactivity.
The protected branches feature is available on Neon paid plans.
- The Launch plan supports up to 2 protected branches
- The Scale plan supports up to 5 protected branches
Set a branch as protected
This example sets branch as protected.
To set a branch as protected:
- 
In the Neon Console, select a project. 
- 
Select Branches to view the branches for the project.  
- 
Select a branch from the table. In this example, we'll configure our default branch productionas a protected branch.
- 
On the branch page, click Protect.  
- 
In the Set as protected confirmation dialog, click Set as protected to confirm your selection.  Your branch is now designated as protected, as indicated by the protected branch shield icon, shown below.  The protected branch designation also appears on your Branches page.  
New passwords generated for Postgres roles on child branches
When you create a branch in Neon, it includes all Postgres databases and roles from the parent branch. By default, Postgres roles on the child branch will have the same passwords as on the parent branch. However, this does not apply to protected branches. When you create a child branch from a protected branch, new passwords are generated for the matching Postgres roles on the child branch.
This behavior is designed to prevent the exposure of passwords that could be used to access your protected branch. For example, if you have designated a production branch as protected, the automatic password change for child branches ensures that you can create child branches for development or testing without risking access to data on your production branch.
Please note that resetting or restoring a child branch from a protected parent branch preserves passwords for matching Postgres roles on the child branch. Please refer to the feature notes below for more.
Feature notes
- The "new password" feature for child branches was released on July, 31, 2024. If you have existing CI scripts that create branches from protected branches, please be aware that passwords for matching Postgres roles on those newly created branches will now differ. If you depend on those passwords being the same, you'll need to make adjustments to get the correct connection details for those branches.
- After a branch is created, the up-to-date connection string is returned in the output of the Create Branch GitHub Action.
- The Reset Branch GitHub Action also outputs connection string values, in case you are using this action in your workflows.
- The Neon CLI supports a connection-string command for retrieving a branch's connection string.
 
- Prior to September, 6, 2024, resetting or restoring a child branch from a protected parent branch restored passwords for matching Postgres roles on the child branch to those used on the protected parent branch. As of September, 6, 2024, passwords for matching Postgres roles on the child branch are preserved when resetting or restoring a child branch from a protected parent branch.
How to apply IP restrictions to protected branches
On plans that support it, you can use the protected branches feature in combination with Neon's IP Allow feature to apply IP access restrictions to protected branches only. The basic setup steps are:
- Define an IP allowlist for your project
- Restrict IP access to protected branches only
- Set a branch as protected (if you have not done so already)
Define an IP allowlist for your project
To configure an allowlist:
- Select a project in the Neon Console.
- On the Project Dashboard, select Settings.
- Select Network Security.
- Under IP Allow, specify the IP addresses you want to permit. Separate multiple entries with commas.
- Click Save changes.
For details about specifying IP addresses, see How to specify IP addresses.
Restrict IP access to protected branches only
After defining an IP allowlist, the next step is to select the Restrict access to protected branches only option.

This option removes IP restrictions from all branches in your Neon project and applies them to protected branches only.
After you've selected the protected branches option, click Save changes to apply the new configuration.
Remove branch protection
Removing a protected branch designation can be performed by selecting Set as unprotected from the More drop-down menu on the branch page.
Need help?
Join our Discord Server to ask questions or see what others are doing with Neon. For paid plan support options, see Support.