PostgreSQL之 使用扩展Extension

摘要:
//Blog.csdn.net/u012736152/article/details/81874884 Postgresql的官方建议是单个表的大小超过服务器内存的大小,因此,您可以考虑分区(大致来说,根据现代服务器的物理性能,加载到数据库中的扩展功能可以像内置功能一样运行。甚至PostgreSQL复制解决方案也可以从外部开发。PG源代码中包含的扩展列表,请参阅:

   目前开发中用到的都是PostgreSQL的一些基本的功能,无意间查到PostgreSQL还支持Extension,不仅源码包中自带有Extension,还有一些其他非官方的Extension。现在不用,记录一下,以后碰到问题时希望自己能想起来,也是一个思路吧。

        pg_partman 是 PostgreSQL 的一个扩展插件,用于创建和管理基于时间或者基于序列的表分区。也支持多级子分区。

        PG-Strom 是 PostgreSQL 的一个扩展,作为 custom-scan provider。PG-Strom 的目的是利用其庞大的并行执行能力,解放 GPU 设备的一些 CPU 密集工作流。GPU 在处理器核心数量(通常是几百 - 几千)和更大的 RAM 带宽(通常比 CPU 大几倍容量)上有优势。在同时处理大规模数值操作的时候最高效。

        查了一下,甚至有些支持中文分词,和ES的功能一样了,我觉得入库速度上和查询速度上和ES应该还达不到一个数量级。

        原文:https://blog.csdn.net/u012736152/article/details/81874884

        Postgresql官方的建议是单表大小超过了服务器内存大小可以考虑分区(大概的了解了下按照现代的服务器物理性能,单表大小不超过32GB,两千万记录)。

        postgresql在9.6以前的版本就支持分区,但都是基于触发器性能并不是很好,pg10目前内置了分区但根据pg社区里的一些测试看出pg10分区性能不如pg_pathman。这里主要测试pg_pathman的range分区

        

   原文链接: https://blog.csdn.net/pg_hgdb/article/details/79490509

  

  PostgreSQL被设计为易于扩展。因此,加载到数据库中的扩展功能就可以像内置的特性一样运行。
  与源代码一起发布的contrib/ 目录包含一些扩展。扩展是独立开发的,比如PostGIS。甚至PostgreSQL复制解决方案也可以在外部开发。

  例如,Slony-I是一个受欢迎的主/备用复制解决方案,它是独立于核心项目开发的。

  PG源代码中包含的扩展列表参考:
  https://www.postgresql.org/docs/9.6/static/contrib.html

  PostgreSQL引入了一种方式来安装contrib模块,称为扩展(extensions)。
  此方法适用于所有使用扩展规范构建的contrib模块,包括如下:
  扩展SQL文件( extension_name.sql )
  扩展控制文件 ( extension_name.control )
  扩展库文件(extension_name.so)

  找到系统中的contrib模块
  检查你是否安装了contrib模块的一个好方法是查看pgbench程序是否可用。pgbench是安装了完整程序的少数contrib组件之一,而不仅仅只是你可以使用的一个脚本。以下是在UNIX系统中检查pgbench的示例:
  $ pgbench -V

  pgbench (PostgreSQL) 9.6

  在大多数Linux系统中,如果用户使用的是RPM或DEB打包版本的PostgreSQL,则可选的postgresql-contrib软件包中包含所有contrib模块及其关联的安装程序脚本。如果尚未安装,你可能需要使用yum,apt-get或类似的机制添加此软件包。在Solaris系统上,这个软件包名为SUNWpostgr-contrib。

  我们来看下面的命令,请注意必须用超级用户执行:
  CREATE EXTENSION extension_name: 此命令将安装一个名为extension_name的新扩展
  ALTER EXTENSION extension name: 此命令将更改扩展名,大多用于升级扩展。
  DROP EXTENIONS extension_name: 在清理操作完成后,此命令用于删除一个扩展。

  以上命令不能执行或执行报异常,一种可能是contrib模块没有执行编译安装,可以到contrib/目录下执行

  make&make install完成编译安装后在尝试执行以上命令。

  示例:
  cd /software/postgresql-9.5.7/contrib
  make
  make install

  testdb=# create extension pg_buffercache;
  CREATE EXTENSION

  testdb=# dx
                        List of installed extensions
        Name      | Version |   Schema   |           Description           
  ----------------+---------+------------+---------------------------------
   pg_buffercache | 1.1     | public     | examine the shared buffer cache
   pgstattuple    | 1.3     | public     | show tuple-level statistics
   plpgsql        | 1.0     | pg_catalog | PL/pgSQL procedural language

  (3 rows)

  这里新添加的扩展属于public模式,另外pg_catalog这个schema是PostgreSQL默认的元数据schema,所有的元数据都在这里。创建在pg_catalog里面的扩展优先级最高,所有用户可见。


  可以运行如下指令指定或修改扩展的所属模式:

  create extension extension_name with schema pg_catalog;
  alter extension extension_name set schema pg_catalog;  

  示例:
  testdb=# alter extension pg_buffercache set schema pg_catalog;
  ALTER EXTENSION

  testdb=# dx
                        List of installed extensions
        Name      | Version |   Schema   |           Description           
  ----------------+---------+------------+---------------------------------

   pg_buffercache | 1.1     | pg_catalog | examine the shared buffer cache
   pgstattuple    | 1.3     | public     | show tuple-level statistics
   plpgsql        | 1.0     | pg_catalog | PL/pgSQL procedural language

  testdb=# drop extension pg_buffercache ;
  DROP EXTENSION

  testdb=# dx
                     List of installed extensions
      Name     | Version |   Schema   |         Description          
  -------------+---------+------------+------------------------------
  pgstattuple | 1.3     | public     | show tuple-level statistics
  plpgsql     | 1.0     | pg_catalog | PL/pgSQL procedural language


  (2 rows)
  扩展被添加到每个登录的数据库上,如果让每个数据库都可调用扩展模块,需要再每个库上执行create extension,也可以在模板库template1 上创建后,作为新建数据库的拷贝。
  除了PostgreSQL核心自带的程序、contrib模块和pgFoundry上提供的软件之外,还可以从互联网上获取许多其他程序,以使PostgreSQL更易用和更强大。

免责声明:文章转载自《PostgreSQL之 使用扩展Extension》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇机器学习进阶-案例实战-图像全景拼接-图像全景拼接(RANSCA) 1.sift.detectAndComputer(获得sift图像关键点) 2.cv2.findHomography(计算单应性矩阵H) 3.cv2.warpPerspective(获得单应性变化后的图像) 4.cv2.line(对关键点位置进行连线画图)C++开源库详细介绍下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Ruby语法基础(二)

Ruby语法基础(二) 继续ruby的学习,这次主要把目光放到运算符,条件判断,循环,方法,以及其他ruby特有的基本概念上 运算符 算术运算符:+,-,/,%,**,值的注意的是,ruby中一切皆为对象,a+b等价于a.+(b) 比较运算符:基本与Python的一致,不等于要用!=,还有联合运算符<=>,返回-1,0,1。.eql?判断数据...

生成远程控制木马以及提权

远程控制木马以及提权 Kail攻击机IP: 192.168.199.216 Win7靶机IP:  192.168.199.132 Kali Linux 2中提供了多个可以用来产生远程控制被控端程序的方式,但是其中最为简单强大的方法应该要数Msfvenom命令了。这个命令是著名渗透测试软件Metasploit的一个功能。 以前旧版本的Metasplo...

邂逅Sass和Compass之Compass篇

本文主要讲解Compass的内容,众所周知Compass是Sass的工具库,如果对Sass不甚了解的同学可以移步 邂逅Sass和Compass之Sass篇 Sass本身只是一个“CSS预处理器”,Compass在它的基础上,封装了一系列的模块和模板,补充了Sass的功能。 1.Compass的安装 和Sass一样,Compass也是用Ruby语言开发的,所...

suricata的模块和插槽

参考资料 suricata官方文档https://suricata.readthedocs.io/en/latest/performance/runmodes.html#different-runmodes suricata的源代码https://blog.csdn.net/shenwansangz/article/details/37900875?utm...

框架模块设计经验总结

转自:http://www.cnblogs.com/zgynhqf/archive/2011/07/15/2107593.html 这是原创,尊重原创、、、、、、、、、、、、     框架模块设计经验总结      三个月没写日志了,比较懒散……下半年准备做OEA 的 B/S 版本,比较复杂,需要从架构设计开始认真入手。正好今天到了部门反思的时间,今天...

Lua的require小结

在游戏开发中会经常使用到lua作为游戏逻辑层的脚本语言,各种优势就不说了,虽然平时用的比较多,但对lua语言本身和内部的一些实现并不是很了解,让我们先从lua的require入手来一探require的各种用法吧。 require其实类似与C/C++中的#include,就是加载一个指定名称的模块进来,该模块可以来自于lua,也可能来自于C/C++,在lua...