- Dependency updates
- Create shadow and audit with auatovacuum default turned off. Should avoid lock queues when disabling vacuum on audit table. #97
- Dependency updates and refresh docker release process with multi-platform build
- Fix typo in README.md shayonj#87
- Support for views shayonj#88
- Gem path and CI fixes
- Ruby 3.1.3 and prettier/ruby shayonj#83
- Ruby matrix in ci and require ruby 2.7+ shayonj#84
- Re-enable autovacuum by @jfrost shayonj#85
- Bump google-protobuf from 3.21.6 to 3.21.7 shayonj#76
- Supports tablenames containing uppercase letters shayonj#77
- Update rubocop todo shayonj#78
- Ensure original triggers are carried over from parent table shayonj#79
- off-by-one: Don't skip PK sequence value by one shayonj#74
- Update primary key sequence on shadow table shayonj#72
- Thanks to @brycethornton for the report
- Only refresh primary key when a sequence is attached shayonj#73
NOTE: Skip to 0.7.3. 0.7.2 release missed the change.
- Update primary key sequence on shadow table shayonj#72
- Thanks to @brycethornton for the report
- Move CI to Github Actions in shayonj#64
- Set --password as optional since it is deprecated in shayonj#66
- Smoke tests in shayonj#65
- Add foreign keys to parent during swap in shayonj#67
- Delete items by audit table PK when replaying by @shayonj @jfrost in shayonj#60
- Fixes a race condition issue: shayonj#58
- Share some preliminary load test figures in shayonj#54
- Reuse existing transaction open for reading table columns in shayonj#53
- Start to deprecate --password with PGPASSWORD in shayonj#56
- Introduce configurable PULL_BATCH_COUNT and DELTA_COUNT in shayonj#57
- Lint sourcecode, setup Rubocop proper and Lint in CI by @shayonj in shayonj#46
- Uniquely identify operation_type column by @shayonj in shayonj#50
- Introduce primary key on audit table for ordered reads by @shayonj in shayonj#49
- This addresses an edge case with replay.
- Uniquely identify trigger_time column by @shayonj in shayonj#51
- Abstract assertions into a helper function by @shayonj in shayonj#52
- Explicitly call dependencies and bump dependencies by @shayonj shayonj#44
- Introduce Dockerfile and release process shayonj#45
- Use ISOLATION LEVEL SERIALIZABLE (#42) (props to @jfrost)
Initial release
pg-online-schema-change (pg-osc
) is a tool for making schema changes (any ALTER
statements) in Postgres tables with minimal locks, thus helping achieve zero downtime schema changes against production workloads.
pg-osc
uses the concept of shadow table to perform schema changes. At a high level, it copies the contents from a primary table to a shadow table, performs the schema change on the shadow table and swaps the table names in the end while preserving all changes to the primary table using triggers (via audit table).
Checkout Readme for more details.