创建不用执行sudo可绿色的PostgreSQL

创建不用执行sudo可绿色的PostgreSQL,第1张

概述原文键接 感谢原文作者给出的精彩方法 PostgreSQL安装的时候(仅指Linux和MacOSX),往往会安装系统目录中,这样做有几点不方便。 安装多个版本的时候会冲突,尤其是想安装测试版或不同的小版本的时候。 安装路径散落在系统的好几个目录中,记起来不方便。 因为安装到了系统目录,我们有时候需要用sudo执行或者需要用su 切换到postgres用户权限下去执行。 尤其是pg的开发人员,可能需

原文键接

感谢原文作者给出的精彩方法

Postgresql安装的时候(仅指linux和MacOSX),往往会安装系统目录中,这样做有几点不方便。

安装多个版本的时候会冲突,尤其是想安装测试版或不同的小版本的时候。 安装路径散落在系统的好几个目录中,记起来不方便。 因为安装到了系统目录,我们有时候需要用sudo执行或者需要用su 切换到postgres用户权限下去执行。

尤其是pg的开发人员,可能需要安装不同的版本,或者要自己统计不同的时间的测试版,如何快速在的不同的测试版之间进行启停数据库,有没有好办法解决这两个问题呢?

下面我们演示在Mac OS X 和linux下解决这些问题的办法。
在Mac OS X下(译者亲测 10.11.4)

> cd /tmp> mkdir pg-build> wget 下载对应的源码包> cd postgresql源码目录中> ./configure --prefix=/tmp/pg-build> make> make install

在ubuntu下(译者亲测ubuntu16.04)

> cd /tmp> mkdir pg-build> wget 下载对应的源码包> cd postgresql源码目录中> ./configure --prefix=/tmp/pg-build --disable-rpath> export LD_RUN_PATH='$ORIGIN/../lib'> make> make install

然后,我们对编译的动态支持库文件进行谳整引用重定位
在Mac OS X下

find /tmp/pg-build/bin -type f | \  xargs -L 1 install_name_tool -change \  /tmp/pg-build/lib/libpq.5.dylib \  '@executable_path/../lib/libpq.5.dylib'

然后就可以了。

> cd $HOME> cp -R /tmp/pg-build pg> mkdir data> ./pg/bin/initdb data> ./pg/bin/pg_ctl -D data start

现在,你的pg就运行起来了,并且你可以把这个目录任意改名,放到你自己的任意目录,都可以运行了。 我一般测试多个版本的pg,都在自己的目录下建立pg931,pg943,pg952,pg6b1这样的目录,想用哪个用哪个。很方便。

为了自动化的实现这个功能,我写了一个小脚本,可以很方便的编译、运行不同时期源码的数据库。代码很短,自己根据自己的需要改改,放到自己的PATH目录下,就会很方便了。

[git-hub] https://github.com/lvbuwei/mypgscript

总结

以上是内存溢出为你收集整理的创建不用执行sudo可绿色的PostgreSQL全部内容,希望文章能够帮你解决创建不用执行sudo可绿色的PostgreSQL所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1174365.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存