|
|||||||
|
|||||||
作者:yurt(蒙古包) |
这份手册是我在Solaris7中文版环境下安装配置PHP和SYBASE数据库的心得体会, 整个安装过程总共花费了11天(从11月12号到22号)时间,可谓费尽周折。安装 期间我拜访了国内外无数的网站、BBS、MAILLIST和NEWSGROUP,请教过PHP函数 的作者和SYBASE公司的工程师。在众多热心人的帮助下,我终于把它搞定了,呵 呵。既然是大家的成果,我就不敢一人独享,所以把它写出来,来帮助那些需要 帮助的人。如果我写的这篇文章帮您解决了令您头疼的问题,能不能给我发一张 贺卡,我一定会和您一样高兴的^Y^。 我的E-Mail是 yurt@163.com , yurt@21cn.com 。 =======================所需软件======================= sybase 12.0 for solaris 光盘介质 (下列软件下载地点//www.sunfreeware.com/programlistsparc7.html ) gzip-1.3-sol7-sparc-local.gz (必须) gcc-2.8.1-sol7-sparc-local.gz (必须) libstdc++-2.8.1.1-sol7-sparc-local.gz (必须) make-3.78.1-sol7-sparc-local.gz (可不安装) gd-1.8.3.tar.gz (可选。如不安装GD库,不需下载和GD相关的软件包) php-4.0.2.tar.gz (在//www.php.net/downloads.php下载) apache_1.3.14.tar.gz (在//httpd.apache.org/dist/ 下载) zlib-1.1.3-sol7-sparc-local.gz (安装GD库需要) jpeg-6b-sol7-sparc-local.gz (和GD库相关) libpng-1.0.2-sol7-sparc-local.gz (安装GD库需要) xpm-3.4k-sol7-sparc-local.gz (和GD库相关) 把所有文件放在/export/home目录下。 另外再建一个目录,用于存放编译好的二进制文件: #mkdir /opt/soft ------------------------------------------------- **软件解压及预安装******* 由于solaris7的tar不认识-z选项,可先用WINZIP将gzip-1.3-sol7-sparc-local.gz 解压成gzip-1.3-sol7-sparc-local再ftp到/export/home目录下进行安装。 #cd /export/home #pkgadd -d gzip-1.3-sol7-sparc-local 注意pkgadd在安装时会用到/var/tmp存放临时文件,应保证该分区有足够空间; 如果空间不够,可按以下操作: #mv /var/tmp /var/tmp_old #ln -s /tmp /var (将/var/tmp link到/tmp) 解压并预安装部分软件: #gzip -d gcc-2.8.1-sol7-sparc-local.gz #gzip -d libstdc++-2.8.1.1-sol7-sparc-local.gz #gzip -d make-3.78.1-sol7-sparc-local.gz #pkgadd -d gcc-2.8.1-sol7-sparc-local #pkgadd -d libstdc++-2.8.1.1-sol7-sparc-local #pkgadd -d make-3.78.1-sol7-sparc-local #pkgadd -d zlib-1.1.3-sol7-sparc-local #pkgadd -d jpeg-6b-sol7-sparc-local #pkgadd -d libpng-1.0.2-sol7-sparc-local #pkgadd -d xpm-3.4k-sol7-sparc-local #gzip -dc gd-1.8.3.tar.gz |tar xvf - (将会建立目录gd-1.8.3) #gzip -dc php-4.0.2.tar.gz |tar xvf - (将会建立目录php-4.0.2) #gzip -dc apache_1.3.14.tar.gz |tar xvf - (将会建立目录apache_1.3.14) 然后设置好路径(注意前后顺序) #PATH=/usr/local/bin:/usr/bin:/usr/sbin:/usr/ucb:/usr/ccs/bin #export PATH 至此,编译PHP所需的系统环境已准备妥当。 ------------------------------------------------- ===============安装sybase 12.0并启动SQL SERVER================== 此处略去sybase12.0安装配置过程,sybase12.0安装在/opt/sybase12目录下。 在进行以下步骤前,应保证sybase已正常启动运行。 ------------------------------------------------- ***** 安装GD库 ***** #cd /export/home/gd-1.8.3 #vi Makefile 搜索X11R6,将全部的X11R6替换为X,存盘退出。 #make #make install GD库安装完毕。 如果编译过程出现错误,一定要先 #make clean 然后再重新进行编译(以下同)。 ------------------------------------------------- XXXXXXXXXXXXXXXXXXXXXX 安装PHP4.02 XXXXXXXXXXXXXXXXXXXXXXX #cd /export/home/apache_1.3.14 #./configure --prefix=/opt/soft/apache (指定apache编译后存放在/opt/soft/apache目录下) #cd ../php-4.0.2 (进入php4.0.2源代码目录) #./configure --prefix=/opt/soft/php4 --with-apache=../apache_1.3.14 --with-mysql=no --with-sybase-ct=/opt/sybase12/OCS-12_0 -with-gd -with-zlib-dir -with-jpeg-dir -with-png-dir -with-xpm-dir --enable-track-vars #make (编译) #make install (安装) php4.0.2安装完毕 如果编译出错,仔细查看出错信息。 如果提示没有sybXXX.h之类的文件,可到 //www.sybase.com.cn/htm/cpjs/r_cpbdb_c.htm去下载Solaris平台相应版 本的ebf文件,然后展开到sybase相应目录下再进行编译,如果没有符合的版本, 找略高版本的代替。 ------------------------------------------------- ++++++++++++++++++ 安装Apache 1.3.14+++++++++++++++++++++ #cd /export/home/apache_1.3.14 #./configure --prefix=/opt/soft/apache --activate-module=src/modules/php4/libphp4.a #make #make install Apache 1.3.14完装完毕 #cd ../php-4.0.2 (进入php4.0.2源代码目录) #cp php.ini-dist /usr/local/lib/php.ini (拷贝PHP配置文件到指定目录) ------------------------------------------------- ####################### 修改 httpd.conf ######################## #cd /opt/soft/apache/conf #vi httpd.conf 去掉"AddType application/x-httpd-php .php" 前的"#"号,此时php就可以用了。 去掉"ServerName XXXXX"前的"#"号,此时Apache就可以顺利启动了。 查找index.html所在的行,在index.html后面增加"index.php"(不包含双引号,且 index.html和index.php之间用空格隔开),此时Apache就可以按先index.html后 index.php的顺序查找文件了。 ------------------------------------------------- ***** 修改PHP配置文件 ***** #vi /usr/local/lib/php.ini 搜索default_charset,使其有效,并将其值改为 "gb2312"。 搜索sybase.interfaces_file,使其有效,并将其值改为"/opt/sybase12/interfaces"。 搜索sybct.min_server_severity,将其值改为"50"。 搜索sybct.min_client_severity,将其值改为"50"。 注意:修改完毕重起Apache服务器时,执行以下2个步骤: #/opt/soft/apache/bin/apachectl stop 等几秒钟后再执行 #/opt/soft/apache/bin/apachectl start 不要使用#kill -HUP 或#/opt/soft/apache/bin/apachectl restart重起 服务器。另外,据报告Php4.0.3pl1有Apache服务器不读sybct.min_XXXXX_severity的 bug,所以本文编译的是PHP4.0.2的正式发布版。 ------------------------------------------------- ***** 修改SYBASE12配置文件 ***** #vi /opt/sybase12/interfaces 其内容看起来如下面的样子: SYBASE12 master tli tcp /dev/tcp x00021e84c0a800030000000000000000 query tli tcp /dev/tcp x00021e84c0a800030000000000000000 x00021e84c0a800030000000000000000的含义为: x 表示十六进制 0002 表示以太网(在Dec等机器上可能由于字节顺序不同而写为0200) 1e84 表示SYBASE12监听的服务端口号(十进制为7812) c0a80003 表示SYBASE12的服务器IP地址(点分法表示为192.168.0.3) ------------------------------------------------- 接下来修改客户端默认字符集,使其和SYBASE12服务器的字符集一致: #vi /opt/sybase12/locales/locales.dat 找到sun_svr4所在的段,找到default所在的行: locale = default, us_english, iso_1 将其改为: locale = default, us_english, cp850 如果你的服务器不是使用cp850字符集,请改为相应的字符集。本环境中SYBASE12和 客户端均使用cp850字符集。服务端和客户端字符集不匹配会出现乱码(注意这里所说 的客户端是指Apache服务器,而不是浏览器)。 然后在sybase12环境下使用 #isql -SSYBASE12 -Usa -P -Jcp850和 #isql -Usa -P测试字符集是否匹配。注意如果使用sybase client for Windows进行汉 字插/录入,注意当时客户端使用的字符集。 我在SYBASE字符集上花费了一整天时间才搞定,主要是没有资料可供参考。PHP的网站 上说sybase_connect()有第四个参数可以设定Client的字符集, 调用方法为sybase_connect(ServerName,UserName,Password[,CharSet]),但是无论我 怎么试都提示"参数数目不正确",经过和该函数的作者联系得知: 该函数只支持sybase-DB,不支持sybase-CT。 ------------------------------------------------- ***** 启动Apache服务器 ***** 如果要让Apache监听80端口,必须以root启动httpd服务。 首先修改环境变量,使root具备sybase启动需要的环境: #cd #vi .profile 在export PATH后面加入以下一行 . /opt/sybase12/SYBASE.sh 存盘退出。 #exit 以root重新登录,执行 #/opt/soft/apache/bin/apachectl start (启动Apache服务器) 然后在/opt/soft/apache/htdocs目录下建立一个文件index.php 内容为: 存盘退出。 #chown nobody index.php #chgrp nobody index.php 打这个网址测试一下://ServerName (ServerName即为httpd.conf中的ServerName)。 ------------------------------------------------- ***** 测试sybase数据库 ***** 以webmaster的权限登录,编辑一个文件/opt/soft/apache/htdocs/test.php进行测试, 内容如下: $servername = "SYBASE12"; $username = "sa"; $password = ""; $table = "chat"; $dbName = "www"; sybase_min_server_severity(50); $dbHandle = sybase_connect($servername, $username, $password) or die("连接数据库失败"); sybase_select_db("$dbName") or die( "在服务器上找不到相应数据库。"); $query = sprintf("select * from %s",$table); $result = sybase_query($query); if(!$result)die("查询数据库失败!"); while($field = sybase_fetch_array($result)) { printf("Database:%s ","www"); printf("Table:%s ","chat"); printf("Name:%s ",$field[name]); printf("Date:%s ",$field[date]); printf("Msg:%s ",$field[msg]); } sybase_close($dbHandle); //测试非数据库环境下的中文显示。 echo "蒙古包的缕缕炊烟,轻轻地飘向蓝天,茫茫的绿草地,是我生长的摇篮。 "; ?> 数据库的结构如下: CREATE TABLE dbo.chat ( name varchar(15) NULL, date datetime NULL, msg varchar(200) NULL ) ------------------------------------------------- ***** 测试GD库 ***** 以webmaster的权限登录,编辑一个文件/opt/soft/apache/htdocs/gd.php进行测试, 内容如下: Header("Content-type: image/png"); $im = imagecreate(400,30); $black = ImageColorAllocate($im, 0,0,0); $white = ImageColorAllocate($im, 255,255,255); imageline($im, 1, 1, 350, 25, $black); imagearc($im, 200, 15, 20, 20, 35, 190, $white); imagestring($im, 5, 4, 10, "Graph TEST!!", $white); Imagepng($im); ImageDestroy($im); ?> 1.6.2 版以前的 GD库有支持 GIF 格式的功能,但因为 GIF 格式使用的 LZW 演算法牵 涉到 Unisys 的专利权,因此在1.6.2版之后的 GD 库不再支持 GIF 的格式。本文使用 的是1.8.3版的GD库,因此对GIF格式不支持。 安装配置SYBASE12.0不在本文讨论范围之内,请参考相关文章。 ======================== The End ======================= | ||||||
:查看相关: | |||||||