PostgreSQL的安装 安装PostgreSQL数据库不一定需要root用户权限,普通用户也可以。安装方式有两种,一种是编译安装,一种是直接用已编译好的二进制安装包安装。使用二进制安装包进行安装比较简单,这里就不再介绍了,这里主要介绍编译安装的方法。 1. 先介绍编译安装的总体流程: 下面步骤非强制
- #######################
-
How To Set Up An Active/Passive PostgreSQL Cluster With Pacemaker, Corosync, And DRBD (CentOS 5.5)
-
http://www.howtoforge.com/how-to-set-up-an-active-passive-postgresql-cluster-with-pacemaker-corosync-and-drbd-centos-5.5-p2
-
#######################
-
system must install rpm :
-
yum install -y gcc perl-mailtools perl-dbi php-pgsql
-
rpm -Uvh http://download.fedora.redhat.com/pub/epel/5/x86_64/epel-release-5-4.noarch.rpm
-
wget -O /etc/yum.repos.d/pacemaker.repo http://clusterlabs.org/rpm/epel-5/clusterlabs.repo
-
yum install -y pacemaker corosync drbd83 kmod-drbd83 heartbeat
zypper install bison flex readline-devel gcc make-devel libpq libpq-dev libpq5 php5-pgsql
开始安装(无注释): - su - root
-
groupadd -g 26 postgres
-
useradd -g 26 -u 26 -d /data/pgsql -m postgres
-
-
cd sourcesfilefolder
- ./configure \
- --prefix=/data/pgsql \
- --with-libedit-preferred \
- --with-pgport=1921 \
- --with-segsize=8 \
- --with-wal-segsize=64 \
- --enable-thread-safety \
- --with-perl \
- --with-python \
- --with-openssl \
- --with-pam \
- --with-ldap \
- --with-libxml \
- --with-libxslt
-
## or : ./configure
-
gmake
-
gmake install
-
cd contrib/
-
gmake all
-
gmake install
-
-
su - postgres
-
/data/pgsql/bin/initdb -D /data/pgsql/data
-
echo 'host all all 10.0.0.0/8 md5' >> /data/pgsql/data/pg_hba.conf
-
vi data/postgresql.conf
-
data_directory = '/data/pgsql/data/'
-
hba_file = '/data/pgsql/data/pg_hba.conf'
-
listen_addresses = '*'
-
port = 5432
-
max_connections = 200
-
log_directory = 'pg_log'
-
log_filename = 'postgresql-%Y-%m-%d_%H%M%S.log'
-
log_checkpoints = on
-
log_connections = on
-
autovacuum = on
-
-
mkdir pg_log;chmod 700 pg_log;
-
-
# User specific environment and startup programs
-
PATH=$PATH:$HOME/bin
-
export PATH
-
LD_LIBRARY_PATH=/data/pgsql/lib
-
export LD_LIBRARY_PATH
-
PATH=/data/pgsql/bin:$PATH
-
export PATH
-
MANPATH=/data/pgsql/man:$MANPATH
-
export MANPATH
-
export PGDATA=/data/pgsql/data
-
export PGLOG=$PGDATA/pg_log
-
alias pgstart="pg_ctl -D $PGDATA -l $PGLOG/postgresql-`date +%F%H%M%S`.log start"
-
alias pgstop='pg_ctl kill INT `head -1 $PGDATA/postmaster.pid`'
-
alias pgstatus='pg_ctl status'
-
-
pgstart # start postgresql
-
psql postgres #login db for chan
-
psql (9.0.3)
-
Type "help" for help.
-
-
postgres=# ALTER ROLE postgres with password 'yourpassword';
-
ALTER ROLE
-
/data/pgsql/bin/createdb test
-
/data/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@node1 /usr/src/postgresql-8.4.3]#rpm -qa |grep readline readline-5.2-13.fc9.i386 如果要使用TAB键补全命令功能还要安装readline-devel包。 要求五(非强制): 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-XXX.tar.gz tar xvf postgresql-XXX.tar 如果在Linux下,可以一步解压: tar zxvf postgresql-XXX.tar.gz 如果是.tar.bz2包: tar jxvf postgresql-XXX.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 如果仅安装客户端程序: gmake -C src/bin install gmake -C src/include install gmake -C src/interfaces install gmake -C doc install 如果是在windows平台,可以注册event log: regsvr32 pgsql_library_directory/pgevent.dll ⑷ 卸载 gmake uninstall 5.设置环境变量和共享库路径和可执行文件路径 可以把下面的内容添加到UNIX用户的~/.bash_profile或~/.profile文件中,或如果对所有用户生效,可以添加到/etc/profile文件中: 在Bourne shells (sh, ksh, bash, zsh): LD_LIBRARY_PATH=/data/pgsql/lib export LD_LIBRARY_PATH PATH=/data/pgsql/bin:$PATH export PATH MANPATH=/data/pgsql/man:$MANPATH export MANPATH or in csh or tcsh:
setenv LD_LIBRARY_PATH /data/pgsql/lib set path = ( /data/pgsql/bin $path ) 在BSD/OS, Linux, or SunOS 4平台下,使用root用户执行:
/sbin/ldconfig /data/pgsql/lib On FreeBSD, NetBSD, and OpenBSD: /sbin/ldconfig -m /data/pgsql/lib 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 或 .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 避免在后面的建用户数据库时可以会报如下错误: postgres=# CREATE DATABASE mydb WITH ENCODING='UTF8' TEMPLATE template0; ERROR: encoding UTF8 does not match locale en_US DETAIL: The chosen LC_CTYPE setting requires encoding LATIN1. 初使化数据库目录: su - postgres /data/pgsql/bin/initdb -D $PGDATA 修改数据库参数: 按需要修改$PGDATA/postgresql.conf中的参数,如: logging_collector = on log_rotation_age = 1d log_rotation_size = 10MB
log_directory = 'pg_log' (非必需) log_filename = 'postgresql-%Y-%m-%d_%H%M%S.log' (非必需) 启动数据库: /data/pgsql/bin/pg_ctl -D $PGDATA start
这时就可以进入psql命令行了: [postgres@pghost pgdata]$ psql psql Type "help" for help.
postgres=#
这时可以创建用户数据库了:
在psql中命令行中输入create database中的命令行:
CREATE DATABASE mydb WITH ENCODING='UTF8' TEMPLATE template0;
如果报如下错误: postgres=# CREATE DATABASE mydb WITH ENCODING='UTF8' TEMPLATE template0; ERROR: encoding UTF8 does not match locale en_US DETAIL: The chosen LC_CTYPE setting requires encoding LATIN1. 表明前面的执行initdb做初使用化时的LANG没有设置成与数据库的字符集,这时可以在建数据库时指定本地的的字符集: CREATE DATABASE mydb ENCODING 'UTF8' TEMPLATE template0 LC_COLLATE 'zh_CN.UTF8' LC_CTYPE 'zh_CN.UTF8' |