Manage projects
A project is the top-level object in the Neon object hierarchy. Tier limits define how many projects you can create. Neon's Free Tier permits one project per Neon account.
A Neon project is created with the following resources, by default:
- A primary branch called
main
. You can create child branches from the primary branch or from a previously created branch. For more information, see Manage branches. - A single read-write compute endpoint, which is the compute instance associated with a branch. For more information, see Manage computes.
- A ready-to-use database, called
neondb
, which resides in the project's primary branch. - A default Postgres role that takes its name from your Neon account (the Google, GitHub, or partner account that you registered with).
Create a project
Neon Free Tier users can create a single project. Support for multiple projects is available to Neon Pro plan users.
To create a Neon project:
-
Navigate to the Neon Console.
-
If you are creating your very first project, click Create a project. Otherwise, click New Project.
-
Specify vales for Name, Postgres version, and Region. Project names are limited to 64 characters. If you are a Neon Pro plan user, you can specify Compute size settings when creating a project. The settings you specify become the default settings for compute endpoints that you add to your project when creating branches or read replicas.
- Neon supports fixed size computes and Autoscaling. For more information, see Compute size and Autoscaling configuration.
- The Auto-suspend delay setting defines the period of inactivity after which a compute endpoint is automatically suspended. For more information, see Auto-suspend configuration.
-
Click Create Project.
Upon creating a project, you are presented with a dialog that provides your connection details for a ready-to-use neondb
database. The connection details include your password.
Compute size configuration with Autoscaling
Neon Pro plan users can configure default compute size settings when creating a project or from the the Settings > Compute page.
Compute size is the number of Compute Units (CUs) assigned to a Neon compute endpoint. The number of CUs determines the processing capacity of the compute endpoint. One CU is equal to 1 vCPU with 4 GBs of RAM. Currently, a Neon compute endpoint can have anywhere from .25 CUs to 7 CUs. Larger compute sizes will be supported in a future release.
Neon supports two compute size configuration options:
- Fixed Size: This option allows you to select a fixed compute size ranging from .25 CUs to 7 CUs. A fixed-size compute does not scale to meet workload demand.
- Autoscaling: This option allows you to specify a minimum and maximum compute size. Neon scales the compute size up and down within the selected compute size boundaries in response to the current load. Currently, Autoscaling supports a range of 1 to 7 CUs. The 1/4 CU and 1/2 CU settings, called shared compute, will be supported with Autoscaling in a future release. For information about how Neon implements the Autoscaling feature, see Autoscaling.
View projects
To view your projects:
- Navigate to the Neon Console.
- Select Home or the Neon logo at the top left of the Console.
- The Projects page lists your projects, including any projects that have been shared with you.
Edit a project
You are permitted to change the project name when editing a project.
To edit a Neon project:
- Navigate to the Neon Console.
- Select the project that you want to edit.
- Select Settings.
- Select General.
- Make your change and click Save.
Configure history retention
By default, Neon retains a 7-day history of changes for all branches in a Neon project, which allows you to create a branch that restores data to any point within the defined retention period. The supported range is 0 to 7 days for Free Tier users, and 0 to 30 days for Pro plan users. Please be aware that increasing the history retention period affects all branches in your project and increases project storage.
To configure the history retention period for a project:
- Select a project in the Neon console.
- On the Neon Dashboard, select Settings.
- Select Storage.
- Use the slider to select the history retention period.
- Click Save.
Delete a project
Deleting a project is a permanent action, which also deletes any compute endpoints, branches, databases, and roles that belong to the project.
To delete a project:
- Navigate to the Neon Console.
- Select the project that you want to delete.
- Select Settings.
- Select Delete.
- Click Delete project.
- On the confirmation dialog, click Delete.
Share a project
Project sharing is a Neon Pro plan feature that allows you to share your project with other Neon accounts.
To share a project:
- In the Neon Console, select a project.
- Select Settings.
- Select Sharing.
- Under Grant access to your project, enter the email address of the account you want to share access with.
- Click Grant access.
The email you specify is added to the list of People who have access to the project. The Neon account associated with that email address is granted full access to the project with the exception privileges required to delete the project. When that user logs in to Neon, the shared project is listed on their Projects page, under Shared with me.
The costs associated with a shared project are charged to the Neon account that owns the project. For example, if you were to share your project with another Neon user account, any usage incurred by that user within your project is billed to your Neon account, not theirs.
Manage projects with the Neon API
Project actions performed in the Neon Console can also be performed using the Neon API. The following examples demonstrate how to create, view, and delete projects using the Neon API. For other project-related API methods, refer to the Neon API reference.
note
The API examples that follow may not show all of the user-configurable request body attributes that are available to you. To view all attributes for a particular method, refer to method's request body schema in the Neon API reference.
The jq
option specified in each example is an optional third-party tool that formats the JSON
response, making it easier to read. For information about this utility, see jq.
Prerequisites
A Neon API request requires an API key. For information about obtaining an API key, see Create an API key. In the cURL examples shown below, $NEON_API_KEY
is specified in place of an actual API key, which you must provide when making a Neon API request.
Create a project with the API
The following Neon API method creates a project. The Neon Free Tier permits one project per account. To view the API documentation for this method, refer to the Neon API reference.
The API method appears as follows when specified in a cURL command. The myproject
name value is a user-specified name for the project.
The response includes information about the roles, the ready-to-use database (neondb)
), the primary branch (main
), and the read-write compute endpoint that is created with the project.
Response body
List projects with the API
The following Neon API method lists projects for your Neon account. To view the API documentation for this method, refer to the Neon API reference.
The API method appears as follows when specified in a cURL command:
Response body
Update a project with the API
The following Neon API method updates the specified project. To view the API documentation for this method, refer to the Neon API reference.
The API method appears as follows when specified in a cURL command. The project_id
is a required parameter. The example changes the project name
to project1
.
Response body
Delete a project with the API
The following Neon API method deletes the specified project. To view the API documentation for this method, refer to the Neon API reference.
The API method appears as follows when specified in a cURL command. The project_id
is a required parameter.
Response body
Need help?
Send a request to support@neon.tech, or join the Neon community forum.