PostgreSQL学习(1)-- 安装pageinspect extension
1.源码编译
pageinspect的源码在postgre源码包的contrib目录下,解压postgre源码包后进入对应的目录。
[root@localhost pageinspect]# pwd
/root/postgresql-11beta2/contrib/pageinspect
[root@localhost pageinspect]# ll
total
-rwxr-xr-x Jun : brinfuncs.c
-rwxr-xr-x Jun : btreefuncs.c
drwxr-xr-x Jun : expected
-rwxr-xr-x Jun : fsmfuncs.c
-rwxr-xr-x Jun : ginfuncs.c
-rwxr-xr-x Jun : hashfuncs.c
-rwxr-xr-x Jun : heapfuncs.c
-rwxr-xr-x Jun : Makefile
-rwxr-xr-x Jun : pageinspect--1.0--1.1.sql
-rwxr-xr-x Jun : pageinspect--1.1--1.2.sql
-rwxr-xr-x Jun : pageinspect--1.2--1.3.sql
-rwxr-xr-x Jun : pageinspect--1.3--1.4.sql
-rwxr-xr-x Jun : pageinspect--1.4--1.5.sql
-rwxr-xr-x Jun : pageinspect--1.5--1.6.sql
-rwxr-xr-x Jun : pageinspect--1.5.sql
-rwxr-xr-x Jun : pageinspect--1.6--1.7.sql
-rwxr-xr-x Jun : pageinspect.control
-rwxr-xr-x Jun : pageinspect.h
-rwxr-xr-x Jun : pageinspect--unpackaged--1.0.sql
-rwxr-xr-x Jun : rawpage.c
drwxr-xr-x Jun : sql
有makefile文件,直接用make命令进行编译即可。编译后,只要得到pageinspect.so这个文件。
[root@localhost pageinspect]# ll
total
-rwxr-xr-x Jun : brinfuncs.c
-rw-r--r-- root root Jul : brinfuncs.o
-rwxr-xr-x Jun : btreefuncs.c
-rw-r--r-- root root Jul : btreefuncs.o
drwxr-xr-x Jun : expected
-rwxr-xr-x Jun : fsmfuncs.c
-rw-r--r-- root root Jul : fsmfuncs.o
-rwxr-xr-x Jun : ginfuncs.c
-rw-r--r-- root root Jul : ginfuncs.o
-rwxr-xr-x Jun : hashfuncs.c
-rw-r--r-- root root Jul : hashfuncs.o
-rwxr-xr-x Jun : heapfuncs.c
-rw-r--r-- root root Jul : heapfuncs.o
-rwxr-xr-x Jun : Makefile
-rwxr-xr-x Jun : pageinspect--1.0--1.1.sql
-rwxr-xr-x Jun : pageinspect--1.1--1.2.sql
-rwxr-xr-x Jun : pageinspect--1.2--1.3.sql
-rwxr-xr-x Jun : pageinspect--1.3--1.4.sql
-rwxr-xr-x Jun : pageinspect--1.4--1.5.sql
-rwxr-xr-x Jun : pageinspect--1.5--1.6.sql
-rwxr-xr-x Jun : pageinspect--1.5.sql
-rwxr-xr-x Jun : pageinspect--1.6--1.7.sql
-rwxr-xr-x Jun : pageinspect.control
-rwxr-xr-x Jun : pageinspect.h
-rwxr-xr-x root root Jul : pageinspect.so
-rwxr-xr-x Jun : pageinspect--unpackaged--1.0.sql
-rwxr-xr-x Jun : rawpage.c
-rw-r--r-- root root Jul : rawpage.o
drwxr-xr-x Jun : sql
然后使用make install命令,把相关文件安装到/usr/localpgsql的目录下。
[root@localhost pageinspect]# make install
/bin/mkdir -p '/usr/local/pgsql/lib'
/bin/mkdir -p '/usr/local/pgsql/share/extension'
/bin/mkdir -p '/usr/local/pgsql/share/extension'
/usr/bin/install -c -m pageinspect.so '/usr/local/pgsql/lib/pageinspect.so'
/usr/bin/install -c -m ./pageinspect.control '/usr/local/pgsql/share/extension/'
/usr/bin/install -c -m ./pageinspect--1.6--1.7.sql ./pageinspect--1.5.sql ./pageinspect--1.5--1.6.sql ./pageinspect--1.4--1.5.sql ./pageinspect--1.3--1.4.sql ./pageinspect--1.2--1.3.sql ./pageinspect--1.1--1.2.sql ./pageinspect--1.0--1.1.sql ./pageinspect--unpackaged--1.0.sql '/usr/local/pgsql/share/extension/'
2.创建pageinspect extension
准备工作完成,然后切换到postgre的用户,进入psql,创建pageinspect extension。
[pguser@localhost log]$ su pguser
Password:
[pguser@localhost log]$ psql -d test
psql (11beta2)
Type "help" for help. test=# \d pg_extension;
Table "pg_catalog.pg_extension"
Column | Type | Collation | Nullable | Default
----------------+---------+-----------+----------+---------
extname | name | | not null |
extowner | oid | | not null |
extnamespace | oid | | not null |
extrelocatable | boolean | | not null |
extversion | text | | not null |
extconfig | oid[] | | |
extcondition | text[] | | |
Indexes:
"pg_extension_name_index" UNIQUE, btree (extname)
"pg_extension_oid_index" UNIQUE, btree (oid) test=# create extension pageinspect;
CREATE EXTENSION
test=# \d pg_extension;
Table "pg_catalog.pg_extension"
Column | Type | Collation | Nullable | Default
----------------+---------+-----------+----------+---------
extname | name | | not null |
extowner | oid | | not null |
extnamespace | oid | | not null |
extrelocatable | boolean | | not null |
extversion | text | | not null |
extconfig | oid[] | | |
extcondition | text[] | | |
Indexes:
"pg_extension_name_index" UNIQUE, btree (extname)
"pg_extension_oid_index" UNIQUE, btree (oid) test=# select extName from pg_extension;
extname
-------------
plpgsql
pageinspect
( rows)
这样就安装成功了。
3.使用pageinspect的函数
最后还通过pageinspect的函数,查看table t2的页头信息。
test=# SELECT * FROM page_header(get_raw_page('t2', ));
lsn | checksum | flags | lower | upper | special | pagesize | version | prune_xid
-----------+----------+-------+-------+-------+---------+----------+---------+-----------
/1C3B848 | | | | | | | |
( row)
PostgreSQL学习(1)-- 安装pageinspect extension的更多相关文章
- postgresql学习之安装篇
---恢复内容开始--- 安装方法: 1.可以使用操作系统自带的安装源 2.可以使用官网下载的源码进行安装 3.可以使用编译好的包入.run格式的安装包安装(本文使用的是这种安装方法,下载地址http ...
- 与你相遇好幸运,Postgresql和postgis安装
笔者开发环境: windows 7 x86_64 一开始安装的是官网最新版 PostgreSQL 9.6 ,安装成功 之后安装PostGIS Bundle 2.2 for PostgreSQL x64 ...
- PostgreSQL学习----模式schema
PostgreSQL学习---模式schema 小序 接触PostgreSQL也有好长时间了,知识不总结梳理,似乎总不是自己的,继续努力吧少年!以此记录我的软件工艺之路! 模式(Schema) 一个 ...
- postgresql pgagent 的安装及使用
pgagent 作为postgresql的一个任务调度代理,在postgresql 9.0 以前 是附带在pgadmin 包下面的,只是默认不安装,9.0之后作为了一个单独是的安装包.所以要使用pga ...
- postgresql学习记录1
数据库9.3.5,系统fedora20,不同系统操作略有不同. 使用yum 命令安装即可:sudo yum install postgresql,postgresql-server 安装完毕后系统中会 ...
- Mac下手动安装SafariDriver extension
环境:Mac OS X Yosemite 10.10.4下, Safari 8 Step 1:第一次运行SafariDriver时,先找到WebDriver extension的安装路径,比如/Use ...
- Hbase深入学习(二) 安装hbase
Hbase深入学习(二) 安装hbase This guidedescribes setup of a standalone hbase instance that uses the local fi ...
- PostgreSQL学习手册
事实上之前有很长一段时间都在纠结是否有必要好好学习它,但是始终都没有一个很好的理由说服自己.甚至是直到这个项目最终决定选用PostgreSQL 时,我都没有真正意识到学习它的价值,当时只是想反正和其它 ...
- Hadoop学习------Hadoop安装方式之(二):伪分布部署
要想发挥Hadoop分布式.并行处理的优势,还须以分布式模式来部署运行Hadoop.单机模式是指Hadoop在单个节点上以单个进程的方式运行,伪分布模式是指在单个节点上运行NameNode.DataN ...
随机推荐
- JQuery Easyui/TopJUI 创建多级联动下拉框(纯HTML实现!!!)
JQuery Easyui/TopJUI 创建多级联动下拉框(纯HTML实现!!!) 效果展示: 代码如下: <form data-toggle="topjui-form"& ...
- ldap 报错整理
1.httpd 无法启动 先用systemctl status httpd 查看一下日志 1.提示端口号是否冲突,修改httpd.conf端口号 2.提示没有权限:检查selinux,防火墙是否关闭或 ...
- HTML5----前段各种常见BUG
1.在IE6下,DIV中的字会多出,并且自成一行,而且是原来的字. 这是注释bug,经典的ie6 bug. 说明:注释造成文字溢出是IE6的BUG,注释造成文字溢出与其位置有关,注释造成文字溢 ...
- [设计模式]JDK中的设计模式
转载自:http://blog.csdn.net/gtuu0123/article/details/6114197 本文主要是归纳了JDK中所包含的设计模式,包括作用和其设计类图. 首先来个总结,具体 ...
- Table行合并操作
此方法不可取,但几天心血 保留,已有新想法,稍后会出一个完善的Table行列合并方法 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Tran ...
- Jenkins+Gitlab+Ansible自动化部署(二)
接Jenkins+Gitlab+Ansbile自动化部署(一):https://www.cnblogs.com/zd520pyx1314/p/10210727.html Ansible的配置与部署 工 ...
- MapReduce基本流程与设计思想初步
1.MapReduce是什么? MapReduce是一种编程模型,用于大规模数据集的并行运算.它借用了函数式的编程概念,是Google发明的一种数据处理模型. 主要思想为:Map(映射)和Reduce ...
- Ubuntu下安装Yarm-PM2
首先打开yarm的官网.https://www.yarnpkg.com/zh-Hant/ (一)yarn的官方安装方法: 1.上通过 Debian 套件安裝 Yarn,粘贴以下命令 curl -sS ...
- Linux netstat命令详解和使用例子(显示各种网络相关信息)
netstat命令用于显示与IP.TCP.UDP和ICMP协议相关的统计数据,一般用于检验本机各端口的网络连接情况.netstat是在内核中访问网络及相关信息的程序,它能提供TCP连接,TCP和UDP ...
- JAVA---spring-boot入门(图文教程)
Spring Boot可以轻松创建独立的,生产级的基于Spring的应用程序,他的特征: 1.创建独立的Spring应用程序 2.直接嵌入Tomcat,Jetty或Undertow(无需部 ...