热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Apache+php3+PostgreSQL的安装

以下将说明使用Apache+PHP3+PostgreSQL作为基于Web的数据库平台的安装和配置方法。关于Apache、PHP3和PostgreSQL的更多内容可以从软件的附带文档、Linux的HOWTO文件以及以下站点处找到:Apache:http://www.apache.orgPHP3:http://www.ph
EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

Apache + php3 + PostgreSQL的安装
时间:2006-02-27 00:00 来源:网管之家bitsCN.com 字体:[ ] 评论:
标签:ApachePostgreSQL

以下将说明使用Apache+PHP3+PostgreSQL作为基于Web的数据库平台的安装和配置方法。关于Apache、PHP3和PostgreSQL的更多内容可以从软件的附带文档、Linux的HOWTO文件以及以下站点处找到:

Apache: http://www.apache.org

PHP3: http://www.php.net

PostgreSQL: http://www.postgresql.org


1. PostgreSQL的安装和设置

1.1 获得源程序


----PostgreSQL最新版本的源程序可以在http://www.postgresql.org找到。目前的最新版本是6.5.X。以下以6.4 版为例说明安装方法。

---- 1.2 准备工作

---- 编译PostgreSQL需要3.75版以上的GNU make (用gmake -v检查版本号) ,2.7.2版以上的 GNU C(用gcc -v 检查版本号)以及bison和flex(通常这两种工具都已经安装) 。

---- PostgreSQL的默认安装位置为/usr/local/pgsql/,系统文件约需3-10M空间。附带的测试程序在运行时需要约20M空间,所以安装时应注意预留足够的空间,建议/usr/local/pgsql/ 目录下保证有50M以上空间。另外展开和编译源程序约需30-60M空间。

---- 对多用户的应用环境,建议设置一个专用用户名,例如 postgres :

---- $ su 首先登录为root

---- # /usr/sbin/adduser postgres

---- 另外PostgreSQL使用了System V的共享内存机制。FreeBSD默认状态不支持该机制。如使用中的内核的设置文件中无以下项目则需追加后重新编译内核:

options SYSVSHM

options SYSVSEM

options SYSVMSG


建保存源程序的目录/usr/local/src/pgsql和

安装目录/usr/local/pgsql:

#mkdir /usr/local/pgsql

#chown postgres:postgres /usr/local/pgsql

#mkdir /usr/local/src

#mkdir /usr/local/src/pgsql

#chown postgres:postgres /usr/local/src/pgsql


1.3 编译

以postgres用户登录, 解压缩源程序:

# su postgres

$ tar -xzvf /tmp/postgresql-v6.4.tar.gz

[假设下载文件保存在/tmp目录下]

完成后应生成一个postgresql-v6.4目录,下面开始编译:

$ cd /usr/local/src/pgsql/postgresql-v6.4/src

$ ./configure --with-mb=EUC_CN


---- 其中,--with-mb=指定系统默认字符编码。除GB码(EUC_CN) 外,还可以指定为日语 (EUC_JP)、韩语(EUC_KR) 、台湾(EUC_TW) 、UNICODE、MULE_INTERNAL、LATIN1等。

---- 注意,如使用6.3.2版需用--with-template=... 指定操作系统,具体内容见源程序附带的说明文件。

---- configure如顺利完成,将生成GNUmakefile,Makefile.global和Makefile.port等文件。 $ gmake all在编译结束后将显示以下信息:

All of PostgreSQL is successfully made. Ready to install.

安装:

$ gmake install


---- 正常完成后,PostgreSQl的执行文件和库文件等将被安装到/usr/local/pgsql目录下。

安装附带文档:

$ gmake install-man

$ cd /usr/local/src/postgresql-v6.4/doc

$ make install

至此PostgreSQL的编译安装已经完成,下面开始初期设置。


1.4 初期设置

设置环境变量:

如使用的shell为bash, 则在.bashrc中添加以下命令:

PATH="$PATH":/usr/local/pgsql/bin

export POSTGRES_HOME=/usr/local/pgsql

export PGLIB=$POSTGRES_HOME/lib

export PGDATA=$POSTGRES_HOME/data

export MANPATH="$MANPTH":$POSTGRES_HOME/man

export LD_LIBRARY_PATH="$LD_LIBRARY_PATH":"$PGLIB"

然后执行 source ~/.bashrc

如使用的shell为csh/tcsh则在.cshrc中添加以下命令:

setenv PATH="$PATH":/usr/local/pgsql/bin

setenv POSTGRES_HOME=/usr/local/pgsql

setenv PGLIB=$POSTGRES_HOME/lib

setenv PGDATA=$POSTGRES_HOME/data

setenv MANPATH="$MANPTH":$POSTGRES_HOME/man

setenv LD_LIBRARY_PATH="$LD_LIBRARY_PATH":"$PGLIB"

然后执行 source ~/.cshrc

以上环境变量是所有使用数据库的用户都需要设置的。

数据库目录的初始化:

$ initdb

可以使用的参数:

--pgdata=/pgsql/db 指定数据库目录,

默认使用环境变量PGDATA指定的位置

--pgencoding=EUC_CN 指定数据库的字符编码,

默认使用configure时指定的编码。

 

---- 需要注意的是执行initdb的用户将拥有所建数据库目录的管理权。

使用以下命令启动PostgreSQL:

$ postmaster -S

运行测试程序:

$ cd test/regression

$ gmake all runtest

如测试程序能正常运行则说明PostgreSQL能正常运行。

为了让 PostgreSQL在系统启动时能自动启动,需作以下变更:

首先以root登录

$ su

Linux: 在/etc/rc.d/rc.local中追加以下内容:

POSTGRESDIR=/usr/local/pgsql

if [ -x $POSTGRESDIR/bin/postmaster -a

-d $POSTGRESDIR/data ];then

rm -f /tmp/s.PGSQL.5432

su - postgres -c "postmaster -S -i"

echo -n 'postmaster'

fi

FreeBSD: 在/usr/local/etc/rc.d中建立名为

pgsql.sh的文件,内容为:

#! /bin/sh

POSTGRESDIR=/usr/local/pgsql

if [ -x $POSTGRESDIR/bin/postmaster

-a -d $POSTGRESDIR/data ];then

rm -f /tmp/s.PGSQL.5432

su - postgres -c "postmaster -S -i"

echo -n 'postmaster'

fi

修改pgsql.sh文件的权限:

# chmod 755 pgsql.sh

 

---- 现在PostgreSQL的安装和设定基本已经完成了,但是目前为止能使用数据库的用户只有postgres。

---- 为使其他用户可以使用数据库,需要登录数据库用户和生成用户数据。

---- 例如通过Web服务器Apache进行查询的用户,用户名为nobody:

% createuser nobody

Enter user's postgres ID or RETURN to use unix

user ID: 1000 ->1000

Is user "nobody" allowed to create dataase(y/n)n

Is user "nobody" allowed to add users?(y/n)n

createuser: nobody was successfully added

 

---- 删除用户可以使用命令destroyuser 用户名

---- PostgreSQL可以同时管理多个数据库(但数据库之间不能进行join等操作)。新建数据库:

---- $ createdb 数据库名

---- 新建的数据库将被放在/usr/local/pgsql/data/base的同名目录下(环境变量PGDATA指定路径的base目录下)。如省略数据库名参数,将自动以用户名作为数据库名。

---- 例如 名为db1的数据库将被保存在/usr/local/pgsql/data/base/db1目录下。也

可使用initlocation命令指定其他位置:

$ initlocation /pgsql/data

$ export PGDATA2=/pgsql/data

$ createdb -D PGDATA2 db2

 

---- 则数据库db2将被保存在/pgsql/data目录下。另外PostgreSQL 6.4版可以在建立数据库时指定文字编码:

createdb -E “字符编码” “字符编码” 参见configure、initdb。

删除数据库:destroydb 数据库名

PostgreSQL最基本的数据库管理工具是

pgsql. 基本使用方法:pgsql 数据库名

 

---- 1.5 安全设置:

---- PostgreSQL提供了基于主机的认证方式host based authentication(HBA) 、基于口令的用户身份认证和用户操作权限设置等安全机制。

---- 1.5.1 HBA方式和基于口令的用户身份认证方式

---- HBA方式的设置文件为pg_hba.conf。其格式为:

---- host DBNAME IP_ADDRESS ADDRESS_MASK USRAUTH [AUTH_ARGUMENT]

---- host: 固定标志,不能修改

---- DBNAME: 数据库名,all代表所有数据库

---- IP_ADDRESS,ADDRESS_MASK:指定IP地址,也可指定子网,如

192.168.10.0/255.255.255.0

---- USERAUTH: 对用户的认证方式,包括ident(RFC1413) 、trust(不进行认证) 、reject (拒绝符合条件的访问) 、password [passwd_file](根据flat file口令文件进行认证) 、 crypt(使用PostgreSQL的系统数据库pg_shadow进行认证) 、kbr4/kbr5(Kerberos V4/V5认证) 。如在作为Web 数据库使用, 使用passwd口令文件进行本地登录时可如下设置:

---- Host all 127.0.0.1 255.255.255.255 password passwd

---- passwd文件默认位置为/usr/local/pgsql/data, 有数据库管理权限的用户可以使用

---- pg_passwd命令管理该文件(注意:flat file口令认证方式采用明文传送口令,故要从网络上其他主机登录,建议使用crypt认证方式) 。

---- 1.5.2 用户操作权限设置

---- 使用SQL命令grant/revoke可以设置用户/用户组可否使用

select/insert/update/rule命令。

---- 根据SQL标准,一个数据表文件(table) 在刚建立时只有建立该表文件的用户有权访问。要分配给用户访问权限,可以使用grant命令:

grant <权限种类 > on to <用户/组 >

权限种类:all,select,insert,update,delete,rule

table名:被设置用户访问权限的表文件

用户/组:public(所有用户) 或用户名/组名

revoke命令作用与grant命令相反,用法如下:

revoke <权限种类> on from <用户/组>

table已设置的用户权限可以使用pgsql的\z 命令查看。

 

---- 2. Apache+PHP3的安装及设置

---- 2.1 源程序

---- Apache和PHP3的最新版本源程序可以从http://www.apache.org/

http://www.php.net/找到。

---- 以下以Apache 1.3.6和PHP3 3.0.5 为例。

---- 2.2 编译

---- 假设Apache和PHP3的源程序都保存在/tmp目录下,首先登录为root:

$ su

# cd /usr/local/src

# tar -xzvf /tmp/apache_1.3.6.tar.gz

# ./configure

# cd /usr/local/src

# tar -xzvf /tmp/php3-3.0.5.tar.gz

# cd php-3.0.5

# ./configure --with-pgsql --with-apache=

../apache_1.3.6 --enable-track-vars

# make

# make install

最后一步将建立/usr/local/src/apache_1.3.6/

src/modules/php3目录,并将以下文件

复制到该目录下:

Makefile.libdir libmodphp3.a mod_php3.c php_version.h

Makefile.tmpl libphp3.module mod_php3.h

编译和安装Apache:

设置环境变量LD_LIBRARY_PATH csh和tcsh shell使用以下命令:

# setenv LD_LIBRARY_PATH /usr/local/pgsql/lib

sh和bash使用如下命令:

# LD_LIBRARY_PATH=/usr/local/pgsql/lib

# export LD_LIBRARY_PATH

然后

# cd /usr/local/src/apache_1.3.6

# ./configure --activate-module=src/modules/php3/libphp3.a

# make

# make install

2.3 修改设置文件

# cd /usr/local/src/php-3.0.5

# cp php3.ini-dist /usr/local/lib/php3.ini

将/usr/local/apache/etc/srm.conf中以下两行内容前的#号删除,

如果以.php3作为PHP3文件的扩展名,则将.phtml 更改为 .php3:

#AddType application/x-httpd-php3 .php3

#AddType application/x-httpd-php3-source .phps

在srm.conf文件的DirectoryIndex下增加 index.php3:

DirectoryIndex index.html index.php3


2.4 启动Apache

# /usr/local/apache/sbin/apachectl start

apachectl start: httpd started


---- 在本地机上启动网络浏览器,地址栏输入http://localhost/(或在其他计算机上的浏览器地址栏输入Apache服务器地址),如能显示出Apache的开始画面则说明Apache已经安装成功。下面测试PHP3模块工作是否正常:

# cd /usr/local/apache/share/htdocs/

# ln -s /usr/local/src/php-3.0.5 .

然后在浏览器的地址栏输入

http://localhost/php-3.0.5/examples/date.php3


---- 观察php3文件的运行结果是否正常。如日期函数能显示正确结果,则说明PHP3模块工作正常。

---- 至此,基于Apache Web服务器和服务器端脚本语言PHP3的PostgreSQL数据库系统的安装已经完成 :-)


推荐阅读
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 本文详细介绍了如何通过多种编程语言(如PHP、JSP)实现网站与MySQL数据库的连接,包括创建数据库、表的基本操作,以及数据的读取和写入方法。 ... [详细]
  • 本文详细介绍了IBM DB2数据库在大型应用系统中的应用,强调其卓越的可扩展性和多环境支持能力。文章深入分析了DB2在数据利用性、完整性、安全性和恢复性方面的优势,并提供了优化建议以提升其在不同规模应用程序中的表现。 ... [详细]
  • PHP 编程疑难解析与知识点汇总
    本文详细解答了 PHP 编程中的常见问题,并提供了丰富的代码示例和解决方案,帮助开发者更好地理解和应用 PHP 知识。 ... [详细]
  • 深入理解OAuth认证机制
    本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
  • 本文详细分析了JSP(JavaServer Pages)技术的主要优点和缺点,帮助开发者更好地理解其适用场景及潜在挑战。JSP作为一种服务器端技术,广泛应用于Web开发中。 ... [详细]
  • Windows服务与数据库交互问题解析
    本文探讨了在Windows 10(64位)环境下开发的Windows服务,旨在定期向本地MS SQL Server (v.11)插入记录。尽管服务已成功安装并运行,但记录并未正确插入。我们将详细分析可能的原因及解决方案。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 解决PHP与MySQL连接时出现500错误的方法
    本文详细探讨了当使用PHP连接MySQL数据库时遇到500内部服务器错误的多种解决方案,提供了详尽的操作步骤和专业建议。无论是初学者还是有经验的开发者,都能从中受益。 ... [详细]
  • 在哈佛大学商学院举行的Cyberposium大会上,专家们深入探讨了开源软件的崛起及其对企业市场的影响。会议指出,开源软件不仅为企业提供了新的增长机会,还促进了软件质量的提升和创新。 ... [详细]

author-avatar
无痕
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有