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的更多相关文章

  1. postgresql学习之安装篇

    ---恢复内容开始--- 安装方法: 1.可以使用操作系统自带的安装源 2.可以使用官网下载的源码进行安装 3.可以使用编译好的包入.run格式的安装包安装(本文使用的是这种安装方法,下载地址http ...

  2. 与你相遇好幸运,Postgresql和postgis安装

    笔者开发环境: windows 7 x86_64 一开始安装的是官网最新版 PostgreSQL 9.6 ,安装成功 之后安装PostGIS Bundle 2.2 for PostgreSQL x64 ...

  3. PostgreSQL学习----模式schema

    PostgreSQL学习---模式schema 小序 接触PostgreSQL也有好长时间了,知识不总结梳理,似乎总不是自己的,继续努力吧少年!以此记录我的软件工艺之路! 模式(Schema) 一个 ...

  4. postgresql pgagent 的安装及使用

    pgagent 作为postgresql的一个任务调度代理,在postgresql 9.0 以前 是附带在pgadmin 包下面的,只是默认不安装,9.0之后作为了一个单独是的安装包.所以要使用pga ...

  5. postgresql学习记录1

    数据库9.3.5,系统fedora20,不同系统操作略有不同. 使用yum 命令安装即可:sudo yum install postgresql,postgresql-server 安装完毕后系统中会 ...

  6. Mac下手动安装SafariDriver extension

    环境:Mac OS X Yosemite 10.10.4下, Safari 8 Step 1:第一次运行SafariDriver时,先找到WebDriver extension的安装路径,比如/Use ...

  7. Hbase深入学习(二) 安装hbase

    Hbase深入学习(二) 安装hbase This guidedescribes setup of a standalone hbase instance that uses the local fi ...

  8. PostgreSQL学习手册

    事实上之前有很长一段时间都在纠结是否有必要好好学习它,但是始终都没有一个很好的理由说服自己.甚至是直到这个项目最终决定选用PostgreSQL 时,我都没有真正意识到学习它的价值,当时只是想反正和其它 ...

  9. Hadoop学习------Hadoop安装方式之(二):伪分布部署

    要想发挥Hadoop分布式.并行处理的优势,还须以分布式模式来部署运行Hadoop.单机模式是指Hadoop在单个节点上以单个进程的方式运行,伪分布模式是指在单个节点上运行NameNode.DataN ...

随机推荐

  1. 判断iphone 屏幕大小宏定义

    #define IS_IPAD (UI_USER_INTERFACE_IDIOM() == UIUserInterfaceIdiomPad)  #define IS_IPHONE (UI_USER_I ...

  2. Luogu P1637 三元上升子序列【权值线段树】By cellur925

    题目传送门 emmm..不开结构体的线段树真香! 首先我们知道"三元上升子序列"的个数就是对于序列中的每个数,**它左边比他小的数*它右边比他大的数**.但是如何快速求出这两个数? ...

  3. JS中substr与substring的区别

    js中substr和substring都是截取字符串中子串,非常相近,可以有一个或两个参数. 语法:substr(start [,length]) 第一个字符的索引是0,start必选 length可 ...

  4. Opencv级联分类器实现人脸识别

    在本章中,我们将学习如何使用OpenCV使用系统相机捕获帧.org.opencv.videoio包的VideoCapture类包含使用相机捕获视频的类和方法.让我们一步一步学习如何捕捉帧 - 第1步: ...

  5. 2017swpu-ctf总结

    2017swpu-ctf总结 今年是我第一次出题感受很多,就分析几道我印象最深刻的题吧 你能进入后台吗? 这道题主要是考察php_screw还有md5加密开启true过后的注入 phpscrew加密在 ...

  6. 如果查询的结果少,可以把查询结果当子集,再查另一张表,比join的速度快得多得多

    ) as qty from riv_print_history_l phl JOIN tab_user_profile up on up.UP_USER_ID = phl.PHL_PRINT_USER ...

  7. NET Core项目部署

    NET Core项目部署到linux(Centos7) 阅读目录 1.开篇说明 2.Jexus简单说明 3.Visual Studio 2015本地发布并且测试 4.配置Jexus并且部署.NET C ...

  8. 关于eclipse安装maven之后,maven找不到JDK问题

    问题: 最近在Eclipse里面装了maven之后,启动或者在运行项目时存在如下的警告: Eclipse is rinning in a JRE,but a JDK is require, Some ...

  9. 宿主机Windows访问虚拟机Linux文件(二)

    上一篇文章中详细讲述FTP服务(基于文件传输协议的服务),本文则介绍另一种能够实现此功能Telnet(Telecommunications network 远程登陆)服务.本文介绍的telnet我常用 ...

  10. cocos 2d-x 3.0配制环境

    cocos2d-x 3.0发布有一段时间了,作为一个初学者,我一直觉得cocos2d-x很坑.每个比较大的版本变动,都会有不一样的项目创建方式,每次的跨度都挺大…… 但是凭心而论,3.0RC版本开始 ...