centos 6.8 + postgresql 9.6 + adminpack

adminpack提供了一些支持函数,pgAdmin和其他管理工具会用这些函数来提供额外的功能,例如服务器日志文件的远程管理。
只有超级用户才能使用全部这些函数

mondb=#  select * 
mondb-#    from pg_available_extensions
mondb-#   where 1=1
mondb-#     and name like '%adminpack%';
   name    | default_version | installed_version |                 comment                 
-----------+-----------------+-------------------+-----------------------------------------
 adminpack | 1.0             | 1.0               | administrative functions for PostgreSQL
(1 row)


mondb=# create extension adminpack;
CREATE EXTENSION

mondb=#  select *
mondb-#    from pg_extension 
mondb-#   where 1=1
mondb-#     and extname like '%adminpack%';
  extname  | extowner | extnamespace | extrelocatable | extversion | extconfig | extcondition 
-----------+----------+--------------+----------------+------------+-----------+--------------
 adminpack |       10 |           11 | f              | 1.0        |           | 
(1 row)

mondb=# select pp.proname,
mondb-#        pp.prosrc,
mondb-#        pp.probin
mondb-# from pg_proc pp
mondb-# where 1=1
mondb-# and pp.probin like '%adminpack%'
mondb-# ;
    proname     |     prosrc     |      probin       
----------------+----------------+-------------------
 pg_file_write  | pg_file_write  | $libdir/adminpack
 pg_file_rename | pg_file_rename | $libdir/adminpack
 pg_file_unlink | pg_file_unlink | $libdir/adminpack
 pg_logdir_ls   | pg_logdir_ls   | $libdir/adminpack
(4 rows)
$ cd /usr/pgsql-9.6/share/extension/
$ ls -l |grep -i admin
-rw-r--r-- 1 root root  1535 Aug 10 10:15 adminpack--1.0.sql
-rw-r--r-- 1 root root   176 Aug 10 10:15 adminpack.control

$ more adminpack--1.0.sql
/* contrib/adminpack/adminpack--1.0.sql */

-- complain if script is sourced in psql, rather than via CREATE EXTENSION
\echo Use "CREATE EXTENSION adminpack" to load this file. \quit

/* ***********************************************
 * Administrative functions for PostgreSQL
 * *********************************************** */

/* generic file access functions */

CREATE FUNCTION pg_catalog.pg_file_write(text, text, bool)
RETURNS bigint
AS 'MODULE_PATHNAME', 'pg_file_write'
LANGUAGE C VOLATILE STRICT;

CREATE FUNCTION pg_catalog.pg_file_rename(text, text, text)
RETURNS bool
AS 'MODULE_PATHNAME', 'pg_file_rename'
LANGUAGE C VOLATILE;

CREATE FUNCTION pg_catalog.pg_file_rename(text, text)
RETURNS bool
AS 'SELECT pg_catalog.pg_file_rename($1, $2, NULL::pg_catalog.text);'
LANGUAGE SQL VOLATILE STRICT;

CREATE FUNCTION pg_catalog.pg_file_unlink(text)
RETURNS bool
AS 'MODULE_PATHNAME', 'pg_file_unlink'
LANGUAGE C VOLATILE STRICT;

CREATE FUNCTION pg_catalog.pg_logdir_ls()
RETURNS setof record
AS 'MODULE_PATHNAME', 'pg_logdir_ls'
LANGUAGE C VOLATILE STRICT;


/* Renaming of existing backend functions for pgAdmin compatibility */

CREATE FUNCTION pg_catalog.pg_file_read(text, bigint, bigint)
RETURNS text
AS 'pg_read_file'
LANGUAGE INTERNAL VOLATILE STRICT;

CREATE FUNCTION pg_catalog.pg_file_length(text)
RETURNS bigint
AS 'SELECT size FROM pg_catalog.pg_stat_file($1)'
LANGUAGE SQL VOLATILE STRICT;

CREATE FUNCTION pg_catalog.pg_logfile_rotate()
RETURNS int4
AS 'pg_rotate_logfile'
LANGUAGE INTERNAL VOLATILE STRICT;
posted @ 2017-12-20 18:59  peiybpeiyb  阅读(267)  评论(0编辑  收藏  举报