zvook / php-postgresql-stat
PHP PostgreSQL statistic monitoring tool
1.2.0
2017-02-22 11:31 UTC
Requires
- php: >=5.6.0
Requires (Dev)
- phpunit/phpunit: ~5.7
This package is not auto-updated.
Last update: 2025-01-04 22:08:39 UTC
README
Requirements
- PHP 5.6+
- PostgreSQL 9.2+ (9.5+ recommended)
Containing
- Database statistic
- Tables statistic
- Indexes statistic
- Functions statistic
- Statements
- Useless/Missing indexes analytic
Installation
- Update your postgresql.conf
shared_preload_libraries = 'pg_stat_statements' track_counts = on #enabled by default track_functions = on #if you need it track_io_timing = on #optional
- Then connect to the database you want to track with user you will use to connect (not with postgres user!) and run:
CREATE EXTENSION pg_stat_statements
!Please note that you should run SQL above exactly inside your database and exactly by your backend user
- Restart postgre server
- Add to your composer.json
"require": { "zvook/php-postgresql-stat": "*" }
- Run
$ composer update
Demo
When package installed and postgreSQL configured you can build demo page to observe the situation. Go to the package root directory and edit demo.php with your database credentials. Then run:
php demo.php > demo.html
Open demo.html with browser
Basic Usage
!Please not that pg_stat_statements needs a time for collecting statistic to provide you adequate information
use zvook\PostgreStat; $dbName = 'my_db'; $dbUser = 'my_user'; $dbPass = 'my_pass'; $pgStat = new PgStat($dbName, $dbUser, $dbPass); # Get basic DB statistic # Returns instance of zvook\PostgreStat\Models\DbStat $pgStat->getDbStat(); # Get detailed tables statistic # Returns an array of zvook\PostgreStat\Models\TableStat instances $pgStat->getTablesStat(); # Get user functions statistic # Returns an array of zvook\PostgreStat\Models\FunctionStat instances $pgStat->getFunctionsStat(); # Get indexes statistic # Returns an array of zvook\PostgreStat\Models\IndexStat instances $pgStat->getIndexesStat(); # Get statements # Returns an array of zvook\PostgreStat\Models\StatementStat instances $pgStat->getStatementsStat(); # Get useless indexes (analytic) # Returns the same as getIndexesStat() $pgStat->getUselessIndexes(); # Get missing indexes (analytic) # Returns the same as getTablesStat() $pgStat->getLowIndexUsageTables();
Also you can find complete usage example in demo.php in the root dir of the package