mirror of
				https://github.com/postgres/postgres.git
				synced 2025-11-03 09:13:20 +03:00 
			
		
		
		
	It was pointed out that pg_buffercache_summary()'s report of the overall average usage count isn't that useful, and what would be more helpful in many cases is to report totals for each possible usage count. Add a new function to do it like that. Since pg_buffercache 1.4 is already new for v16, we don't need to create a new extension version; we'll just define this as part of 1.4. Nathan Bossart Discussion: https://postgr.es/m/20230130233040.GA2800702@nathanxps13
		
			
				
	
	
		
			58 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
CREATE EXTENSION pg_buffercache;
 | 
						|
select count(*) = (select setting::bigint
 | 
						|
                   from pg_settings
 | 
						|
                   where name = 'shared_buffers')
 | 
						|
from pg_buffercache;
 | 
						|
 ?column? 
 | 
						|
----------
 | 
						|
 t
 | 
						|
(1 row)
 | 
						|
 | 
						|
select buffers_used + buffers_unused > 0,
 | 
						|
        buffers_dirty <= buffers_used,
 | 
						|
        buffers_pinned <= buffers_used
 | 
						|
from pg_buffercache_summary();
 | 
						|
 ?column? | ?column? | ?column? 
 | 
						|
----------+----------+----------
 | 
						|
 t        | t        | t
 | 
						|
(1 row)
 | 
						|
 | 
						|
SELECT count(*) > 0 FROM pg_buffercache_usage_counts() WHERE buffers >= 0;
 | 
						|
 ?column? 
 | 
						|
----------
 | 
						|
 t
 | 
						|
(1 row)
 | 
						|
 | 
						|
-- Check that the functions / views can't be accessed by default. To avoid
 | 
						|
-- having to create a dedicated user, use the pg_database_owner pseudo-role.
 | 
						|
SET ROLE pg_database_owner;
 | 
						|
SELECT * FROM pg_buffercache;
 | 
						|
ERROR:  permission denied for view pg_buffercache
 | 
						|
SELECT * FROM pg_buffercache_pages() AS p (wrong int);
 | 
						|
ERROR:  permission denied for function pg_buffercache_pages
 | 
						|
SELECT * FROM pg_buffercache_summary();
 | 
						|
ERROR:  permission denied for function pg_buffercache_summary
 | 
						|
SELECT * FROM pg_buffercache_usage_counts();
 | 
						|
ERROR:  permission denied for function pg_buffercache_usage_counts
 | 
						|
RESET role;
 | 
						|
-- Check that pg_monitor is allowed to query view / function
 | 
						|
SET ROLE pg_monitor;
 | 
						|
SELECT count(*) > 0 FROM pg_buffercache;
 | 
						|
 ?column? 
 | 
						|
----------
 | 
						|
 t
 | 
						|
(1 row)
 | 
						|
 | 
						|
SELECT buffers_used + buffers_unused > 0 FROM pg_buffercache_summary();
 | 
						|
 ?column? 
 | 
						|
----------
 | 
						|
 t
 | 
						|
(1 row)
 | 
						|
 | 
						|
SELECT count(*) > 0 FROM pg_buffercache_usage_counts();
 | 
						|
 ?column? 
 | 
						|
----------
 | 
						|
 t
 | 
						|
(1 row)
 | 
						|
 |