调试postgresql9.5.2最新源码

最近在考量数据库的选型,考虑后期把数据切换到postgresql ,postgresql源码用c实现,代码很精炼完美,值得学习下

首先去pgsql官网下载最新的源码 ,然后还需要perl,bison

先安装ActiverPerl-5.22.1.2201x64.msi 默认装在c盘,一路点next安装。

我是将Perl是安装到了C盘,则在系统环境变量中添加Perl的C盘路径位置。

打开postgresql9.5.2 文件夹,找到MKVcbuild.pm文件(如下图所示),用文本编辑器打开,修改其中my $vsVersion = DetermineVisualStudioVersion()该行,变为my $vsVersion = “12.0.0”,VS2013 对应的version版本是12.0

反键编辑

打开cmd或用vs2013自带的x64 cmd命令工具打开, 切换到源码msvc目录

MSVC目录下,输入perl build.pl DEBUG  然后开始编译代码,这里需要5-6分钟,速度根据跟人的电脑配置来定

生成源码完成后最后如图所示

接着在命令编辑器中继续输入perl install.pl path,例如:

perl install.pl D:\pgbin

生成后的效果如图

这里很关键 如果没有下面的操作 你就需要去源码里面去掉管理员权限的判断,如果用超级管理员运行 会报错

我们用cmd命令添加一个 postgres用户

net user postgres postgres /add

打开运行输入 runas /user:postgres cmd.exe

此时会以postgres权限打开cmd

我们先直接打开cmd 初始化数据库DB

postgres.exe -D DB 这里就启动了一个server实例,开始监听所有的链接

输入postgres.exe -D DB   (注意-D中的D一定要大写),这里不一定是DB,你也可以自己定

我这里用的数据库pgsql

到这里pgsql服务器算是启动好了。

然后我们用navcat 连接一下试试,建一个数据库

打开源码项目,这里加载会要几分钟时间

backend\executor\execMain.c ,依次打上断点

最后我们这里打开 psql源码, 打开pquery.c,里面设置好断点

启动调试,进断点了。

今天还有点晚了,接下来有时间再分享源码结构的学习

关于源码的说明有专门的网站 http://doxygen.postgresql.org/

接下来就可以开始postgresql的源码学习之旅了,你就可以通过navcat建表,删表,插入数据,update,多种操作,尽情的揉虐 pgsql源码了。希望此文能给大家学习pgsql一些帮助,这款数据库真的很优秀,如果你去用了会有一种相见恨晚的感觉

时间: 05-06

调试postgresql9.5.2最新源码的相关文章

PostgreSQL9.2.4内核源码结构介绍

PostgreSQL的源代码可以随意获得,其开源协议也允许研究者任意修改,这里介绍一下PostgreSQL的源码结构以及部分实现机制.下载PostgreSQL源代码并减压后,其一级目录结构如下图: PostgreSQL源代码一级结构 其中config目录下存放一些系统的配置文件.contrib目录下包括一些没有集成到核心代码中的外围工具和一些实验性质的开发代码.doc目录下是帮助文档,由SGML编写.src为系统核心代码,其他文件属于编译安装相关文件. src目录,各子目录及其对应内容如下表:

eclipse调试第三方jar包需要源码的问题

很多时候测试自己的jar包功能时,需要有一个测试工程导入该jar包,但是一般在调试的时候,需要跟进去看看步骤和逻辑是否正确,这个时候就需要在jar包的源码中下断点.最近刚好自己也会经常这样做,也遇到了类似的问题,相信不少网友都会遇到,这里把我看到的一个解决方法贴出来,原帖在这里:http://www.tuicool.com/articles/aa6zyi,感谢作者的无私奉献. 步骤如下: 1.选择要调试的项目进入调试状态. 2.在thread这里,选择当前线程,然后右键,选择edit sourc

[福音][散发]从github下载Android最新源码

============问题描述============ 我刚发表了一篇博文<从github下载最新Android源码>,想看Andorid源码,又迫于google被墙的同学可以看看- 本贴散分,先到先得- 文章链接:http://blog.csdn.net/xusiwei1236/article/details/39395359 (欢迎大家前去围观) ============解决方案1============ 我最先到..... ============解决方案2============ 沙

SoYun社工库最新源码以及审计出的漏洞报告信息

本文作者:浅蓝 前段时间有人发过搜云的源码,都好长时间了. 这次我放出个最新的. 是在他换模板之前的源码.(现在的搜云后端基本没什么变化 换了个模板而已) 同时审计出来了一些漏洞.. 我里面的数据库配置信息等重要敏感信息换成了"马赛克" 以下附上审计出的漏洞 1.user.ph#sql注入 265行 $card = $_POST['card']; if ($_POST['card']) {     $sql = "select * from alipay where card

Lamp最新源码包一般安装过程及常见问题

l Lamp简介 l Apache安装 l Mysql安装 l Php安装 l 测试lamp l 常见问题 l 参考资料 Lamp简介 Lamp是Linux+Apache+Mysql/MariaDB+Perl/PHP/Python一组常用来搭建动态网站或者服务器的开源软件.比较流行的是Linux+Apache+Mysql+PHP架构. php功能很强大,安装包install文件中是这样说的: Before starting the installation, first you need to 

Ubuntu12.04下postgresql-9.3.4编译源码出错,无readline library not found

1.问题现象: 下载链接:http://www.postgresql.org/ftp/source/ 解压后编译安装(需要root权限) 1 [email protected]:/opt/postgresql-9.3.4#  tar -zxvf postgresql-9.3.4.tar.gz 2 [email protected]:/opt/postgresql-9.3.4#  cd postgresql-9.3.4/ 3 [email protected]:/opt/postgresql-9.

js实现的省市县三级联动的最新源码

<!DOCTYPE html> <html> <head> <title>省市区三级联动</title> <!-- 直接使用QQ的省市区数据 --> <!-- <script type="text/javascript" src="http://ip.qq.com/js/geo.js"></script> --> <script type="t

Android逆向之旅---动态方式破解apk进阶篇(IDA调试so源码)

一.前言 今天我们继续来看破解apk的相关知识,在前一篇:Eclipse动态调试smali源码破解apk 我们今天主要来看如何使用IDA来调试Android中的native源码,因为现在一些app,为了安全或者效率问题,会把一些重要的功能放到native层,那么这样一来,我们前篇说到的Eclipse调试smali源码就显得很无力了,因为核心的都在native层,Android中一般native层使用的是so库文件,所以我们这篇就来介绍如何调试so文件的内容,从而让我们破解成功率达到更高的一层.

设置Eclipse可以Debug模式调试JDK源码,并显示局部变量的1

最近突然萌发了研究JDK源码的想法,所以就想到了在自己常用的Eclipse上可以调试JDK源码. 整个设置过程也很简单: 首先你要安装好JDK(我的JDK安装路径根目录是D:\Java\jdk-8u92-windows-x64),JDK安装路径里有个"src.zip"就是JDK的源码文件压缩包: 设置好环境变量的JAVA_HOME变量和PATH变量(JAVA_HOME变量值也是D:\Java\jdk-8u92-windows-x64). 然后打开Eclipse设置可以Debug模式调试