postgresql_cluster
embedded-postgres
postgresql_cluster | embedded-postgres | |
---|---|---|
9 | 4 | |
1,272 | 745 | |
- | - | |
9.0 | 5.3 | |
6 days ago | 2 days ago | |
Jinja | Go | |
MIT License | MIT License |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
postgresql_cluster
-
Automated Deployment of PostgreSQL Ha Clusters Anywhere
Creating a robust and reliable database cluster is often fraught with challenges.A manual deployment process can be fraught with risks, particularly for those who lack extensive experience. Even minor errors in configuration can drastically affect your database's performance and stability.
Recognizing this intricacy, many businesses choose to use cloud-based managed databases. These services offer convenience but not without limitations. These drawbacks can include being tied to a specific cloud provider and limited direct access to the database server for adjustments. These constraints can hinder your ability to tune your system and perform thorough performance analyses.
In response to these challenges, we've developed a project to make this process easier and more efficient. This project uses automation to streamline the deployment of High-Availability PostgreSQL Clusters. By doing so, it helps mitigate the risks involved with manual configuration and speeds up the deployment process.
Our solution caters to various deployment environments. It allows you to establish your cluster either in your own data center or in the cloud, providing a robust database solution similar to managed databases, but with you retaining full control.
Explore the project here: https://github.com/vitabaks/postgresql_cluster
-
Docker: Patroni + HAProxy + Etcd + PgBouncer
FYI: postgresql_cluster
-
Can someone share experience configuring Highly Available PgSQL?
HA postgres
- Toying with the idea of running Postgres instead of using RDS
- HaProxy/PgBouncer location.
- PostgreSQL High-Availability Cluster
-
Ask HN: Tips on hosting your own Postgres instance
If not Kubernetes, check out this: https://github.com/vitabaks/postgresql_cluster – Postgres + patroni + pgBouncer + WAL-G or pgBackRest + Netdata + more, managed by Ansible.
If you do want to use Kubernetes, then check out StackGres.io and https://github.com/zalando/postgres-operator
-
PostgreSQL High availability
Also check PostgreSQL High-Availability Cluster (based on "Patroni" and "DCS(etcd)"). Automating deployment with Ansible.
embedded-postgres
-
If you could go back in time | What would you do different regarding go
So what can you do insted? For testing databases, setup a docker instance for tests (e.g. like in https://github.com/ardanlabs/service), or start an embedded-postgres daemon (see https://github.com/fergusstrange/embedded-postgres). For communication with external APIs, just pass the http.Client (either in context.Context or as a field on the struct). Then in tests, you can override the http.Client.Transport func.
-
Embedded database options
This is down to nuance, but all databases are "file based" as they all write to files. But most of them require a separate process with lock coordination to get away from writer lock delays and ensure ACID, which includes Postgresql. Calling any version of pgl "embedded" is confusing because I see that being used to describe pgl databases which are run in a localhost mode with a single reader/writer client. Regardless, those still require a postgres process and access it over IP. For simplicity, if one uses a database by touching its files directly from the process accessing the database, then it's "embedded"; but then again I guess that semantic ship has sailed: https://github.com/fergusstrange/embedded-postgres so the point may be moot.
-
Ask HN: Tips on hosting your own Postgres instance
depending on the language you have chosen for your side project you might also be able to run postgresql in embedded mode here is the one for golang https://github.com/fergusstrange/embedded-postgres . There is similar solution for java as well.
What are some alternatives?
patroni - A template for PostgreSQL High Availability with Etcd, Consul, ZooKeeper, or Kubernetes
go-mutesting - Mutation testing for Go source code
pg_auto_failover - Postgres extension and service for automated failover and high-availability
goc - A Comprehensive Coverage Testing System for The Go Programming Language
pgcat - PostgreSQL pooler with sharding, load balancing and failover support.
Testify - A toolkit with common assertions and mocks that plays nicely with the standard library
top500-benchmark - Automated Top500 benchmark for clusters or single nodes.
ginkgo - A Modern Testing Framework for Go
pigsty - Battery-Included PostgreSQL Distro as a Free RDS Alternative
go-vcr - Record and replay your HTTP interactions for fast, deterministic and accurate tests
k3s - Lightweight Kubernetes
schema - Quick and easy expression matching for JSON schemas used in requests and responses