From V1.0.0 on this file will not get updated (Checkout GitHub releases)
- changes from upstream (pg15, k8s manifest update & UUID pakcage change)
- bump up golang version to 1.19
- bump up debian version for docker images
- added Slave Mode status to stolonctl status
- remove depricated ioutil package
- changes from upstream (pg15, k8s manifest update & UUID pakcage change)
- bump up golang version to 1.19
- bump up debian version for docker images
- added Slave Mode status to stolonctl status
- remove depricated ioutil package
- control over loadbalance of the slave nodes
- bump up golang version to 1.18
- fix bug when there is no healthy slave
- simple round robin selection of slave nodes
- Added extra logging when slave node is selected
- Support PostgreSQL 14 (From original repository)
- Added slave option to proxy
and many other changes.
A big Thank You to everybody who contributed to this release!
- k8s store: patch pod annotations instead of doing a full update (#751)
- Make proxyCheckInterval and proxyTimeout configurable (#756)
- Make DefaultSyncTimeout infinite (#752)
- Document SyncTimeout cluster spec option (#749)
and many other changes.
A big Thank You to everybody who contributed to this release!
- Support PostgreSQL 12 (#727)
- Added wal-g examples (#726)
- Stolonctl spec: don't show null clusterspec options (#736)
- Prevent stolonctl init with empty clusterspec file (#702)
- Do pg_rewind only against primary instance (#698)
and many other changes.
A big Thank You to everybody who contributed to this release!
- Add sentinel prometheus metrics (#656)
- Store only the last 2 postgres timeline histories to not exceed the max value size of the underlying store (#651)
- Add keeper prometheus metrics (#639)
- stolonctl status can output status in json format (#628)
- Enable all k8s client auth plugins (#625 #632)
- It's now possible to define the advertise address and port in stolon keeper (#581)
- A new
stolonctl register
command was added to set service discovery information about keepers to an external service (currently only consul) (#557) - Ability to auto restart an instance when updating a postgres parameter that requries a restart (#568)
- Add stolon clusterdata read/write subcommands (#578)
- Enable verbose e progress logging for pg_basebackup (#665)
- Implement timeouts for kubernetes api calls (#666)
- Avoid unneeded postgres instance reloads (#558)
- Allow special characters in pg-su-username (#658)
- Fix failover process if a keeper has filesystem errors (#637)
- postgres: use go database/sql context functions (#635)
- Use go database/sql context functions (#635)
- Fix hanging sentinels (#659)
and many other changes.
- The
stolonctl clusterdata
command has been split into two subcommands:stolonctl clusterdata read
which will be used to read the current clusterdata.stolonctl clusterdata write
which will be used to write the new clusterdata into the new store.
A big Thank You to everybody who contributed to this release:
- Anton Markelov (@strangeman)
- Arunvel Sriram (@arunvelsriram)
- Aswin Karthik (@aswinkarthik)
- Ben Wheatley (@benwh)
- David Eichin (@daMupfel)
- Dinesh B (@dineshba)
- Don Bowman (@donbowman)
- Harry Maclean (@hmac)
- Krishnaswamy Subramanian (@jskswamy)
- Lawrence Jones (@lawrencejones)
- Milyutin Maksim (@maksm90)
- Mosab Ibrahim (@mos3abof)
- Nicolas Juhel (@nabbar)
- Prabhu Jayakumar (@prabhu43)
- Add a
stolonctl
command to force fail a keeper (#546) - Overcome PostgreSQL synchronous replication limitation that could cause lost transactions under some events (#514)
- Users can now define
archiveRecoverySettings
in the cluster spec of a standby cluster. One of the possible use cases is to feed the standby cluster only with archived logs without streaming replication. (See Upgrade Notes) (#543) - Keeper: remove trailing new lines from provided passwords (#548)
- Sort keepers addresses in
pg_hba.conf
to avoid unneeded postgres instance reloads (#558) - Set
recovery_target_action
to promote when using recovery target settings (#545) - Fixed wrong listen address used in
pg_hba.conf
whenSUReplAccessStrict
mode was enabled (#520)
and many other bug fixes and documentation improvements.
Thanks to everybody who contributed to this release.
- The clusterspec
standbySettings
option as been replaced by thestandbyConfig
option. Internally it can contain two fieldsstandbySettings
andarchiveRecoverySettings
(see the clusterspec doc with the descriptors of this new option). If you're updating a standby cluster, BEFORE starting it you should update, usingstolonctl
, the clusterspec with the newstandbyConfig
option.
- Detect and report when keeper persistent data dir is not the expected one (usually due to wrong configuration, non persistent storage etc...) (#510)
- Support PostgresSQL 11 (beta) (#513)
- Replication slots declared in the clusterspec
additionalMasterReplicationSlots
option will now be prefixed with thestolon_
string to let users be able to manually create/drop custom replication slots (See Upgrade Notes) (#531)
- fix wrong address in pg_hba.conf when clusterspec
defaultSUReplAccessMode
isstrict
(#520)
and many other bug fixes and documentation improvements.
Thanks to everybody who contributed to this release:
Alexandre Assouad, Lothar Gesslein, @nseyvet
- Replication slots declared in the clusterspec
additionalMasterReplicationSlots
option will now be prefixed with thestolon_
string to let users be able to manually create/drop custom replication slots (they shouldn't start withstolon_
). Users of these feature should upgrade all the references to these replication slots adding thestolon_
prefix.
- In the k8s store backend, stolon components discovery now uses the
component
label instead of theapp
label (See Upgrade Notes) (#469) - Improved docker swarm examples to resemble the k8s one (#482)
- If the user enabled ssl/tls use it also for replication/pg_rewind connections (#501)
- Remove final newline from example base64 password in k8s example (#505)
- Fixed wrong libkv store election path (See Upgrade Notes) (#479)
- Fixed a check in synchronous replication that will block future synchronous standbys updates under some circumstances (#494)
- Fixed atomic writes of postgresql genenerated files (#495)
Thanks to everybody who contributed to this release:
Bill Helgeson, Niklas Hambüchen, Sylvere Richard, Tyler Kellen
- In the k8s store backend, the label that defines the kind of stolon component has changed from
app
tocomponent
. When upgrading you should update the various resource descriptors setting the k8s component name (stolon-keeper
,stolon-sentinel
,stolon-proxy
) inside thecomponent
label instead of theapp
label. - When using the etcdv2 store, due to a wrong leader election path introduced in the last release and now fixed, if your sentinel returns an election error like
election loop error {"error": "102: Not a file ...
you should stop all the sentinels and remove the wrong dir usingetcdctl rmdir /stolon/cluster/$STOLONCLUSTER/sentinel-leader
where$STOLONCLUSTER
should be substituted with the stolon cluster name (remember to setETCDCTL_API=2
).
- Initial support for native kubernetes store (#433)
- Improved sync standby management (#444)
- Ability to use strict and dynamic hba entries for keeper replication (#412)
- Ability to define additional replication slots for external clients (#434)
- Improved wal level selection (#450)
Thanks to everybody who contributed to this release:
Pierre Alexandre Assouad, Arun Babu Neelicattu, Sergey Kim
- The logs will be colored only when on a tty or when
--log-color
is provided (#416) - Now the store prefix is configurable
--store-prefix
(#425)
- Fixed keeper missing waits for instance ready (#418)
- Fixed etcdv3 store wrong get leader timeout causing
stolonctl status
errors (#426)
Thanks to everybody who contributed to this release:
Pierre Fersing, Dmitry Andreev
- Added support for etcd v3 api (using --store-backend etcdv3) (#393)
- Now the stolon-proxy has tcp keepalive enabled by default and provides options for tuning its behavior (#357)
- Added
removekeeper
command to stolonctl (#383) - Added the ability to choose the authentication method for su and replication user (currently one of md5 or trust) (#380)
- Fixed and improved db startup logic to handle a different pg_ctl start behavior between postgres 9 and 10 (#401)
- Fixed keeper datadir locking (#405)
and many other bug fixes and documentation improvements.
Thanks to everybody who contributed to this release:
AmberBee, @emded, Pierre Fersing
- Added ability to define custom pg_hba.conf entries (#341)
- Added ability to set Locale, Encoding and DataChecksums when initializing a new pg db cluster (#338)
- Added stolonctl
clusterdata
command to dump the current clusterdata saved in the store (#318) - Detect if a standby cannot sync due to missing wal files on primary (#312)
- Various improvements to proxy logic (#308) (#310)
- Added cluster spec option to define additional wal senders (#311)
- Added various postgresql recovery target settings for point in time recovery (#303)
- Added
--log-level
argument to stolon commands (deprecating--debug
) (#298)
and many other bug fixes and documentation improvements
Thanks to everybody who contributed to this release:
Albert Vaca, @emded, Niklas Hambüchen, Tim Heckman
This version introduces various interesting new features (like support for upcoming PostgreSQL 10 and standby cluster) and different bug fixes.
- Support for PostgreSQL 10 (#281)
- Standby cluster (for multi site disaster recovery and near zero downtime migration) (#283)
- Old dead keeper removal (#280)
- On asynchronous clusters elect master only if behind a user defined lag (#268)
- Docker standalone, swarm and compose examples (#231) and (#238)
- Fix incorrect parsing of
synchronous_standby_names
when using synchronous replication with two or more synchronous standbys (#264) - Fix non atomic writes of local state files (#265)
and many other
Thanks to everybody who contributed to this release:
Alexander Ermolaev, Dario Nieuwenhuis, Euan Kemp, Ivan Sim, Jasper Siepkes, Niklas Hambüchen, Sajal Kayan
This version is a big step forward previous releases and provides many new features and a better cluster management.
- Now the configuration is fully declarative (see cluster specification documentation) (#178).
- Ability to create a new cluster starting from a previous backup (point in time recovery) (#183)
- Wal-e backup/restore example (#183)
- Better synchronous replication, the user can define a min and a max number of required synchronous standbys and the master will always block waiting for acknowledge by the required sync standbys. Only synchronous standbys will be elected as new master. (#219)
- Production ready kubernetes examples (just change the persistent volume provider) (#215)
- To keep an unique managed central configuration, the postgresql parameters can now only be managed only using the cluster specification (#181)
- When (re)initializing a new cluster (with an empty db, from an existing instance or from a backup) the postgresql parameters are automatically merged in the cluster spec (#181)
- Use only store based communication and discovery (removed all the kubernetes specific options) (#195)
- Ability to use TLS communication with the store (for both etcd and consul) (#208)
- Better standby monitoring and replacement (#218)
- Improved logging (#187)
Many other improvements and bug fixes
Some cleanups and changes in preparation for release v0.5.0 that will receive a big refactor (with different breaking changes) needed to bring a lot of new features.
- Support multiple stores via libkv (#102). Currently etcd and consul are supported.
- Can use pg_rewind to sync slaves instead of doing a full resync (#122).
- The
--initial-cluster-config
option has been added to thestolon-sentinel
to provide an initial cluster configuration (#107). - A cluster config option for initializing the cluster also if multiple keepers are registred has been added (#106). By default a sentinel won't initialize a new if multiple keepers are registered since it cannot know which one should be the master. With this option a random keeper will be choosed as the master. This is useful when an user wants to create a new cluster with an empty database and starting all the keeper together instead of having to start only one keeper, wait it to being elected as master and then starting the other keepers.
- The
--discovery-type
option has been added to thestolon-sentinel
to choose if keeper discovery should be done using the store or kubernetes (#129). - Various options has been added to the
stolon-keeper
for setting postgres superuser, replication and initial superuser usernames and passwords (#136). - Numerous enhancements and bugfixes.
Thanks to all the contributors!
- A stolon client (stolonctl) is provided. At the moment it can be used to get clusters list, cluster status and get/replace/patch cluster config (#28 #64). In future multiple additional functions will be added. See doc/stolonctl.md.
- The cluster config is now configurable using stolonctl (#2). See doc/cluster_config.md.
- Users can directly put their preferred postgres configuration files inside a configuration directory ($dataDir/postgres/conf.d or provided with --pg-conf-dir) (see doc/postgres_parameters.md)
- Users can centrally manage global postgres parameters. They can be configured in the cluster configuration (see doc/postgres_parameters.md)
- Now the stolon-proxy closes connections on etcd error. This will help load balancing multiple stolon proxies (#74 #76 #80).
- kubernetes: added readiness probe for stolon proxy (#82)
- The keeper takes an exclusive fs lock on its datadir (#48)
- Numerous bug fixes and improved tests.