windows下源码安装调试postgresql
环境:windows 10
postgresql版本:postgresql-9.6.5
使用工具:vs2017社区版
辅助工具:perl、diff、flex、bison
相关工具下载地址:
perl下载链接:http://pan.baidu.com/s/1i5aPilB
密码:k6f0
diff、flex、bison下载链接:http://pan.baidu.com/s/1hrHotes
密码:4ku6
以上工具均为绿色版,解压后,设置环境变量即可
此处使用的编译调试工具为vs2017社区版,该版本为免费版,个人使用不存在版权困扰。
首先离线下载vs2017社区版,也可在线安装,安装方式如下:
微软官方下载官方提供的下载工具:vs_community.exe
cmd中执行以下命令,zh-CN表示中文,en-US表示英文,E:\vs2017表示下载位置:
vs_community.exe
--layout E:\vs2017 offline --lang zh-CN
安装vs2017,选择如下内容安装即可:

修改postgresql配置文件,否则编译过程会出现错误。修改内容如下:
E:\PG\postgresql_9.6.5\src\tools\msvc\VSObjectFactory.pm中,将“if ($major > 14)”修改为“if ($major > 15)”,如下所示:

E:\PG\postgresql_9.6.5\src\tools\msvc\Mkvcbuild.pm将“my $vsVersion = DetermineVisualStudioVersion();”修改为“my $vsVersion = '14.00';”,如下图所示:

以上两步解决pg的perl脚本中不识别vs2017版本的问题,报错信息为“Unable to determine Visual
Studio version: The nmake version could not be determined. at
src/tools/msvc/Mkvcbuild.pm line 86.”
用vs打开文件“E:\PG\postgresql_9.6.5\src\fe_utils\print.c”,执行如下操作:




然后保存替换原来的文件。此处解决的问题:该文件中的换行符使用的是各个操作系统通用的换行符,在windows下编译会出现警告。报错信息为“warning C4819: The file
contains a character that cannot be represented in the current code page (936).
Save the file in Unicode format to prevent data loss”
下面编译postgresql源码:

然后执行“cd /d E:\PG\postgresql_9.6.5\src\tools\msvc”切换到pg源码路径,执行命令“perl build.pl DEBUG”此处为方便调试使用DEBUG模式,编译时间会比在linux下要长,编译完成后,如下:

编译完成后,可以执行“perl vcregress.pl check”跑一下回归测试,结果如下:

确认无误后,执行“perl install.pl E:\pg\pgdb”进行安装,安装结果如下:

然后进入到pg安装目录“cd /d E:\pg\pgdb”进行建库操作“initdb.exe -D ../data”,建库完成后,启动pg数据库“pg_ctl.exe -D ../data -l
logfile start”,启动完成后即可进入数据库“psql -d postgres”

如果需要使用vs调试pg,先将pg代码使用vs打开,打开方式,找到编译后的文件夹“E:\PG\postgresql_9.6.5”,打开文件“pgsql.sln”即出现以下提示,因使用vs2015的编译器编译,不对项目进行重定向,选项如下:

确定后,即可使用vs打开pg源码。然后确定当前打开pg的进程ID:



点击附加,即可附加到进程。
尝试调试


此时pg在等待输入,通过堆栈信息可以看出是等待网络消息的状态,最终停止在函数“WaitForMultipleObjects”
使用断点调试,例如在pg错误入口函数下断点,
如下

然后执行错误的SQL语句:

数据库中并不存在表aaaa,此时vs状态如下:

以上堆栈信息即为pg执行错误SQL时所使用的函数。
windows下源码安装调试postgresql的更多相关文章
- CentOS 7下源码安装MySQL 5.7
网上说linux安装mysql服务分两种安装方法: ①源码安装,优点是安装包比较小,只有几十M左右,缺点是安装依赖的库多,安装编译时间长,安装步骤复杂容易出错: ②使用官方编译好的二进制文件安装,优点 ...
- CentOS 6.3下源码安装LAMP(Linux+Apache+Mysql+Php)环境【转载】
本文转载自 园友David_Tang的博客,如有侵权请联系本人及时删除,原文地址: http://www.cnblogs.com/mchina/archive/2012/11/28/2778779.h ...
- centos 6x系统下源码安装mysql操作记录
在运维工作中经常部署各种运维环境,涉及mysql数据库的安装也是时常需要的.mysql数据库安装可以选择yum在线安装,但是这种安装的mysql一般是系统自带的,版本方面可能跟需求不太匹配.可以通过源 ...
- lnux下源码安装MySQL 5.6
nux下源码安装MySQL 5.6 说明:本文是我自己测试的MySQL5.6源码安装,经本人亲自实践,完全可用,另在5.6之前的版本也是可以按照本文源码安装的.我是在两台linux下一台安装5.5,另 ...
- CentOS下源码安装Apache2.4+PHP5.4+MySQL5.5
一.准备(把所有的源文件放在‘/home/yuanjun’目录下) apr http://mirror.bjtu.edu.cn/apache/apr/apr-1.4.6.tar.gz apr-util ...
- nginx在Centos7.5下源码安装和配置
安装nginx 安装nginx依赖包 yum install -y pcre-devel zlib-devel openssl-devel wget gcc tree vim 进入目录/root/se ...
- 在ConoHa上Centos7环境下源码安装部署LNMP
本文记录了从源码,在Centos 7上手动部署LNMP环境的过程,为了方便以后对nginx和mariadb进行升级,这里采用yum的方式进行安装. 1.建立运行网站和数据库的用户和组 groupadd ...
- CentOS7 下源码安装 python3
CentOS 7 下源码安装 python3 在CentOS7下,默认安装的是python2.7:为满足项目要求,安装python3 的方法如下: 1. 首先安装python3.6可能使用的依 ...
- CentOS7.3环境下源码安装httpd
CentOS7.3环境下源码安装httpd 本文在CentOS7.3下,源码安装apache服务httpd2.4. 1.下载好源码安装包 [root@localhost ~]#ll total 625 ...
随机推荐
- 20190827 On Java8 第十四章 流式编程
第十四章 流式编程 流的一个核心好处是,它使得程序更加短小并且更易理解.当 Lambda 表达式和方法引用(method references)和流一起使用的时候会让人感觉自成一体.流使得 Java ...
- 前端 CSS的选择器 属性选择器
属性选择器,字面意思就是根据标签中的属性,选中当前的标签. 属性选择器 通常在表单控件中 使用比较多 根据属性查找 /*用于选取带有指定属性的元素.*/ <!DOCTYPE html> & ...
- mysql 小数位
1 select convert(t/100,decimal(15,2)) as a from user (1) convert() 一.在mysql操作中我们经常需要对数据进行类型转换.此时我 ...
- mybatis加载配置文件详解
spring整合Mybatis后,SqlSessionFactory的创建由spring进行了代理,以下是SqlSessionFactory创建的流程 SqlSessionFactoryBean: p ...
- 以区间DP为前提的【洛谷p1063】能量项链
(跑去练习区间DP,然后从上午拖到下午qwq) 能量项链[题目链接] 然后这道题也是典型的区间DP.因为是项链,所以显然是一个环,然后我们可以仿照石子合并一样,把一个有n个节点的环延长成为有2*n个节 ...
- 剑指offer学习读书笔记--二维数组中的查找
在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都是按照从上到下递增的顺序排序.请设计一个函数,输入这样的一个二维数组和一个整数,判断数组是否含有这个整数. 1 2 8 9 2 4 9 1 ...
- 如何利用Chrome进行跨域调试
为什么要跨域调试: 拿嵌入式web开发说,代码都是跑在板子上,我一个优雅的前端开发要每次改完代码都打包到板子上,用板子的地址打开,这是人做的事??? 怎么跨域调试: 1.升级Chrome为最新版本 2 ...
- Vue —— You may use special comments to disable some warnings. Use // eslint-disable-next-line to ignore the next line. Use /* eslint-disable */ to ignore all warnings in a file.问题
方法1: 在build/webpack.base.conf.js文件中,找到module->rules中有关eslint的规则,注释或者删除掉就可以了 module: { rules: [ // ...
- Robot Framework 源码阅读 day1 run.py
robot里面run起来的接口主要有两类 run_cli def run_cli(arguments): """Command line execution entry ...
- PayPal支付对接
开发时间:2019-04-30 我的目标:在我们公司的海外网站上,接入PayPal支付,美国用户在线完成付款. 准备: (1)准备:公司注册信息(执照,注册号,法人等),法人信息(身份证,住址等) ( ...