Skip to main content

A CLI tool for analyzing PostgreSQL index efficiency

Project description

pgindexinsight

pgindexinsight is a command-line interface (CLI) tool designed to help PostgreSQL users analyze and optimize the efficiency of their database indexes. The tool highlights inefficient indexes, offering insights to improve space utilization, vacuum operations, and overall database performance without the need for external extensions or packages.

Table of Contents

Why Choose pgindexinsight?

pgindexinsight offers a simple yet powerful way to ensure that your PostgreSQL indexes are running efficiently. Here are key reasons to choose this tool:

  • No Extensions or Packages Required: Unlike other PostgreSQL performance tools, pgindexinsight doesn’t require the installation of any database extensions or other packages. It keeps your database setup clean and reduces complexity.
  • No Need to Memorize Index Queries: The tool uses pre-defined queries to analyze your indexes, so you don’t have to recall or memorize the correct index analysis queries every time. This provides a hassle-free experience for database inspection.
  • Minimal Setup: The tool is easy to install and use. Whether you're a beginner or a seasoned database administrator, pgindexinsight is designed to make index management intuitive and straightforward.
  • Portable & Lightweight: As a standalone CLI tool, pgindexinsight can be run in any environment with PostgreSQL access. There’s no dependency on external software, so you can freely install or remove it whenever needed.

Key Features

  1. Index Usage Analysis: Detect redundant, unused, or bloated indexes and ensure your database operates efficiently.
  2. Comprehensive Reporting: Generate detailed reports on index health, usage, and redundancy.
  3. JSON Export Support: Easily export the results of your analyses in JSON format for further processing or integration with other systems.
  4. User-Friendly CLI: The tool is designed with ease of use in mind, allowing database administrators and developers to get started with minimal effort.

Benefits

  • Keep your PostgreSQL database clean: No need to install or manage third-party database extensions.
  • Flexible: Run the tool only when needed, and easily remove it afterward if no longer required.
  • Empowers Database Administrators: Get valuable insights into your index usage to optimize performance and space, without any extra overhead.

Requirements

  • Python 3.6 or higher
  • PostgreSQL 16 or higher
  • Required Python packages (listed in requirements.txt)

Installation

Installation from Source

  1. Clone the repository:
git clone https://github.com/yourusername/pg_index_insight.git
cd pg_index_insight
  1. Set up a virtual environment (optional but recommended):
python3 -m venv venv
source venv/bin/activate

3.Install the required packages:

pip install -r requirements.txt
pip install -e .

⚠️ Warning

Please ensure that you are working with proper python virtual env! It is not an obligation but strongly suggested.

Configure PostgreSQL User

pgindexinsight requires a user which can connect to the database that will be scanned. Therefore, the following example reveals the minimum privileges. Before executing pgindexinsight please ensure that the user has enough privileges.In addition to this please confirm pg_hba.conf allows the connection.

GRANT SELECT ON TABLE pg_stat_user_indexes TO pg_index_insight_user;
GRANT SELECT ON TABLE pg_index TO pg_index_insight_user;
GRANT SELECT ON TABLE pg_class TO pg_index_insight_user;
GRANT SELECT ON TABLE pg_namespace TO pg_index_insight_user;
GRANT SELECT ON TABLE pg_attribute TO pg_index_insight_user;
GRANT SELECT ON TABLE pg_stats TO pg_index_insight_user;
GRANT SELECT ON TABLE pg_indexes TO pg_index_insight_user;

Configure Environment Variables

Before using this tool, you need to configure some environment variables. These variables are essential for connecting to your PostgreSQL database. Set them by running the following commands in your terminal:

export DB_HOST="localhost"
export DB_PORT="5432"
export DB_NAME="your_db_name"
export DB_USER="your_user"
export DB_PASSWORD="your_pass"

Usage

pgindexinsight [command] [options]

Examples

pgindexinsight list-unused-or-old-indexes --json --output-path '/where/to/put/json/'
pgindexinsight list-invalid-indexes --json --output-path '/where/to/put/json/' --dry-run
pgindexinsight list-bloated-btree-indexes --json --output-path '/where/to/put/json/' --dry-run --bloat-threshold 5
pgindexinsight list-unemployed-indexes --json --output-path '/where/to/put/json/' --dry-run

Available Commands

  • list-unused-or-old-indexes: Lists unused or outdated indexes.

    • Options:
      • --json: Export output to a JSON file.
      • --output-path: JSON file output directory.
  • list-invalid-indexes: Identifies invalid indexes.

    • Options:
      • --dry-run: Display actions without executing them.
      • --json: Export output to a JSON file.
      • --output-path: JSON file output directory.
      • --drop-force: Drop invalid indexes. (User must be the owner or have superuser privileges.)
  • list-unemployed-indexes: Lists unused indexes.

    • Options:
      • --dry-run: Display actions without executing them.
      • --json: Export output to a JSON file.
      • --output-path: JSON file output directory.
  • list-bloated-btree-indexes: Reports on bloated B-tree indexes.

    • Options:
      • --dry-run: Display actions without executing them.
      • --json: Export output to a JSON file.
      • --output-path: JSON file output directory.
      • --bloat-threshold INTEGER: Set the bloat threshold percentage (default is 50%).

Example Output for list-unemployed-indexes

+-----------------+---------------+-------------------------------+--------------+------------------------+
| Database Name   | Schema Name   | Index Name                    | Index Size   | Category               |
|-----------------+---------------+-------------------------------+--------------+------------------------|
| benchmark_v1    | public        | idx_test_v7                   | 545 MB       | Unused&Redundant Index |
| benchmark_v1    | public        | idx_test_v6                   | 545 MB       | Unused&Redundant Index |
| benchmark_v1    | public        | idx_test_v5                   | 545 MB       | Unused&Redundant Index |
| benchmark_v1    | public        | idx_test_v6                   | 545 MB       | Duplicate Btree Index  |
| benchmark_v1    | public        | idx_test_v5                   | 545 MB       | Duplicate Btree Index  |
| benchmark_v1    | sales         | orders_2023_q2_order_date_idx | 16 kB        | Unused&Redundant Index |
| benchmark_v1    | public        | pgbench_accounts_pkey_v2      | 1285 MB      | Duplicate Unique Index |
| benchmark_v1    | public        | idx_test_data                 | 0 bytes      | Unused&Redundant Index |
| benchmark_v1    | public        | idx_test_data                 | 0 bytes      | Invalid Index          |
+-----------------+---------------+-------------------------------+--------------+------------------------+

Contributing

Contributions are welcome! If you have suggestions for improvements or would like to report a bug, please open an issue or submit a pull request.

  1. Fork the repository.
  2. Create your feature branch:
git checkout -b feature/YourFeatureName
  1. Commit your changes:
git commit -m 'Add some feature'
  1. Push to the branch:
git push origin feature/YourFeatureName
  1. Open a pull request.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pg_index_insight-1.4.0.tar.gz (15.7 kB view details)

Uploaded Source

Built Distribution

pg_index_insight-1.4.0-py3-none-any.whl (14.6 kB view details)

Uploaded Python 3

File details

Details for the file pg_index_insight-1.4.0.tar.gz.

File metadata

  • Download URL: pg_index_insight-1.4.0.tar.gz
  • Upload date:
  • Size: 15.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.9.6

File hashes

Hashes for pg_index_insight-1.4.0.tar.gz
Algorithm Hash digest
SHA256 fa5b4a00047c62d6f707504c0958469cf4b06288200b65bfaa30cb90d4f59132
MD5 31ee621028495f5175c21f6432526c27
BLAKE2b-256 13aee6c4656fcf5c277e7aceb4ae32582546cab32d21120179ea68bc46457908

See more details on using hashes here.

File details

Details for the file pg_index_insight-1.4.0-py3-none-any.whl.

File metadata

File hashes

Hashes for pg_index_insight-1.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6082ba8cdde90676a889629408ef72faf882de2a0a46bb3570a1a97d4bac6caf
MD5 a500d3e8d73a0418d1df3d3d0eb7519d
BLAKE2b-256 e273778aa4280d5920a4cc6fff619db66056bf3d1b30708d7e97c387cf93d69e

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page