From 6139cfc25d8ce4a272adf0587085455f136cdb66 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Juli=C3=A1n=20Calle?= Date: Wed, 21 Feb 2024 18:48:01 -0500 Subject: [PATCH] feat: add percent progress to initializing status view (#387) --- CHANGELOG.md | 53 +++++++++++++-------------------------- pgbelt/cmd/convenience.py | 8 ++---- pgbelt/cmd/preflight.py | 20 +++++++++------ pgbelt/cmd/status.py | 16 ++++++++++++ pgbelt/util/postgres.py | 32 +++++++++++++++++++++++ 5 files changed, 81 insertions(+), 48 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 1ea4f3a..48c0f57 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,119 +2,102 @@ ## [0.6.2](https://github.com/Autodesk/pgbelt/compare/v0.6.1...v0.6.2) (2024-02-02) - ### Bug Fixes -* stop using default replication set ([#371](https://github.com/Autodesk/pgbelt/issues/371)) ([cfa6276](https://github.com/Autodesk/pgbelt/commit/cfa62766c43c4f632582730339637be2f5021390)) +- stop using default replication set ([#371](https://github.com/Autodesk/pgbelt/issues/371)) ([cfa6276](https://github.com/Autodesk/pgbelt/commit/cfa62766c43c4f632582730339637be2f5021390)) ## [0.6.1](https://github.com/Autodesk/pgbelt/compare/v0.6.0...v0.6.1) (2024-01-22) - ### Bug Fixes -* pglogical teardown will now always revoke all from all tables from pglogical role ([#362](https://github.com/Autodesk/pgbelt/issues/362)) ([89e892c](https://github.com/Autodesk/pgbelt/commit/89e892c323ffda4bfbedd4d4a04ec612202cbe81)) +- pglogical teardown will now always revoke all from all tables from pglogical role ([#362](https://github.com/Autodesk/pgbelt/issues/362)) ([89e892c](https://github.com/Autodesk/pgbelt/commit/89e892c323ffda4bfbedd4d4a04ec612202cbe81)) ## [0.6.0](https://github.com/Autodesk/pgbelt/compare/v0.5.4...v0.6.0) (2023-11-20) - ### Features -* refactor Teardown Command due to DROP EXTENSION woes ([#326](https://github.com/Autodesk/pgbelt/issues/326)) ([5de6300](https://github.com/Autodesk/pgbelt/commit/5de6300d597f3e3f45dd03b83c286fcc07b1ced0)) +- refactor Teardown Command due to DROP EXTENSION woes ([#326](https://github.com/Autodesk/pgbelt/issues/326)) ([5de6300](https://github.com/Autodesk/pgbelt/commit/5de6300d597f3e3f45dd03b83c286fcc07b1ced0)) ## [0.5.4](https://github.com/Autodesk/pgbelt/compare/v0.5.3...v0.5.4) (2023-11-09) - ### Bug Fixes -* bump pydantic from 1.10.13 to 2.4.2 ([#299](https://github.com/Autodesk/pgbelt/issues/299)) ([8597fcc](https://github.com/Autodesk/pgbelt/commit/8597fccca106606dd1513839bc23c170383f3f2b)) +- bump pydantic from 1.10.13 to 2.4.2 ([#299](https://github.com/Autodesk/pgbelt/issues/299)) ([8597fcc](https://github.com/Autodesk/pgbelt/commit/8597fccca106606dd1513839bc23c170383f3f2b)) ## [0.5.3](https://github.com/Autodesk/pgbelt/compare/v0.5.2...v0.5.3) (2023-11-09) - ### Bug Fixes -* grant pglogical schema usage [#278](https://github.com/Autodesk/pgbelt/issues/278) ([#318](https://github.com/Autodesk/pgbelt/issues/318)) ([0de9290](https://github.com/Autodesk/pgbelt/commit/0de929074db26e5ca3d47ab9adfbf9bc3d055f0f)) +- grant pglogical schema usage [#278](https://github.com/Autodesk/pgbelt/issues/278) ([#318](https://github.com/Autodesk/pgbelt/issues/318)) ([0de9290](https://github.com/Autodesk/pgbelt/commit/0de929074db26e5ca3d47ab9adfbf9bc3d055f0f)) ## [0.5.2](https://github.com/Autodesk/pgbelt/compare/v0.5.1...v0.5.2) (2023-10-26) - ### Bug Fixes -* remote.py error handling needs to shore up plugin error ([#311](https://github.com/Autodesk/pgbelt/issues/311)) ([b47b07f](https://github.com/Autodesk/pgbelt/commit/b47b07f6705b1c8548b67d17b69e5a29e2de5178)) +- remote.py error handling needs to shore up plugin error ([#311](https://github.com/Autodesk/pgbelt/issues/311)) ([b47b07f](https://github.com/Autodesk/pgbelt/commit/b47b07f6705b1c8548b67d17b69e5a29e2de5178)) ## [0.5.1](https://github.com/Autodesk/pgbelt/compare/v0.5.0...v0.5.1) (2023-10-06) - ### Bug Fixes -* index commands need to surface as CLI commands too ([#275](https://github.com/Autodesk/pgbelt/issues/275)) ([a8d6fae](https://github.com/Autodesk/pgbelt/commit/a8d6faef753d434a6883aac5797c2b0cb952e86a)) +- index commands need to surface as CLI commands too ([#275](https://github.com/Autodesk/pgbelt/issues/275)) ([a8d6fae](https://github.com/Autodesk/pgbelt/commit/a8d6faef753d434a6883aac5797c2b0cb952e86a)) ## [0.5.0](https://github.com/Autodesk/pgbelt/compare/v0.4.0...v0.5.0) (2023-10-06) - ### Features -* stripping indexes and adding them later, and testing ([#273](https://github.com/Autodesk/pgbelt/issues/273)) ([c730e78](https://github.com/Autodesk/pgbelt/commit/c730e7852fdf40001633fd074b5aac4128a48af2)) - +- stripping indexes and adding them later, and testing ([#273](https://github.com/Autodesk/pgbelt/issues/273)) ([c730e78](https://github.com/Autodesk/pgbelt/commit/c730e7852fdf40001633fd074b5aac4128a48af2)) ### Bug Fixes -* precheck parameter value guidelines updated for [#267](https://github.com/Autodesk/pgbelt/issues/267) ([#268](https://github.com/Autodesk/pgbelt/issues/268)) ([e423929](https://github.com/Autodesk/pgbelt/commit/e42392993da1500ef564c3f6cc287f89531651e0)) +- precheck parameter value guidelines updated for [#267](https://github.com/Autodesk/pgbelt/issues/267) ([#268](https://github.com/Autodesk/pgbelt/issues/268)) ([e423929](https://github.com/Autodesk/pgbelt/commit/e42392993da1500ef564c3f6cc287f89531651e0)) ## [0.4.0](https://github.com/Autodesk/pgbelt/compare/v0.3.0...v0.4.0) (2023-07-10) - ### Features -* ability to not write logs to disk if needed ([#255](https://github.com/Autodesk/pgbelt/issues/255)) ([69469c0](https://github.com/Autodesk/pgbelt/commit/69469c0c16f1891992e7d15f4725369de3162cd7)) +- ability to not write logs to disk if needed ([#255](https://github.com/Autodesk/pgbelt/issues/255)) ([69469c0](https://github.com/Autodesk/pgbelt/commit/69469c0c16f1891992e7d15f4725369de3162cd7)) ## [0.3.0](https://github.com/Autodesk/pgbelt/compare/v0.2.4...v0.3.0) (2023-06-29) - ### Features -* check-connectivity command ([#253](https://github.com/Autodesk/pgbelt/issues/253)) ([6ebfff7](https://github.com/Autodesk/pgbelt/commit/6ebfff7a80573a1a33f1c54096fe300786e205c3)) +- check-connectivity command ([#253](https://github.com/Autodesk/pgbelt/issues/253)) ([6ebfff7](https://github.com/Autodesk/pgbelt/commit/6ebfff7a80573a1a33f1c54096fe300786e205c3)) ## [0.2.4](https://github.com/Autodesk/pgbelt/compare/v0.2.3...v0.2.4) (2023-06-15) - ### Bug Fixes -* allowing backwards compatibility down to python 3.9 ([#247](https://github.com/Autodesk/pgbelt/issues/247)) ([78b2fd8](https://github.com/Autodesk/pgbelt/commit/78b2fd8d05368f23ecd6c1ece223893bb424731c)) +- allowing backwards compatibility down to python 3.9 ([#247](https://github.com/Autodesk/pgbelt/issues/247)) ([78b2fd8](https://github.com/Autodesk/pgbelt/commit/78b2fd8d05368f23ecd6c1ece223893bb424731c)) ## [0.2.3](https://github.com/Autodesk/pgbelt/compare/v0.2.2...v0.2.3) (2023-05-04) - ### Bug Fixes -* double quotes on table names ([#228](https://github.com/Autodesk/pgbelt/issues/228)) ([893773a](https://github.com/Autodesk/pgbelt/commit/893773aa113b719f32e4e5486e585c584499cd9e)) +- double quotes on table names ([#228](https://github.com/Autodesk/pgbelt/issues/228)) ([893773a](https://github.com/Autodesk/pgbelt/commit/893773aa113b719f32e4e5486e585c584499cd9e)) ## [0.2.2](https://github.com/Autodesk/pgbelt/compare/v0.2.1...v0.2.2) (2023-05-02) - ### Bug Fixes -* undo bump of virtualenv, back to 20.21.0 ([#223](https://github.com/Autodesk/pgbelt/issues/223)) ([01bfe6f](https://github.com/Autodesk/pgbelt/commit/01bfe6fc167df009d451ac83666f1075a4a0ae05)) +- undo bump of virtualenv, back to 20.21.0 ([#223](https://github.com/Autodesk/pgbelt/issues/223)) ([01bfe6f](https://github.com/Autodesk/pgbelt/commit/01bfe6fc167df009d451ac83666f1075a4a0ae05)) ## [0.2.1](https://github.com/Autodesk/pgbelt/compare/v0.2.0...v0.2.1) (2023-05-02) - ### Bug Fixes -* typer doesn't support union types from python 3.11 ([#220](https://github.com/Autodesk/pgbelt/issues/220)) ([0315390](https://github.com/Autodesk/pgbelt/commit/03153909bcdf4e621b3e7c66aa5a99e55c9ceea4)) +- typer doesn't support union types from python 3.11 ([#220](https://github.com/Autodesk/pgbelt/issues/220)) ([0315390](https://github.com/Autodesk/pgbelt/commit/03153909bcdf4e621b3e7c66aa5a99e55c9ceea4)) ## [0.2.0](https://github.com/Autodesk/pgbelt/compare/v0.1.2...v0.2.0) (2023-04-28) - ### Features -* update to python 3.11 ([#191](https://github.com/Autodesk/pgbelt/issues/191)) ([3c44681](https://github.com/Autodesk/pgbelt/commit/3c44681bfda3679bff10022eb9bfcb56fdd9e50a)) - +- update to python 3.11 ([#191](https://github.com/Autodesk/pgbelt/issues/191)) ([3c44681](https://github.com/Autodesk/pgbelt/commit/3c44681bfda3679bff10022eb9bfcb56fdd9e50a)) ### Bug Fixes -* incorrect precheck command in quickstart.md ([#172](https://github.com/Autodesk/pgbelt/issues/172)) ([36ce96f](https://github.com/Autodesk/pgbelt/commit/36ce96feb6f5c98bcb3c7a0648a25e4f3b9ce655)) -* no need to find and replace owners in schema ([#215](https://github.com/Autodesk/pgbelt/issues/215)) ([dfe1324](https://github.com/Autodesk/pgbelt/commit/dfe1324a56f57e75fa44dfe7196e104c34988695)) +- incorrect precheck command in quickstart.md ([#172](https://github.com/Autodesk/pgbelt/issues/172)) ([36ce96f](https://github.com/Autodesk/pgbelt/commit/36ce96feb6f5c98bcb3c7a0648a25e4f3b9ce655)) +- no need to find and replace owners in schema ([#215](https://github.com/Autodesk/pgbelt/issues/215)) ([dfe1324](https://github.com/Autodesk/pgbelt/commit/dfe1324a56f57e75fa44dfe7196e104c34988695)) ## [0.1.2](https://github.com/Autodesk/pgbelt/compare/v0.1.1...v0.1.2) (2022-10-03) diff --git a/pgbelt/cmd/convenience.py b/pgbelt/cmd/convenience.py index 97bb994..0af3167 100644 --- a/pgbelt/cmd/convenience.py +++ b/pgbelt/cmd/convenience.py @@ -34,9 +34,7 @@ def src_dsn( echo( conf.src.owner_dsn if owner - else conf.src.pglogical_dsn - if pglogical - else conf.src.root_dsn + else conf.src.pglogical_dsn if pglogical else conf.src.root_dsn ) @@ -56,9 +54,7 @@ def dst_dsn( echo( conf.dst.owner_dsn if owner - else conf.dst.pglogical_dsn - if pglogical - else conf.dst.root_dsn + else conf.dst.pglogical_dsn if pglogical else conf.dst.root_dsn ) diff --git a/pgbelt/cmd/preflight.py b/pgbelt/cmd/preflight.py index 88c7695..325b3fe 100644 --- a/pgbelt/cmd/preflight.py +++ b/pgbelt/cmd/preflight.py @@ -52,10 +52,14 @@ async def _print_prechecks(results: list[dict]) -> list[list]: style(r["db"], "green"), style( r["server_version"], - "green" - if float(r["server_version"].rsplit(" ", 1)[0].rsplit(".", 1)[0]) - >= 9.6 - else "red", + ( + "green" + if float( + r["server_version"].rsplit(" ", 1)[0].rsplit(".", 1)[0] + ) + >= 9.6 + else "red" + ), ), style( r["max_replication_slots"], @@ -76,9 +80,11 @@ async def _print_prechecks(results: list[dict]) -> list[list]: style(pglogical, "green" if pglogical == "installed" else "red"), style( r["rds.logical_replication"], - "green" - if r["rds.logical_replication"] in ["on", "Not Applicable"] - else "red", + ( + "green" + if r["rds.logical_replication"] in ["on", "Not Applicable"] + else "red" + ), ), style(root_ok, "green" if root_ok else "red"), style(owner_ok, "green" if owner_ok else "red"), diff --git a/pgbelt/cmd/status.py b/pgbelt/cmd/status.py index 7dc0b97..dba7ddf 100644 --- a/pgbelt/cmd/status.py +++ b/pgbelt/cmd/status.py @@ -7,6 +7,7 @@ from pgbelt.util import get_logger from pgbelt.util.pglogical import dst_status from pgbelt.util.pglogical import src_status +from pgbelt.util.postgres import initialization_status from tabulate import tabulate from typer import echo from typer import style @@ -22,6 +23,9 @@ async def _print_status_table(results: list[dict[str, str]]) -> list[list[str]]: style("flush_lag", "yellow"), style("write_lag", "yellow"), style("replay_lag", "yellow"), + style("src_db_size", "yellow"), + style("dst_db_size", "yellow"), + style("progress", "yellow"), ] ] @@ -41,6 +45,9 @@ async def _print_status_table(results: list[dict[str, str]]) -> list[list[str]]: style(r["flush_lag"], "green" if r["flush_lag"] == "0" else "red"), style(r["write_lag"], "green" if r["write_lag"] == "0" else "red"), style(r["replay_lag"], "green" if r["replay_lag"] == "0" else "red"), + style(r["src_db_size"], "green"), + style(r["dst_db_size"], "green"), + style(r["progress"], "green"), ] ) @@ -70,6 +77,7 @@ async def status(conf_future: Awaitable[DbupgradeConfig]) -> dict[str, str]: conf = await conf_future src_logger = get_logger(conf.db, conf.dc, "status.src") dst_logger = get_logger(conf.db, conf.dc, "status.dst") + initialization_logger = get_logger(conf.db, conf.dc, "status.initialization") pools = await gather( create_pool(dsn=conf.src.root_uri, min_size=1), @@ -81,10 +89,18 @@ async def status(conf_future: Awaitable[DbupgradeConfig]) -> dict[str, str]: result = await gather( src_status(src_pool, src_logger), dst_status(dst_pool, dst_logger), + initialization_status( + conf.src.db, conf.dst.db, src_pool, dst_pool, initialization_logger + ), ) result[0].update(result[1]) result[0]["db"] = conf.db + if result[0]["pg1_pg2"] != "initializing": + result[2]["src_db_size"] = "n/a" + result[2]["dst_db_size"] = "n/a" + result[2]["progress"] = "n/a" + result[0].update(result[2]) return result[0] finally: await gather(*[p.close() for p in pools]) diff --git a/pgbelt/util/postgres.py b/pgbelt/util/postgres.py index 3ec5c84..b23e115 100644 --- a/pgbelt/util/postgres.py +++ b/pgbelt/util/postgres.py @@ -376,3 +376,35 @@ async def precheck_info( result["owner"] = u return result + + +async def get_db_size(db: str, pool: Pool, logger: Logger) -> str: + """ + Get the DB size + """ + logger.info("Getting the DB size...") + result = { + "db_size": await pool.fetchval(f"SELECT pg_database_size('{db}');"), + "db_size_pretty": await pool.fetchval( + f"SELECT pg_size_pretty( pg_database_size('{db}') );" + ), + } + + return result + + +async def initialization_status( + db_src: str, db_dst: str, src_pool: Pool, dst_pool: Pool, logger: Logger +) -> dict[str, str]: + """ + Get the status of the initialization stage + """ + logger.info("checking status of the initialization stage...") + src_db_size = await get_db_size(db_src, src_pool, logger) + dst_db_size = await get_db_size(db_dst, dst_pool, logger) + status = { + "src_db_size": src_db_size["db_size_pretty"], + "dst_db_size": dst_db_size["db_size_pretty"], + "progress": f"{str(round(int(dst_db_size['db_size'])/int(src_db_size['db_size'])*100 ,1))} %", + } + return status