在ubuntu上源码编译PostgreSQL
【on the way】
    1:下载PostgreSQL代码 wget?http://ftp.postgresql.org/pub/source/v9.2.4/postgresql-9.2.4.tar.gz
    2:解压后执行./configure
    3:编译安装
    make
    make install
    4:添加一个用户postgres 管理postgresql数据库
    adduser postgres
    5:创建postgresql要用的数据目录
    mkdir -p /home/postgres/data
    chown postgres /home/postgres/data
    chown -R postgres /home/postgres/
    6: 以postgres 用户登录 su postgres
    7:初始化数据库
    用make install安装时postgresql默认安装到了/usr/local目录下
    为便于管理可以把安装到这个目录下的pgsql目录的全部文件拷贝到postgres下
    /home/postgres/bin/initdb -D /home/postgres/data
    8:启动数据库
    /home/postgres/bin/pg_ctl -D /home/postgres/data -l logfile start
    9:将postgresql加入系统服务实现开机自启动
    PostgreSQL的开机自启动脚本位于postgresql源码目录contrib/start-scripts目录下的linux
    1: chmod a+x linux
    2: 将linux改名为postgresql
    3:修改脚本中prefix (postgresql的安装目录),PGDATA (postgresql的数据目录) 的路径
    4:将postgresql复制到/etc/init.d目录下
    设置开机自启动服务
    1:手动设置
    ubuntu下开机自启动相关知识
    首先,linux随机启动的服务程序都在/etc/init.d这个文件夹里,里面的文件全部都是脚本文件(脚本程序简单的说就是把要运行的程序写 到一个 文件里让系统能够按顺序执行,类似windows下的autorun.dat文件),另外在/etc这个文件夹里还有诸如名为rc1.d, rc2.d一直到rc6.d的文件夹,这些都是linux不同的runlevel,我们一般进入的X windows多用户的运行级别是第5级,也就是rc5.d,在这个文件夹下的脚本文件就是运行第5级时要随机启动的服务程序。需要注意的是,在每个rc (1-6).d文件夹下的文件其实都是/etc/init.d文件夹下的文件的一个软连接(类似windows中的快捷方式),也就是说,在/etc/init.d文件夹下是全部的服务程序,而每个rc(1-6).d只链接它自己启动需要的相应的服务程序!
    要启动scim(某一程序),我们首先要知道scim程序在哪里,用locate命令可以找到,scim在/usr/bin/scim这里,其中usr表示是属于用户的,bin在linux里表示可以执行的程序。这样,我就可以编写一个脚本程序,把它放到/etc/init.d里,然后在rc5.d里做一个相 应的软链接就可以了。这个脚本其实很简单,就两行:
    #!/bin/bash
    /usr/bin/scim
    第一行是声明用什么终端运行这个脚本,第二行就是要运行的命令。
    还需要注意的一点是,在rc5.d里,每个链接的名字都是以S或者K开头的,S开头的表示是系统启动是要随机启动的,K开头的是不随机启动的。这样,你就可以知道,如果我要哪个服务随机启动,就把它名字第一个字母K改成S就可以了,当然,把S改成K后,这个服务就不能随机启动了。因此,我这个链接 还要起名为SXXX,这样系统才能让它随机启动。
    在RH下,rc.local是默认启动的最后一个脚本文件,所以,如果你想要随机启动,还有一种方法就是在rc.local的尾部加入/usr/bin/scim,这样就可以了。
    2:采用工具设置 sysv-rc-conf
    操作界面十分简洁,你可以用鼠标点击,也可以用键盘方向键定位,用空格键选择, "X"表示开启该服务。 用Ctrl+N翻下一页,用Ctrl+P翻上一页,用Q退出。
    apt-get install sysv-rc-conf
    至此:postgresql安装完成