-
Notifications
You must be signed in to change notification settings - Fork 66
/
model.go
1142 lines (1033 loc) · 51.5 KB
/
model.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
/*
* Copyright 2024 RapidLoop, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package pgmetrics
// ModelSchemaVersion is the schema version of the "Model" data structure
// defined below. It is in the "semver" notation. Version history:
//
// 1.18 - Add schema name for extensions
// 1.17 - Raw log entries, Postgres 17 support
// 1.16 - Postgres 16 support
// 1.15 - Pgpool ReplicationDelaySeconds
// 1.14 - PgBouncer 1.19, Pgpool support
// 1.13 - Citus 11 support, Postgres 15
// 1.12 - Azure metrics, queryid in plan, progress views
// 1.11 - Postgres 14, PgBouncer 1.16, other attributes
// 1.10 - New fields in pg_stat_statements for Postgres 13
// 1.9 - Postgres 13, Citus support
// 1.8 - AWS RDS/EnhancedMonitoring metrics, index defn,
// backend type counts, slab memory (linux), user agent
// 1.7 - query execution plans, autovacuum, deadlocks, table acl
// 1.6 - added highest WAL segment number
// 1.5 - add PID to replication_outgoing entries
// 1.4 - pgbouncer information
// 1.3 - locks information
// 1.2 - more table and index attributes
// 1.1 - added NotificationQueueUsage and Statements
// 1.0 - initial release
const ModelSchemaVersion = "1.18"
// Model contains the entire information collected by a single run of
// pgmetrics. It can be converted to and from json without loss of
// precision.
type Model struct {
Metadata Metadata `json:"meta"` // metadata about this object
StartTime int64 `json:"start_time"` // of postmaster
SystemIdentifier string `json:"system_identifier"` // from pg_control
// Checkpoint information
CheckpointLSN string `json:"checkpoint_lsn"`
PriorLSN string `json:"prior_lsn"`
RedoLSN string `json:"redo_lsn"`
TimelineID int `json:"timeline_id"`
NextXid int `json:"next_xid"`
OldestXid int `json:"oldest_xid"`
OldestActiveXid int `json:"oldest_active_xid"`
CheckpointTime int64 `json:"checkpoint_time"`
// wal
WALFlushLSN string `json:"wal_flush_lsn"`
WALInsertLSN string `json:"wal_insert_lsn"`
WALLSN string `json:"wal_lsn"`
// Recovery
IsInRecovery bool `json:"is_in_recovery"`
IsWalReplayPaused bool `json:"is_wal_replay_paused"`
LastWALReceiveLSN string `json:"last_wal_receive_lsn"`
LastWALReplayLSN string `json:"last_wal_replay_lsn"`
LastXActReplayTimestamp int64 `json:"last_xact_replay_timestamp"`
// last committed transaction (needs track_commit_timestamp = on)
LastXactXid int `json:"last_xact_xid"`
LastXactTimestamp int64 `json:"last_xact_time"`
// wal - settings, archival stats
WALArchiving WALArchiving `json:"wal_archiving"`
WALCount int `json:"wal_count"`
WALReadyCount int `json:"wal_ready_count"`
// NotificationQueueUsage is the fraction of the asynchronous notification
// queue currently occupied. Postgres v9.6 and above only. Added in
// schema version 1.1.
NotificationQueueUsage float64 `json:"notification_queue_usage"`
// replication
ReplicationOutgoing []ReplicationOut `json:"replication_outgoing,omitempty"`
ReplicationIncoming *ReplicationIn `json:"replication_incoming,omitempty"`
ReplicationSlots []ReplicationSlot `json:"replication_slots,omitempty"`
// other cluster-level stats
BGWriter BGWriter `json:"bg_writer"`
Backends []Backend `json:"backends"`
VacuumProgress []VacuumProgressBackend `json:"vacuum_progress,omitempty"`
// structural cluster-level information
Roles []Role `json:"roles"`
Databases []Database `json:"databases,omitempty"`
Tablespaces []Tablespace `json:"tablespaces,omitempty"`
// Database-specific
Tables []Table `json:"tables,omitempty"`
Indexes []Index `json:"indexes,omitempty"`
Sequences []Sequence `json:"sequences,omitempty"`
UserFunctions []UserFunction `json:"user_functions,omitempty"`
Extensions []Extension `json:"extensions,omitempty"`
DisabledTriggers []Trigger `json:"disabled_triggers,omitempty"`
Statements []Statement `json:"statements,omitempty"`
// System-level
System *SystemMetrics `json:"system,omitempty"`
// settings
Settings map[string]Setting `json:"settings"` // all settings and their values
// following fields present only in schema 1.2 and later
// Logical replication (database-specific)
Publications []Publication `json:"publications,omitempty"`
Subscriptions []Subscription `json:"subscriptions,omitempty"`
// following fields present only in schema 1.3 and later
// Lock information
Locks []Lock `json:"locks,omitempty"`
BlockingPIDs map[int][]int `json:"blocking_pids,omitempty"`
// following fields present only in schema 1.4 and later
PgBouncer *PgBouncer `json:"pgbouncer,omitempty"`
// following fields are present only in schema 1.6 and later
// the numerically highest wal segment number
HighestWALSegment uint64 `json:"highwal,omitempty"`
// following fields are present only in schema 1.7 and later
// query execution plans
Plans []Plan `json:"plans,omitempty"`
// autovacuum information
AutoVacuums []AutoVacuum `json:"autovacuums,omitempty"`
// deadlock information
Deadlocks []Deadlock `json:"deadlocks,omitempty"`
// following fields are present only in schema 1.8 and later
// metrics from AWS RDS
RDS *RDS `json:"rds,omitempty"`
// the types of running backends and their counts
BackendTypeCounts map[string]int `json:"betypecounts,omitempty"`
// following fields are present only in schema 1.9 and later
// citus-related information, per db
Citus map[string]*Citus `json:"citus,omitempty"`
// following fields are present only in schema 1.11 and later
// WAL activity info, from pg_stat_wal, pg >= v14
WAL *WAL `json:"wal,omitempty"`
// following fields are present only in schema 1.12 and later
// metrics from Azure PostgreSQL, via Azure Monitor APIs
Azure *Azure `json:"azure,omitempty"`
// progress information from pg_stat_progress_* (see above for vacuum)
AnalyzeProgress []AnalyzeProgressBackend `json:"analyze_progress,omitempty"`
BasebackupProgress []BasebackupProgressBackend `json:"basebackup_progress,omitempty"`
ClusterProgress []ClusterProgressBackend `json:"cluster_progress,omitempty"`
CopyProgress []CopyProgressBackend `json:"copy_progress,omitempty"`
CreateIndexProgress []CreateIndexProgressBackend `json:"create_index_progress,omitempty"`
// following fields are present only in schema 1.14 and later
// metrics from Pgpool
Pgpool *Pgpool `json:"pgpool,omitempty"`
// following fields are present only in schema 1.17 and later
// raw log entries during specified time span
LogEntries []LogEntry `json:"log_entries,omitempty"`
// contents of pg_stat_checkpointer, pg >= v17
Checkpointer *Checkpointer `json:"checkpointer,omitempty"`
// a 4-tuple of client address, client port, server address, server port
// if connected via tcp, like SSH_CONNECTION
ConnectionTuple string `json:"connection_tuple,omitempty"`
// value of version()
FullVersion string `json:"full_version,omitempty"`
// value of pg_conf_load_time() as seconds since epoch
ConfLoadTime int64 `json:"conf_load_time,omitempty"`
}
// DatabaseByOID iterates over the databases in the model and returns the reference
// to a Database that has the given oid. If there is no such database, it returns nil.
func (m *Model) DatabaseByOID(oid int) *Database {
for i, d := range m.Databases {
if d.OID == oid {
return &m.Databases[i]
}
}
return nil
}
// RoleByOID iterates over the roles in the model and returns the reference
// to a Role that has the given oid. If there is no such role, it returns nil.
func (m *Model) RoleByOID(oid int) *Role {
for i, r := range m.Roles {
if r.OID == oid {
return &m.Roles[i]
}
}
return nil
}
// TableByName iterates over the tables in the model and returns the reference
// to a Table that has the given database, schema and table names. If there is
// no such table, it returns nil.
func (m *Model) TableByName(db, schema, table string) *Table {
for i, t := range m.Tables {
if t.DBName == db && t.SchemaName == schema && t.Name == table {
return &m.Tables[i]
}
}
return nil
}
// TableByOID iterates over the tables in the model and returns the reference
// to a Table that has the given oid. If there is no such table, it returns nil.
func (m *Model) TableByOID(oid int) *Table {
for i, t := range m.Tables {
if t.OID == oid {
return &m.Tables[i]
}
}
return nil
}
// IndexByName iterates over the indexes in the model and returns the reference
// to an Index that has the given database, schema and index names. If there is
// no such index, it returns nil.
func (m *Model) IndexByName(db, schema, index string) *Index {
for i, idx := range m.Indexes {
if idx.DBName == db && idx.SchemaName == schema && idx.Name == index {
return &m.Indexes[i]
}
}
return nil
}
// IndexByOID iterates over the indexes in the model and returns the reference
// to an Index that has the given oid. If there is no such index, it returns nil.
func (m *Model) IndexByOID(oid int) *Index {
for i, idx := range m.Indexes {
if idx.OID == oid {
return &m.Indexes[i]
}
}
return nil
}
// Metadata contains information about how to interpret the other fields in
// "Model" data structure.
type Metadata struct {
Version string `json:"version"` // schema version, "semver" format
At int64 `json:"at"` // time when this report was started
CollectedDBs []string `json:"collected_dbs"` // names of dbs we collected db-level stats from
Local bool `json:"local"` // was connected to a local postgres server?
UserAgent string `json:"user_agent"` // "pgmetrics/1.8.1"
Username string `json:"user"` // user that pgmetrics connected as
Mode string `json:"mode"` // one of "postgres", "pgbouncer" or "pgpool", added schema 1.14
}
type SystemMetrics struct {
CPUModel string `json:"cpu_model,omitempty"` // model of the CPU
NumCores int `json:"num_cores"` // number of cores
LoadAvg float64 `json:"loadavg"` // 1-minute load average from the OS
MemUsed int64 `json:"memused"` // used RAM, in bytes
MemFree int64 `json:"memfree"` // free RAM, in bytes
MemBuffers int64 `json:"membuffers"` // RAM used for buffers, in bytes
MemCached int64 `json:"memcached"` // RAM used for cache, in bytes
SwapUsed int64 `json:"swapused"` // used swap memory in bytes, 0 if no swap
SwapFree int64 `json:"swapfree"` // free swap memory in bytes, 0 if no swap
Hostname string `json:"hostname"` // hostname from the OS
// following fields present only in schema 1.8 and later
MemSlab int64 `json:"memslab"` // RAM used for slab in bytes
}
type Backend struct {
DBName string `json:"db_name"`
RoleName string `json:"role_name"`
ApplicationName string `json:"application_name"`
PID int `json:"pid"`
ClientAddr string `json:"client_addr"`
BackendStart int64 `json:"backend_start"`
XactStart int64 `json:"xact_start"`
QueryStart int64 `json:"query_start"`
StateChange int64 `json:"state_change"`
WaitEventType string `json:"wait_event_type"`
WaitEvent string `json:"wait_event"`
State string `json:"state"`
BackendXid int `json:"backend_xid"`
BackendXmin int `json:"backend_xmin"`
Query string `json:"query"`
// following fields present only in schema 1.11 and later
QueryID int64 `json:"query_id,omitempty"` // >= pg14
}
type ReplicationSlot struct {
SlotName string `json:"slot_name"`
Plugin string `json:"plugin"`
SlotType string `json:"slot_type"`
DBName string `json:"db_name"`
Active bool `json:"active"`
Xmin int `json:"xmin"`
CatalogXmin int `json:"catalog_xmin"`
RestartLSN string `json:"restart_lsn"`
ConfirmedFlushLSN string `json:"confirmed_flush_lsn"`
Temporary bool `json:"temporary"`
// following fields present only in schema 1.11 and later
WALStatus string `json:"wal_status,omitempty"` // >= pg13
SafeWALSize int64 `json:"safe_wal_size,omitempty"` // >= pg13
TwoPhase bool `json:"two_phase,omitempty"` // >= pg14
// following fields present only in schema 1.16 and later
Conflicting bool `json:"conflicting,omitempty"` // >= pg16
}
type Role struct {
OID int `json:"oid"`
Name string `json:"name"`
Rolsuper bool `json:"rolsuper"`
Rolinherit bool `json:"rolinherit"`
Rolcreaterole bool `json:"rolcreaterole"`
Rolcreatedb bool `json:"rolcreatedb"`
Rolcanlogin bool `json:"rolcanlogin"`
Rolreplication bool `json:"rolreplication"`
Rolbypassrls bool `json:"rolbypassrls"`
Rolconnlimit int `json:"rolconnlimit"`
Rolvaliduntil int64 `json:"rolvaliduntil"`
MemberOf []string `json:"memberof"`
}
type Tablespace struct {
OID int `json:"oid"`
Name string `json:"name"`
Owner string `json:"owner"`
Location string `json:"location"`
Size int64 `json:"size"`
DiskUsed int64 `json:"disk_used"`
DiskTotal int64 `json:"disk_total"`
InodesUsed int64 `json:"inodes_used"`
InodesTotal int64 `json:"inodes_total"`
}
type Database struct {
OID int `json:"oid"`
Name string `json:"name"`
DatDBA int `json:"datdba"`
DatTablespace int `json:"dattablespace"`
DatConnLimit int `json:"datconnlimit"`
AgeDatFrozenXid int `json:"age_datfrozenxid"`
NumBackends int `json:"numbackends"`
XactCommit int64 `json:"xact_commit"`
XactRollback int64 `json:"xact_rollback"`
BlksRead int64 `json:"blks_read"`
BlksHit int64 `json:"blks_hit"`
TupReturned int64 `json:"tup_returned"`
TupFetched int64 `json:"tup_fetched"`
TupInserted int64 `json:"tup_inserted"`
TupUpdated int64 `json:"tup_updated"`
TupDeleted int64 `json:"tup_deleted"`
Conflicts int64 `json:"conflicts"`
TempFiles int64 `json:"temp_files"`
TempBytes int64 `json:"temp_bytes"`
Deadlocks int64 `json:"deadlocks"`
BlkReadTime float64 `json:"blk_read_time"`
BlkWriteTime float64 `json:"blk_write_time"`
StatsReset int64 `json:"stats_reset"`
Size int64 `json:"size"`
// following fields present only in schema 1.11 and later
ChecksumFailures int64 `json:"checksum_failures,omitempty"` // >= pg12
ChecksumLastFailure int64 `json:"checksum_last_failure,omitempty"` // >= pg12
SessionTime float64 `json:"session_time,omitempty"` // in milliseconds, pg >= v14
ActiveTime float64 `json:"active_time,omitempty"` // in milliseconds, pg >= v14
IdleInTxTime float64 `json:"idle_in_transaction_time,omitempty"` // in milliseconds, pg >= v14
Sessions int64 `json:"sessions,omitempty"` // pg >= v14
SessionsAbandoned int64 `json:"sessions_abandoned,omitempty"` // pg >= v14
SessionsFatal int64 `json:"sessions_fatal,omitempty"` // pg >= v14
SessionsKilled int64 `json:"sessions_killed,omitempty"` // pg >= v14
}
type Table struct {
OID int `json:"oid"`
DBName string `json:"db_name"`
SchemaName string `json:"schema_name"`
Name string `json:"name"`
SeqScan int64 `json:"seq_scan"`
SeqTupRead int64 `json:"seq_tup_read"`
IdxScan int64 `json:"idx_scan"`
IdxTupFetch int64 `json:"idx_tup_fetch"`
NTupIns int64 `json:"n_tup_ins"`
NTupUpd int64 `json:"n_tup_upd"`
NTupDel int64 `json:"n_tup_del"`
NTupHotUpd int64 `json:"n_tup_hot_upd"`
NLiveTup int64 `json:"n_live_tup"`
NDeadTup int64 `json:"n_dead_tup"`
NModSinceAnalyze int64 `json:"n_mod_since_analyze"`
LastVacuum int64 `json:"last_vacuum"`
LastAutovacuum int64 `json:"last_autovacuum"`
LastAnalyze int64 `json:"last_analyze"`
LastAutoanalyze int64 `json:"last_autoanalyze"`
VacuumCount int64 `json:"vacuum_count"`
AutovacuumCount int64 `json:"autovacuum_count"`
AnalyzeCount int64 `json:"analyze_count"`
AutoanalyzeCount int64 `json:"autoanalyze_count"`
HeapBlksRead int64 `json:"heap_blks_read"`
HeapBlksHit int64 `json:"heap_blks_hit"`
IdxBlksRead int64 `json:"idx_blks_read"`
IdxBlksHit int64 `json:"idx_blks_hit"`
ToastBlksRead int64 `json:"toast_blks_read"`
ToastBlksHit int64 `json:"toast_blks_hit"`
TidxBlksRead int64 `json:"tidx_blks_read"`
TidxBlksHit int64 `json:"tidx_blks_hit"`
Size int64 `json:"size"`
Bloat int64 `json:"bloat"`
// following fields present only in schema 1.2 and later
RelKind string `json:"relkind"`
RelPersistence string `json:"relpersistence"`
RelNAtts int `json:"relnatts"`
AgeRelFrozenXid int `json:"age_relfrozenxid"`
RelIsPartition bool `json:"relispartition"`
TablespaceName string `json:"tablespace_name"`
ParentName string `json:"parent_name"`
PartitionCV string `json:"partition_cv"` // partition constraint value
// following fields present only in schema 1.7 and later
ACL string `json:"acl,omitempty"`
// following fields present only in schema 1.11 and later
NInsSinceVacuum int64 `json:"n_ins_since_vacuum,omitempty"` // pg >= v13
// following fields present only in schema 1.16 and later
LastSeqScan int64 `json:"last_seq_scan,omitempty"` // pg >= v16
LastIdxScan int64 `json:"last_idx_scan,omitempty"` // pg >= v16
NTupNewpageUpd int64 `json:"n_tup_newpage_upd,omitempty"` // pg >= v16
}
type Index struct {
OID int `json:"oid"`
DBName string `json:"db_name"`
SchemaName string `json:"schema_name"`
TableOID int `json:"table_oid"`
TableName string `json:"table_name"`
Name string `json:"name"`
IdxScan int64 `json:"idx_scan"`
IdxTupRead int64 `json:"idx_tup_read"`
IdxTupFetch int64 `json:"idx_tup_fetch"`
IdxBlksRead int64 `json:"idx_blks_read"`
IdxBlksHit int64 `json:"idx_blks_hit"`
Size int64 `json:"size"`
Bloat int64 `json:"bloat"`
// following fields present only in schema 1.2 and later
RelNAtts int `json:"relnatts"`
AMName string `json:"amname"`
TablespaceName string `json:"tablespace_name"`
// following fields present only in schema 1.8 and later
Definition string `json:"def"`
// following fields present only in schema 1.16 and later
LastIdxScan int64 `json:"last_idx_scan,omitempty"` // pg >= v16
}
type Sequence struct {
OID int `json:"oid"`
DBName string `json:"db_name"`
SchemaName string `json:"schema_name"`
Name string `json:"name"`
BlksRead int64 `json:"blks_read"`
BlksHit int64 `json:"blks_hit"`
}
type UserFunction struct {
OID int `json:"oid"`
SchemaName string `json:"schema_name"`
DBName string `json:"db_name"`
Name string `json:"name"`
Calls int64 `json:"calls"`
TotalTime float64 `json:"total_time"`
SelfTime float64 `json:"self_time"`
}
// VacuumProgressBackend holds the contents of a row from pg_stat_progress_vacuum.
// In Postgres 17, max_dead_tuples was renamed max_dead_tuple_bytes and
// num_dead_tuples was renamed dead_tuple_bytes. The old names are still used
// in this struct, but will be filled in with values from the new columns in
// pg17.
type VacuumProgressBackend struct {
DBName string `json:"db_name"`
TableOID int `json:"table_oid"`
TableName string `json:"table_name"`
Phase string `json:"phase"`
HeapBlksTotal int64 `json:"heap_blks_total"`
HeapBlksScanned int64 `json:"heap_blks_scanned"`
HeapBlksVacuumed int64 `json:"heap_blks_vacuumed"`
IndexVacuumCount int64 `json:"index_vacuum_count"`
MaxDeadTuples int64 `json:"max_dead_tuples"` // pg <= v16
NumDeadTuples int64 `json:"num_dead_tuples"` // pg <= v16
// following fields present only in schema 1.12 and later
PID int `json:"pid,omitempty"`
// following fields present only in schema 1.17 and later
MaxDeadTupleBytes int64 `json:"max_dead_tuple_bytes"` // pg >= v17
DeadTupleBytes int64 `json:"dead_tuple_bytess"` // pg >= v17
NumDeadItemIDs int64 `json:"num_dead_item_ids,omitempty"` // pg >= v17
IndexesTotal int64 `json:"indexes_total,omitempty"` // pg >= v17
IndexesProcessed int64 `json:"indexes_processed,omitempty"` // pg >= v17
}
type Extension struct {
Name string `json:"name"`
DBName string `json:"db_name"`
DefaultVersion string `json:"default_version"`
InstalledVersion string `json:"installed_version"`
Comment string `json:"comment"`
// following fields present only in schema 1.18 and later
SchemaName string `json:"schema_name"`
}
type Setting struct {
Setting string `json:"setting"`
BootVal string `json:"bootval,omitempty"`
Source string `json:"source,omitempty"`
// following fields present only in schema 1.11 and later
Pending bool `json:"pending,omitempty"`
}
type WALArchiving struct {
ArchivedCount int `json:"archived_count"`
LastArchivedWAL string `json:"last_archived_wal"`
LastArchivedTime int64 `json:"last_archived_time"`
FailedCount int `json:"failed_count"`
LastFailedWAL string `json:"last_failed_wal"`
LastFailedTime int64 `json:"last_failed_time"`
StatsReset int64 `json:"stats_reset"`
}
// BGWriter holds the contents of a row from pg_stat_bgwriter. In Postgres 17,
// some columns were removed, and some where moved to the new
// pg_stat_checkpointer view.
type BGWriter struct {
CheckpointsTimed int64 `json:"checkpoints_timed,omitempty"` // <=pg16
CheckpointsRequested int64 `json:"checkpoints_req,omitempty"` // <=pg16
CheckpointWriteTime float64 `json:"checkpoint_write_time,omitempty"` // <=pg16
CheckpointSyncTime float64 `json:"checkpoint_sync_time,omitempty"` // <=pg16
BuffersCheckpoint int64 `json:"buffers_checkpoint,omitempty"` // <=pg16
BuffersClean int64 `json:"buffers_clean"`
MaxWrittenClean int64 `json:"maxwritten_clean"`
BuffersBackend int64 `json:"buffers_backend,omitempty"` // <=pg16
BuffersBackendFsync int64 `json:"buffers_backend_fsync,omitempty"` // <=pg16
BuffersAlloc int64 `json:"buffers_alloc"`
StatsReset int64 `json:"stats_reset"`
}
type ReplicationOut struct {
RoleName string `json:"role_name"`
ApplicationName string `json:"application_name"`
ClientAddr string `json:"client_addr"`
BackendStart int64 `json:"backend_start"`
BackendXmin int `json:"backend_xmin"`
State string `json:"state"`
SentLSN string `json:"sent_lsn"`
WriteLSN string `json:"write_lsn"`
FlushLSN string `json:"flush_lsn"`
ReplayLSN string `json:"replay_lsn"`
WriteLag int `json:"write_lag"` // only in 10.x
FlushLag int `json:"flush_lag"` // only in 10.x
ReplayLag int `json:"replay_lag"` // only in 10.x
SyncPriority int `json:"sync_priority"`
SyncState string `json:"sync_state"`
// following fields present only in schema 1.5 and later
PID int `json:"pid,omitempty"`
// following fields present only in schema 1.11 and later
ReplyTime int64 `json:"reply_time,omitempty"` // >= pg12
}
type ReplicationIn struct {
Status string `json:"status"`
ReceiveStartLSN string `json:"receive_start_lsn"`
ReceiveStartTLI int `json:"receive_start_tli"`
ReceivedLSN string `json:"received_lsn"` // empty in 13.x+
ReceivedTLI int `json:"received_tli"`
LastMsgSendTime int64 `json:"last_msg_send_time"`
LastMsgReceiptTime int64 `json:"last_msg_receipt_time"`
Latency int64 `json:"latency_micros"`
LatestEndLSN string `json:"latest_end_lsn"`
LatestEndTime int64 `json:"latest_end_time"`
SlotName string `json:"slot_name"`
Conninfo string `json:"conninfo"`
// following fields present only in schema 1.9 and later (13.x+)
WrittenLSN string `json:"written_lsn,omitempty"`
FlushedLSN string `json:"flushed_lsn,omitempty"`
// following fields present only in schema 1.11 and later
SenderHost string `json:"sender_host,omitempty"` // >= pg11
}
type Trigger struct {
OID int `json:"oid"`
DBName string `json:"db_name"`
SchemaName string `json:"schema_name"`
TableName string `json:"table_name"`
Name string `json:"name"`
ProcName string `json:"proc_name"`
}
// Statement represents a row of the pg_stat_statements view. Added in schema
// version 1.1.
type Statement struct {
UserOID int `json:"useroid"` // OID of user who executed the statement
UserName string `json:"user"` // Name of the user corresponding to useroid (might be empty)
DBOID int `json:"db_oid"` // OID of database in which the statement was executed
DBName string `json:"db_name"` // Name of the database corresponding to db_oid
QueryID int64 `json:"queryid"` // Internal hash code, computed from the statement's parse tree
Query string `json:"query"` // Text of a representative statement
Calls int64 `json:"calls"` // Number of times executed
TotalTime float64 `json:"total_time"` // == total_exec_time in pg >= v13
MinTime float64 `json:"min_time"` // == min_exec_time in pg >= v13
MaxTime float64 `json:"max_time"` // == man_exec_time in pg >= v13
StddevTime float64 `json:"stddev_time"` // == stddev_exec_time in pg >= v13
Rows int64 `json:"rows"` // Total number of rows retrieved or affected by the statement
SharedBlksHit int64 `json:"shared_blks_hit"` // Total number of shared block cache hits by the statement
SharedBlksRead int64 `json:"shared_blks_read"` // Total number of shared blocks read by the statement
SharedBlksDirtied int64 `json:"shared_blks_dirtied"` // Total number of shared blocks dirtied by the statement
SharedBlksWritten int64 `json:"shared_blks_written"` // Total number of shared blocks written by the statement
LocalBlksHit int64 `json:"local_blks_hit"` // Total number of local block cache hits by the statement
LocalBlksRead int64 `json:"local_blks_read"` // Total number of local blocks read by the statement
LocalBlksDirtied int64 `json:"local_blks_dirtied"` // Total number of local blocks dirtied by the statement
LocalBlksWritten int64 `json:"local_blks_written"` // Total number of local blocks written by the statement
TempBlksRead int64 `json:"temp_blks_read"` // Total number of temp blocks read by the statement
TempBlksWritten int64 `json:"temp_blks_written"` // Total number of temp blocks written by the statement
BlkReadTime float64 `json:"blk_read_time"` // == shared_blk_read_time in pg >= v17
BlkWriteTime float64 `json:"blk_write_time"` // == shared_blk_write_time in pg >= v17
// following fields present only in schema 1.10 and later (for Postgres v13+)
Plans int64 `json:"plans"` // Number of times the statement was planned
TotalPlanTime float64 `json:"total_plan_time"` // Total time spent planning the statement, in milliseconds
MinPlanTime float64 `json:"min_plan_time"` // Minimum time spent planning the statement, in milliseconds
MaxPlanTime float64 `json:"max_plan_time"` // Maximum time spent planning the statement, in milliseconds
StddevPlanTime float64 `json:"stddev_plan_time"` // Population standard deviation of time spent planning the statement, in milliseconds
WALRecords int64 `json:"wal_records"` // Total number of WAL records generated by the statement
WALFPI int64 `json:"wal_fpi"` // Total number of WAL full page images generated by the statement
WALBytes int64 `json:"wal_bytes"` // Total amount of WAL bytes generated by the statement
// following fields present only in schema 1.17 and later
TopLevel bool `json:"toplevel,omitempty"` // pg >= v14
TempBlkReadTime float64 `json:"temp_blk_read_time,omitempty"` // pg >= v15
TempBlkWriteTime float64 `json:"temp_blk_write_time,omitempty"` // pg >= v15
JITFuntions int64 `json:"jit_functions,omitempty"` // pg >= v15
JITGenerationTime float64 `json:"jit_generation_time,omitempty"` // pg >= v15
JITInliningCount int64 `json:"jit_inlining_count,omitempty"` // pg >= v15
JITInliningTime float64 `json:"jit_inlining_time,omitempty"` // pg >= v15
JITOptimizationCount int64 `json:"jit_optimization_count,omitempty"` // pg >= v15
JITOptimizationTime float64 `json:"jit_optimization_time,omitempty"` // pg >= v15
JITEmissionCount int64 `json:"jit_emission_count,omitempty"` // pg >= v15
JITEmissionTime float64 `json:"jit_emission_time,omitempty"` // pg >= v15
LocalBlkReadTime float64 `json:"local_blk_read_time,omitempty"` // pg >= v17
LocalBlkWriteTime float64 `json:"local_blk_write_time,omitempty"` // pg >= v17
JITDeformCount int64 `json:"jit_deform_count,omitempty"` // pg >= v17
JITDeformTime float64 `json:"jit_deform_time,omitempty"` // pg >= v17
StatsSince int64 `json:"stats_since,omitempty"` // pg >= v17
MinMaxStatsSince int64 `json:"minmax_stats_since,omitempty"` // pg >= v17
}
// Publication represents a single v10+ publication. Added in schema 1.2.
type Publication struct {
OID int `json:"oid"`
Name string `json:"name"`
DBName string `json:"db_name"`
AllTables bool `json:"alltables"`
Insert bool `json:"insert"`
Update bool `json:"update"`
Delete bool `json:"delete"`
TableCount int `json:"table_count"`
}
// Subscription represents a single v10+ subscription. Added in schema 1.2.
type Subscription struct {
OID int `json:"oid"`
Name string `json:"name"`
DBName string `json:"db_name"`
Enabled bool `json:"enabled"`
PubCount int `json:"pub_count"`
TableCount int `json:"table_count"`
WorkerCount int `json:"worker_count"`
ReceivedLSN string `json:"received_lsn"`
LatestEndLSN string `json:"latest_end_lsn"`
LastMsgSendTime int64 `json:"last_msg_send_time"`
LastMsgReceiptTime int64 `json:"last_msg_receipt_time"`
LatestEndTime int64 `json:"latest_end_time"`
Latency int64 `json:"latency_micros"`
// following fields present only in schema 1.13 and later
ApplyErrorCount int `json:"apply_error_count,omitempty"` // >= pg15
SyncErrorCount int `json:"sync_error_count,omitempty"` // >= pg15
}
// Lock represents a single row from pg_locks. Added in schema 1.3.
type Lock struct {
LockType string `json:"locktype"`
DBName string `json:"db_name,omitempty"`
PID int `json:"pid"`
Mode string `json:"mode"`
Granted bool `json:"granted"`
RelationOID int `json:"relation_oid,omitempty"`
// following fields present only in schema 1.11 and later
WaitStart int64 `json:"waitstart,omitempty"` // >= pg14
}
// PgBouncer contains information collected from the virtual "pgbouncer"
// database. Added in schema 1.4.
type PgBouncer struct {
Pools []PgBouncerPool `json:"pools,omitempty"`
Stats []PgBouncerStat `json:"stats,omitempty"`
Databases []PgBouncerDatabase `json:"dbs,omitempty"`
SCActive int `json:"sc_active"` // no. of active server conns
SCIdle int `json:"sc_idle"` // no. of idle server conns
SCUsed int `json:"sc_used"` // no. of used server conns
SCMaxWait float64 `json:"sc_maxwait"` // max wait time for server conns
CCActive int `json:"cc_active"` // no. of active client conns
CCWaiting int `json:"cc_waiting"` // no. of waiting client conns
CCIdle int `json:"cc_idle"` // no. of idle client conns
CCUsed int `json:"cc_used"` // no. of used client conns
CCMaxWait float64 `json:"cc_maxwait"` // max wait time for *waiting* client conns
CCAvgWait float64 `json:"cc_avgwait"` // avg wait time for *waiting* client conns
}
// PgBouncerPool contains information about one pool of PgBouncer (one row
// from SHOW POOLS).
type PgBouncerPool struct {
Database string `json:"db_name"`
UserName string `json:"user"`
ClActive int `json:"cl_active"`
ClWaiting int `json:"cl_waiting"`
SvActive int `json:"sv_active"`
SvIdle int `json:"sv_idle"`
SvUsed int `json:"sv_used"`
SvTested int `json:"sv_tested"`
SvLogin int `json:"sv_login"`
MaxWait float64 `json:"maxwait"` // seconds
Mode string `json:"pool_mode"`
// following fields present only in schema 1.11 and later
ClCancelReq int `json:"cl_cancel_req,omitempty"` // only in pgbouncer v1.16 & v1.17
// following fields present only in schema 1.14 and later
ClActiveCancelReq int `json:"cl_active_cancel_req,omitempty"` // only in pgbouncer >= v1.18
ClWaitingCancelReq int `json:"cl_waiting_cancel_req,omitempty"` // only in pgbouncer >= v1.18
SvActiveCancel int `json:"sv_active_cancel,omitempty"` // only in pgbouncer >= v1.18
SvBeingCanceled int `json:"sv_being_canceled,omitempty"` // only in pgbouncer >= v1.18
}
// PgBouncerDatabase contains information about one database of PgBouncer
// (one row from SHOW DATABASES).
type PgBouncerDatabase struct {
Database string `json:"db_name"`
Host string `json:"host"`
Port int `json:"port"`
SourceDatabase string `json:"srcdb_name"`
User string `json:"force_user"`
MaxConn int `json:"max_connections"`
CurrConn int `json:"current_connections"`
Paused bool `json:"paused"`
Disabled bool `json:"disabled"`
}
// PgBouncerStat contains one row from SHOW STATS. Times are in seconds,
// averages are for the last second (as per PgBouncer docs).
type PgBouncerStat struct {
Database string `json:"db_name"`
TotalXactCount int64 `json:"total_xact_count"`
TotalQueryCount int64 `json:"total_query_count"`
TotalReceived int64 `json:"total_received"` // bytes
TotalSent int64 `json:"total_sent"` // bytes
TotalXactTime float64 `json:"total_xact_time"` // seconds
TotalQueryTime float64 `json:"total_query_time"` // seconds
TotalWaitTime float64 `json:"total_wait_time"` // seconds
AvgXactCount int64 `json:"avg_xact_count"`
AvgQueryCount int64 `json:"avg_query_count"`
AvgReceived int64 `json:"avg_received"` // bytes
AvgSent int64 `json:"avg_sent"` // bytes
AvgXactTime float64 `json:"avg_xact_time"` // seconds
AvgQueryTime float64 `json:"avg_query_time"` // seconds
AvgWaitTime float64 `json:"avg_wait_time"` // seconds
// following fields present only in schema 1.17 and later
TotalServerAssignmentCount int64 `json:"total_server_assignment_count,omitempty"` // only in pgbouncer >= v1.23
AvgServerAssignmentCount int64 `json:"avg_server_assignment_count,omitempty"` // only in pgbouncer >= v1.23
}
// Plan represents a query execution plan. Added in schema 1.7.
type Plan struct {
Database string `json:"db_name"` // might be empty
UserName string `json:"user"` // might be empty
Format string `json:"format"` // text, json, yaml or xml
At int64 `json:"at"` // time when plan was logged, as seconds since epoch
Query string `json:"query"` // the sql query
Plan string `json:"plan"` // the plan as a string
// following fields present only in schema 1.12 and later
QueryID int64 `json:"queryid,omitempty"` // query id
}
// AutoVacuum contains information about a single autovacuum run.
// Added in schema 1.7.
type AutoVacuum struct {
At int64 `json:"at"` // time when activity was logged, as seconds since epoch
Table string `json:"table_name"` // fully qualified, db.schema.table
Elapsed float64 `json:"elapsed"` // in seconds
}
// Deadlock contains information about a single deadlock detection log.
// Added in schema 1.7.
type Deadlock struct {
At int64 `json:"at"` // time when activity was logged, as seconds since epoch
Detail string `json:"detail"` // information about the deadlocking processes
}
// RDS contains metrics collected from AWS RDS (also includes Aurora).
// Added in schema 1.8.
type RDS struct {
Basic map[string]float64 `json:"basic"` // Basic Monitoring Metrics
Enhanced map[string]interface{} `json:"enhanced,omitempty"` // Enhanced Monitoring
}
// Citus contains metrics collected from Citus extension.
// Added in schema 1.9.
type Citus struct {
Version string `json:"version"`
Nodes []CitusNode `json:"nodes"`
Statements []CitusStatement `json:"statements"`
Backends []CitusBackend `json:"dist_activity,omitempty"` // citus <=10.x
WorkerBackends []CitusBackend `json:"worker_activity,omitempty"` // citus <=10.x
Locks []CitusLock `json:"locks"`
// following fields present only in schema 1.13 and later
AllBackends []CitusBackendV11 `json:"activity,omitempty"` // citus >=11.x
Tables []CitusTable `json:"tables,omitempty"` // citus >=11.x
CoordinatorNodeID int `json:"coordinator_nodeid,omitempty"` // citus >=11.x
ConnectedNodeID int `json:"connected_nodeid,omitempty"` // citus >=11.x, the node pgmetrics connected to
}
// CitusNode represents a row from the pg_dist_node table. Added in schema 1.9.
type CitusNode struct {
ID int `json:"nodeid"`
GroupID int `json:"groupid"`
Name string `json:"nodename"`
Port int `json:"nodeport"`
Rack string `json:"noderack"`
IsActive bool `json:"isactive"`
Role string `json:"noderole"`
Cluster string `json:"nodecluster"`
ShouldHaveShards bool `json:"shouldhaveshards"`
}
// CitusStatement represents a row in citus_stat_statements. Added in schema 1.9.
type CitusStatement struct {
QueryID int64 `json:"queryid"` // same as pg_stat_statements.queryid
UserOID int `json:"useroid"` // user who ran the query
DBOID int `json:"db_oid"` // database instance of coordinator
Query string `json:"query"` // anonymized query string
Executor string `json:"executor"` // Citus executor used: adaptive, real-time, task-tracker, router, or insert-select
PartitionKey string `json:"partition_key"` // value of distribution column in router-executed queries, else NULL
Calls int64 `json:"calls"` // number of times the query was run
}
// CitusBackend represents a row from citus_dist_stat_activity or from
// citus_worker_stat_activity; in Citus <=10.x. Added in schema 1.9.
type CitusBackend struct {
Backend // also include all fields from pg_stat_activity
QueryHostname string `json:"query_hostname"`
QueryPort int `json:"query_port"`
MasterQueryHostname string `json:"master_query_hostname"`
MasterQueryPort int `json:"master_query_port"`
TxNumber int64 `json:"transaction_number"`
TxStamp int64 `json:"transaction_stamp"`
}
// CitusBackendV11 represents a row from citus_stat_activity in Citus >=11.x.
// Added in schema 1.13.
type CitusBackendV11 struct {
Backend // also include all fields from pg_stat_activity
GlobalPID int64 `json:"global_pid"`
NodeID int `json:"node_id"`
IsWorkerQuery bool `json:"is_worker_query"`
BackendType string `json:"backend_type"`
}
// CitusLock represents a single row from citus_lock_waits. Added in schema 1.9.
type CitusLock struct {
WaitingPID int `json:"waiting_pid,omitempty"` // citus <=10.x, 0 otherwise
BlockingPID int `json:"blocking_pid,omitempty"` // citus <=10.x, 0 otherwise
BlockedStmt string `json:"blocked_statement"`
CurrStmt string `json:"current_statement_in_blocking_process"`
WaitingNodeID int `json:"waiting_node_id"`
BlockingNodeID int `json:"blocking_node_id"`
WaitingNodeName string `json:"waiting_node_name,omitempty"` // citus <=10.x, '' otherwise
BlockingNodeName string `json:"blocking_node_name,omitempty"` // citus <=10.x, '' otherwise
WaitingNodePort int `json:"waiting_node_port,omitempty"` // citus <=10.x, 0 otherwise
BlockingNodePort int `json:"blocking_node_port,omitempty"` // citus <=10.x, 0 otherwise
// following fields present only in schema 1.13 and later
WaitingGPID int64 `json:"waiting_gpid,omitempty"` // citus >=11.x
BlockingGPID int64 `json:"blocking_gpid,omitempty"` // citus >=11.x
}
// CitusTable represents an equivalent of a single row from citus_tables.
// Added in schema 1.13.
type CitusTable struct {
OID int `json:"oid"`
TableName string `json:"table_name"`
TableType string `json:"citus_table_type"`
DistributionColumn string `json:"distribution_column"`
ColocationID int `json:"colocation_id"`
Size int64 `json:"table_size"`
ShardCount int `json:"shard_count"`
TableOwner string `json:"table_owner"`
AccessMethod string `json:"access_method"`
}
// WAL represents a single row from pg_stat_wal. Added in schema 1.11.
// pg_stat_wal is available only in pg >= v14.
type WAL struct {
Records int64 `json:"records"`
FPI int64 `json:"fpi"`
Bytes int64 `json:"bytes"`
BuffersFull int64 `json:"buffers_full"`
Write int64 `json:"write"`
Sync int64 `json:"sync"`
WriteTime float64 `json:"write_time"` // in milliseconds
SyncTime float64 `json:"sync_time"` // in milliseconds
StatsReset int64 `json:"stats_reset"`
}
// Azure represents metrics and information collected from Azure PostgreSQL
// via Azure Monitor APIs. Added in schema 1.12.
type Azure struct {
ResourceName string `json:"resource_name"`
ResourceType string `json:"resource_type"`
ResourceRegion string `json:"resource_region"`
Metrics map[string]float64 `json:"metrics"`
}
// AnalyzeProgressBackend represents a row (and each row represents one
// backend) from pg_stat_progress_analyze.
//
// pg >= 13, schema >= 1.12, pgmetrics >= 1.13.0
type AnalyzeProgressBackend struct {
PID int `json:"pid"`
DBName string `json:"db_name"`
TableOID int `json:"table_oid"`
Phase string `json:"phase"`
SampleBlocksTotal int64 `json:"sample_blks_total"`
SampleBlocksScanned int64 `json:"sample_blks_scanned"`
ExtStatsTotal int64 `json:"ext_stats_total"`
ExtStatsComputed int64 `json:"ext_stats_computed"`
ChildTablesTotal int64 `json:"child_tables_total"`
ChildTablesDone int64 `json:"child_tables_done"`
CurrentChildTableRelOID int `json:"child_oid"`
}
// BasebackupProgressBackend represents a row (and each row represents one
// backend) from pg_stat_progress_basebackup.
//
// pg >= 13, schema >= 1.12, pgmetrics >= 1.13.0
type BasebackupProgressBackend struct {
PID int `json:"pid"`
Phase string `json:"phase"`
BackupTotal int64 `json:"backup_total"`
BackupStreamed int64 `json:"backup_streamed"`
TablespacesTotal int64 `json:"tablespaces_total"`
TablespacesStreamed int64 `json:"tablespaces_streamed"`
}
// ClusterProgressBackend represents a row (and each row represents one
// backend) from pg_stat_progress_cluster.
//
// pg >= 12, schema >= 1.12, pgmetrics >= 1.13.0
type ClusterProgressBackend struct {
PID int `json:"pid"`
DBName string `json:"db_name"`
TableOID int `json:"table_oid"`
Command string `json:"command"`
Phase string `json:"phase"`
ClusterIndexOID int `json:"cluser_index_oid"`
HeapTuplesScanned int64 `json:"heap_tuples_scanned"`
HeapTuplesWritten int64 `json:"heap_tuples_written"`
HeapBlksTotal int64 `json:"heap_blks_total"`
HeapBlksScanned int64 `json:"heap_blks_scanned"`