FreeBSD 8.0安装PostgreSQL 8.4.x

  最近准备做一个使用PostgreSQL的项目,当然要在服务器上安装PostgreSQL了。安装要比MySQL麻烦一些,现记录如下。

  1、编译安装PostgreSQL 8.4.2
引用
wget http://wwwmaster.postgresql.org/redir/391/f/source/v8.4.2/postgresql-8.4.2.tar.gz
tar zxvf postgresql-8.4.2.tar.gz
cd postgresql-8.4.2
./configure --prefix=/usr/local/pgsql
make
make install


  2、创建PostgreSQL用户,由于PostgreSQL不能用root初始化及启动,所以必须创建一个新的用户
引用
pw groupadd pgsql
pw useradd pgsql -g pgsql -d /data/pgsql -s /bin/csh


  3、创建PostgreSQL数据存放目录
引用
mkdir -p /data/pgsql/data
chown -R pgsql:pgsql /data/pgsql/


  4、初始化数据库
引用
su pgsql /usr/local/pgsql/bin/initdb -D /data/pgsql/data -E UTF8


  5、修改PostgreSQL启动文件
引用
cp contrib/start-scripts/freebsd /usr/local/pgsql/pgsql
vi /usr/local/pgsql/pgsql

#修改PGDATA=/usr/local/pgsql/data
#为PGDATA=/data/pgsql/data

#修改PGUSER=postgres
#为PGUSER=pgsql
#保存退出

vi /etc/rc.local

#在其中加上 /usr/local/pgsql/pgsql start
#保存退出


  至此PostgreSQL就算是安装完了,接下来是安装PHP的PostgreSQL支持。

  1、做一个libpq.so.5的链接
引用
ln -s /usr/local/pgsql/lib/libpq.so.5 /usr/lib/libpq.so.5


  2、重新编译PHP
引用
./configure --prefix=/usr/local/php --with-config-file-path=/usr/local/php/etc --with-mysql=/usr/local/mysql --with-mysqli=/usr/local/mysql/bin/mysql_config --with-iconv-dir=/usr --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr/local --enable-xml --disable-rpath --enable-discard-path --enable-safe-mode --enable-bcmath --enable-shmop --enable-sysvsem --enable-inline-optimization --with-curl --with-curlwrappers --enable-mbregex --enable-fastcgi --enable-fpm --enable-force-cgi-redirect --enable-mbstring --with-mcrypt --with-gd --enable-gd-native-ttf --with-openssl --with-mhash --enable-pcntl --enable-sockets --with-xmlrpc --enable-zip --disable-ipv6 --without-pear --with-pgsql=/usr/local/pgsql
make ZEND_EXTRA_LIBS='-liconv'
make install


  3、重新启动php-fpm
引用
/usr/local/php/sbin/php-fpm stop
/usr/local/php/sbin/php-fpm start


  如果没有报错,那么整个PostgreSQL安装以及PHP支持就算是完成了。祝大家安装顺利。
posted @ 2010-09-03 21:15  与时俱进  阅读(640)  评论(0编辑  收藏  举报
友情链接:同里老宅院民居客栈