Solitons.Postgres.PgUp
1.1.0
See the version list below for details.
dotnet tool install --global Solitons.Postgres.PgUp --version 1.1.0
dotnet new tool-manifest # if you are setting up this repo dotnet tool install --local Solitons.Postgres.PgUp --version 1.1.0
#tool dotnet:?package=Solitons.Postgres.PgUp&version=1.1.0
nuke :add-package Solitons.Postgres.PgUp --version 1.1.0
PgUp - README
Introduction
PgUp is a self-contained console application designed for seamless, zero-downtime deployment of PostgreSQL databases. PgUp's core philosophy centers around minimizing downtime and maintaining database integrity during complex deployments. It leverages PostgreSQL's advanced transactional capabilities to ensure atomicity and consistency, making it an essential tool for mission-critical environments where availability and reliability are paramount.
Key Features
- Zero-Downtime Deployment: PgUp wraps all schema changes and data manipulations within PostgreSQL transactions, ensuring that either all changes are applied or none are, thus maintaining a consistent and reliable database state.
- Automated Script Execution: PgUp supports flexible script discovery and execution modes, allowing you to automate complex deployments without manual intervention. This reduces the risk of errors and ensures that changes are consistently applied across different environments.
- Flexible Parameterization: PgUp allows for the parameterization of SQL scripts, enabling you to easily adapt deployments to different environments (e.g., development, staging, production) without modifying the scripts themselves.
- Cross-Platform Availability: PgUp is available on multiple platforms, including Debian, Ubuntu, and Windows, ensuring that it can be installed and run in a variety of environments without requiring additional runtimes or dependencies.
- Advanced Rollback Capabilities: PgUp offers granular control over rollbacks, allowing you to configure rollback strategies on a per-transaction or per-batch basis, providing enhanced reliability in deployment processes.
Installation
PgUp is available for installation on Debian, Ubuntu, and Windows using various package managers.
Debian/Ubuntu Installation
To install PgUp on Debian or Ubuntu, use the following commands:
Add the PgUp Repository:
sudo apt-get update
Install PgUp:
sudo apt-get install pgup
Windows Installation (Using Winget)
To install PgUp on Windows using Winget, follow these steps:
Open Command Prompt or PowerShell.
Run the Winget Command:
winget install YourCompany.PgUp
This will download and install the latest version of PgUp on your system.
Building from Source
If you prefer to build PgUp from source, you will need to have the .NET SDK and Git installed. The following steps outline the build process:
Clone the Repository:
git clone https://github.com/yourusername/pgup.git
Build the Application:
cd pgup dotnet build
Initializing a New PgUp Project
To start using PgUp, you can initialize a new project in any directory. This will create a directory structure with initial SQL scripts and a pgup.json
file that you can extend or modify as needed.
Initialize with a basic template:
pgup init . --template basic
Initialize without specifying a template (uses basec template by default):
pgup init .
These commands will set up your project directory, ready for you to customize according to your deployment needs.
Usage
PgUp provides a powerful and flexible interface for managing PostgreSQL database deployments. Below are some common examples of how to use the tool:
Deploying a PostgreSQL Database
pgup deploy pgup.json --host localhost --username admin --password secret
This command deploys the database according to the specifications in the pgup.json
configuration file.
Managing Deployment Parameters
pgup deploy --project pgup.json --host localhost --username admin --password secret --parameter[databaseName] mydb
This command overrides the databaseName
parameter in the pgup.json
file with a custom value for this deployment.
Performing a Forced Overwrite
pgup deploy pgup.json --connection "Host=localhost;Username=postgres;Password=secret" --overwrite --force
This command forcefully overwrites the existing database, resulting in the loss of all current data.
For more detailed usage scenarios and advanced options, refer to the Examples section.
Examples
Here are some practical examples of how PgUp can be utilized:
Deploying with Custom Parameters:
pgup deploy pgup.json --host localhost --username admin --password secret --parameter[databaseName] dev_db --timeout 00:30:00
Rollback After Unit Testing: PgUp allows you to define batches that run unit tests during the deployment process. These batches can be configured to roll back after execution, ensuring that test data does not persist in the production environment.
For additional examples and more complex scenarios, refer to the examples.txt file in the documentation.
License
PgUp is licensed under the Mozilla Public License (MPL), which allows for the use, modification, and distribution of the software with the requirement that any modifications made to the source code are also shared under the same license. For more details, see the LICENSE file.
Contributing
Contributions to PgUp are welcome! To contribute:
- Fork the repository on GitHub.
- Create a new branch for your feature or bugfix.
- Submit a pull request with a detailed description of your changes.
Please ensure that your contributions adhere to the project's coding standards and guidelines.
Support
For support, visit our GitHub Issues page or contact us via email at support@pgup.com.
Acknowledgments
We would like to thank all contributors who have helped make PgUp a robust and reliable tool.
Thank you for choosing PgUp! We are confident it will streamline your PostgreSQL deployment processes and enhance your database management capabilities.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
This package has no dependencies.
Version | Downloads | Last updated |
---|---|---|
1.1.1-alpha.15969869184667 | 27 | 1/19/2025 |
1.1.0 | 35 | 1/19/2025 |
Initial release of pgup. Streamline PostgreSQL deployments effortlessly.