postgresql数据库的安装一(源码编译)

来源:互联网 发布:大学生linux基础知识 编辑:程序博客网 时间:2024/05/16 23:55

转自:http://blog.csdn.net/beiigang/article/details/8314216

安装PostgreSQL数据库不一定需要root用户权限,普通用户也可以。安装方式有多种,一种是编译安装,一种是二进制安装包安装,还有各种linux系统的包安装。

一. 源码编译安装
总体流程:
./configure
gmake
su
gmake install
adduser postgres
mkdir /usr/local/pgsql/data
chown postgres /usr/local/pgsql/data
su - postgres
/usr/local/pgsql/bin/initdb -D /usr/local/pgsql/data
/usr/local/pgsql/bin/postgres -D /usr/local/pgsql/data >logfile 2>&1 &
/usr/local/pgsql/bin/createdb test
/usr/local/pgsql/bin/psql test
 
2.安装的前提条件
要求一:
要求有GNU make,版本要大于等于 3.76.1,检查gmake的方法如下:
gmake --version
 
要求二:
编译器要求是兼容ISO/ANSI C 的编译器,遵从C89标准。
如果使用gcc,这两个条件都能支持。而gcc支持大多数的UNIX环境,如Linux、AIX、HPUX、Solaris等。
 
要求三:
由于源代码包是.tar.gz或.tar.bz2的格式,所以要求平台下有能解压缩源代码包的tar和gzip工具。
 
要求四(非强制):
PostgreSQL默认是使用GNU Readline库支持在psql的命令行中可以使用光标键(↑↓)翻出历史命令。当然如果没有GNU Readline库的话,需要增加without-readline 选项到./configure命令后,当然这样做后就失去了使用光标键(↑↓)翻出历史命令的功能。也可以使用libedit库(BSD-licensed)提供类似的功能,这时需要在.configure后增加--with-libedit-preferred 选项。常用的Linux发行版本默认安装了时都安装了GNU Readline库。下面的命令检查是否安装了Readline库:
[root@osdba /usr/src/postgresql-8.4.3]#rpm -qa |grep readline
readline-5.2-13.fc9.i386
 
要求五(非强制):
PostgreSQL默认使用zlib压缩库,主要是pg_dump和pg_restore这两个导入导出工具使用zlib压缩库,指定配置选项--without-zlib可以不使用zlib库,当然这样pg_dump和pg_restore就没有了压缩功能了。
 
要求六(非强制):
主要你需要服务端语言如PL/Perl ,PL/Python PL/Tcl ,当然你需要安装Perl、Python、Tcl。
如果你需要PostgreSQL能提示中文,你需要实现Gettext API。
 
3.下载PostgreSQL源码包
到www.postgresql.org网站上下载源码包,然后解压到一个目录下:
gunzip postgresql-8.4.3.tar.gz
tar xvf postgresql-8.4.3.tar
如果在Linux下,可以一步解压:
tar zxvf postgresql-8.4.3.tar.gz
如果是.tar.bz2包:
tar jxvf postgresql-8.4.3.tar.bz2
 
 
4.安装过程
⑴ ./configure
后面可以跟我们前面讲过的一些选项,如--with-libedit-preferred :
./configure --with-libedit-preferred
后面可以跟很多的选项,具体可以参见PostgreSQL提供的官方手册,这里介绍几个常用的选项:
--prefix=PREFIX:指定安装PostgreSQL的安装目前,如果没有指定,则安装到/usr/local/pgsql目录下。
--with-pgport=NUMBER:指定PostgreSQL的监听端口,默认为5432
--with-wal-segsize=SEGSIZE: 指定WAL日志文件的大小。
--with-wal-blocksize=BLOCKSIZE:指定WAL日志的块大小。
--enable-thread-safety:允许客户端的库函数是线程安全的。
执行的时候可能报:
configure: error: readline library not found
这是因为readline没有安装,只要安装这个库就可以了,如在ubuntu10.04下可以:
aptitude install libreadline6-dev
 
⑵ 编译源代码
gmake
有可能你的机器的没有gmake命令,而make就是gnu make,这时运行make编译:
make
 
⑶ 安装编译生成的文件
gmake install
 
如果仅安装客户端程序:
<span class="APPLICATION"><span class="APPLICATION"><span class="PRODUCTNAME"><tt class="FILENAME"><tt class="REPLACEABLE"><tt class="REPLACEABLE"><tt class="REPLACEABLE"><span class="APPLICATION"><span class="APPLICATION"><span class="PRODUCTNAME"><tt class="FILENAME"><span style="font-family: 新宋体;"><span class="APPLICATION"><span class="APPLICATION"><span class="PRODUCTNAME"><tt class="FILENAME"><kbd class="USERINPUT">gmake -C src/bin install</kbd><kbd class="USERINPUT">gmake -C src/include install</kbd><kbd class="USERINPUT">gmake -C src/interfaces install</kbd><kbd class="USERINPUT">gmake -C doc install</kbd></tt></span></span></span></span></tt></span></span></span></tt></tt></tt></tt></span></span></span>
如果是在windows平台,可以注册event log:
regsvr32 pgsql_library_directory/pgevent.dll
 
⑷ 卸载
gmake uninstall
 
 
5.设置环境变量和共享库路径和可执行文件路径
可以把下面的内容添加到UNIX用户的~/.bash_profile或~/.profile文件中,或如果对所有用户生效,可以添加到/etc/profile文件中:
 
在Bourne shells (shkshbashzsh):
<span class="APPLICATION"><span class="APPLICATION"><span class="PRODUCTNAME"><tt class="FILENAME"><tt class="REPLACEABLE"><tt class="REPLACEABLE"><tt class="REPLACEABLE"><span class="APPLICATION"><span class="APPLICATION"><span class="PRODUCTNAME"><tt class="FILENAME"><em>LD_LIBRARY_PATH=/usr/local/pgsql/libexport LD_LIBRARY_PATH</em></tt></span></span></span></tt></tt></tt></tt></span></span></span>
<span class="APPLICATION"><span class="APPLICATION"><span class="PRODUCTNAME"><tt class="FILENAME"><tt class="REPLACEABLE"><tt class="REPLACEABLE"><tt class="REPLACEABLE"><span class="APPLICATION"><span class="APPLICATION"><span class="PRODUCTNAME"><tt class="FILENAME"><em>PATH=/usr/local/pgsql/bin:$PATHexport PATH</em></tt></span></span></span></tt></tt></tt></tt></span></span></span>
<span class="APPLICATION"><span class="APPLICATION"><span class="PRODUCTNAME"><tt class="FILENAME"><tt class="REPLACEABLE"><tt class="REPLACEABLE"><tt class="REPLACEABLE"><span class="APPLICATION"><span class="APPLICATION"><span class="PRODUCTNAME"><tt class="FILENAME"><em>MANPATH=/usr/local/pgsql/man:$MANPATHexport MANPATH</em></tt></span></span></span></tt></tt></tt></tt></span></span></span>

or in csh or tcsh:

<span class="APPLICATION"><span class="APPLICATION"><span class="PRODUCTNAME"><tt class="FILENAME"><tt class="REPLACEABLE"><tt class="REPLACEABLE"><tt class="REPLACEABLE"><span class="APPLICATION"><span class="APPLICATION"><span class="PRODUCTNAME"><tt class="FILENAME"><em>setenv LD_LIBRARY_PATH /usr/local/pgsql/lib</em></tt></span></span></span></tt></tt></tt></tt></span></span></span>
<span class="APPLICATION"><span class="APPLICATION"><span class="PRODUCTNAME"><tt class="FILENAME"><tt class="REPLACEABLE"><tt class="REPLACEABLE"><tt class="REPLACEABLE"><span class="APPLICATION"><span class="APPLICATION"><span class="PRODUCTNAME"><tt class="FILENAME"><em>set path = ( /usr/local/pgsql/bin $path )</em></tt></span></span></span></tt></tt></tt></tt></span></span></span>
<span class="APPLICATION"> </span>

BSD/OSLinux, or SunOS 4平台下,使用root用户执行:

<span class="APPLICATION"><span class="APPLICATION"><span class="PRODUCTNAME"><tt class="FILENAME"><tt class="REPLACEABLE"><tt class="REPLACEABLE"><span style="font-family: 新宋体;"><tt class="REPLACEABLE"><em>/sbin/ldconfig /usr/local/pgsql/lib</em></tt></span></tt></tt></tt></span></span></span>
<span class="APPLICATION"><span class="APPLICATION"><span class="PRODUCTNAME"><tt class="FILENAME"><tt class="REPLACEABLE"><tt class="REPLACEABLE"><span style="font-family: 新宋体;"><tt class="REPLACEABLE">On <span class="SYSTEMITEM">FreeBSD</span>, <span class="SYSTEMITEM">NetBSD</span>, and <span class="SYSTEMITEM">OpenBSD:</span></tt></span></tt></tt></tt></span></span></span>
<span class="APPLICATION"><span class="APPLICATION"><span class="PRODUCTNAME"><tt class="FILENAME"><tt class="REPLACEABLE"><tt class="REPLACEABLE"><span style="font-family: 新宋体;"><tt class="REPLACEABLE"><em>/sbin/ldconfig -m /usr/local/pgsql/lib</em></tt></span></tt></tt></tt></span></span></span>
 
6.安装contrib目录下的一些工具
源代码目录下有一个contrib目录,是一些第三方组织贡献出来的一些工具代码,这些工具在日常维护中也很有用,建议安装上。
cd /usr/src/postgresql-8.4.3/contrib
make
make install
 
7.创建数据库
建postgres用户:
useradd -m -u 701 postgres
建postgres数据库的目录,假设数据库建在/opt/pgdata目录下:
mkdir /opt/pgdata
chown postgres:postgres /opt/pgdata
 
在postgres用户下的.bash_profile文件中添加如下内容,方便以后启动数据库和关闭数据库:
su - postgres
export PGDATA=/opt/pgdata
alias pgstart='pg_ctl -D $PGDATA start'
alias pgstop='pg_ctl kill INT `head -1 $PGDATA/postmaster.pid`'
如果你要建utf8的数据库,注意设置LANG环境变量为utf8的,把下面的内容加到.bash_profile文件中:
export LANG=en_US.utf8
 
初使化数据库目录:
su - postgres
/usr/local/pgsql/bin/initdb -D $PGDATA
 
修改数据库参数:
按需要修改$PGDATA/postgresql.conf中的参数,如:
logging_collector = on
log_rotation_age = 1d

log_rotation_size = 10MB

启动数据库:
/usr/local/pgsql/bin/pg_ctl -D $PGDATA start

这时就可以进入psql命令行了:
[postgres@pghost pgdata]$ psql
psql (8.4.3)
Type "help" for help.

postgres=#

这时可以创建用户数据库了:

CREATE DATABASE mydb



0 0
原创粉丝点击