• 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;
  • 相关阅读:
    office 所有后缀对应的 content-type
    Vue 拖拽组件 vuedraggable 和 vue-dragging
    vue实现word,pdf文件的导出功能
    vue浏览器全屏实现
    对于js中事件冒泡的理解分析
    一个服务端的登录拦截
    ES6兼容ie9, flex兼容ie9
    webpack报错
    vue项目的一个package.json
    vue项目的构建过程
  • 原文地址:https://www.cnblogs.com/ctypyb2002/p/9793083.html
Copyright © 2020-2023  润新知