[转帖]CentOs下php连mssql并配置unixODBC_VMware, Unix及操作系统讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  VMware, Unix及操作系统讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 4185 | 回复: 0   主题: [转帖]CentOs下php连mssql并配置unixODBC        下一篇 
ulee@land
注册用户
等级:上尉
经验:769
发帖:55
精华:1
注册:2012-12-17
状态:离线
发送短消息息给ulee@land 加好友    发送短消息息给ulee@land 发消息
发表于: IP:您无权察看 2012-12-18 10:17:24 | [全部帖] [楼主帖] 楼主

CentOsphpmssql并配置unixODBC

公司现在用的数据库比较杂,MS SQLORACLEMYSQL都有在用,之前使用WINDOWS+PHP的环境,这种情况下使用PHPMS SQL是比较容易的,但性能上却比之LAMP差了不少。由此,新工作的主要的事情就是系统及WEB配置的迁移。
但是LAMP环境下,PHPMS SQL却有不少的问题。公司的单点登陆问题就实现不了。更不能体现LAMP较之WAMP的优势。怎么办,BAIDU用吧。却发现很多中文的解决方案,不是版本较老,就是实现不了。后来,选择了GOOGLE,找到了很多E文的解决方案。试着做了,虽说走了些弯路,但最终还是实现了我的需求.

目前,我实面了种情况下的安装:
第一:系统安装时已经安装配置好LAMP。这时重新编译PHP环境相当困难。
我使用RPM 包和TAR包两种方式来安装环境。并不改动PHP的安装及配置,但只能使用ODBC连接MS SQL(数据源)。
第二:系统安装后,使用TAR包安装配置LAMP环境。这时可以重新编译PHP
我使用TAR包来安装,且有重新编译PHP和不重新编译PHP的两种方案。重新编译可以实现直接连接和ODBC连接两种方式。不重新编译可以实现ODBC连接MS SQL(数据源)

这篇博文,以第一种情况,且使用TAR包的方式来安装freetds,以rpm安装unixODBC-develunixODBC。使用ODBC连接MS SQL(数据源)。(要想了解更多的关于php下如何连接MS SQL,以及几种方式就参考www.freetds.org中的HOWTO文档,我接触到的使用了两种一是直接连接,一是odbc。)
一、安装环境
1、CentOs 5.1 + FreeTds0.64.tar.gz + unixODBC-2.2.11-7.1(除了FreeTds是额外的包,其它的都可以使用YUM来安装,或是系统安装时就装好)
2、最好也安装上XWINDOWS,我安装的是GNOME的,因为配置DSN(数据源)时会用上。当然,你也可以在文本界面中配置。
二、部分包的安装及版本显示
1[root@rpm-mssql ~]# rpm -aq grep httpd

system-config-httpd-1.3.3.1-1.el5
httpd-2.2.3-11.el5_1.centos.3


httpd-devel-2.2.3-11.el5_1.centos.3
(这个包包含 Apache HTTP 服务器的包含文件、头文件和 APXS 工具程序。如果你打算载入额外的模块(除了该产品所提供的),你需要它。嘿嘿,如果装PHP时,不要使用TAR包的HTTPD,那就可以使用--with-apxs2=/usr/sbin/apxs.关于此的安装另文说明)

httpd-manual-2.2.3-11.el5_1.centos.3
2、[root@rpm-mssql ~]# rpm -aq grep php
php-cli-5.1.6-15.el5
php-common-5.1.6-15.el5
php-5.1.6-15.el5
php-odbc-5.1.6-15.el5
php-pdo-5.1.6-15.el5
php-pear-1.4.9-4
php-mysql-5.1.6-15.el5
php-ldap-5.1.6-15.el5


你并不需要安装如此之多,根据自已的需求,安装。因为我是系统安装时定制安装成LAMP环境的。
3[root@rpm-mssql ~]# rpm -aq grep unixODBC

unixODBC-devel-2.2.11-7.1 (这个包的作用同httpd-devel,一定要装上啊,安装freetds.tar.gz时要用上的,它会自动寻找unixODBC的安装路径的。否则有可能编译出错。)
unixODBC-2.2.11-7.1
unixODBC-kde-2.2.11-7.1(
同志们,这个要装啊,本来是KDE桌面下的图形配置ODBC数据源的工具。呵呵,在GNOME中也能用的。)


OKmysql的安装包我不多说,因为这里主要是使用ODBCDSN数据源)在LAMP环境下PHPMS SQL的。
4、安装要求的包:

freetds-0.6.tar.gz   http://www.ibiblio.org/pub/Linux/ALPHA/freetds/stable/
unixODBC-kde-2.2.11-7.1
unixODBC-devel-2.2.11-7.1.i386.rpm     yum install -y unixODBC-devel [url=http://mirror.centos.org/centos/5.1/os/i386/CentOS/http://mirror.centos.org/centos/5.1/os/i386/CentOS/[/b[/url]]


三、安装、测试和配置:
1
、安装freetds(均是在root用户下,如果你在其它用户下,记得在运行make installsu - root)
注:在系统安装时要安装上GCC编译器等开发工具及库。不过,在CentOs下少什么就用yum来安装啦。
注:同样的条件可以安装在REDHAT AS5.1 AS5下。

[root@rpm-mssql freetds-0.64]# tar zxvf freetds-0.64.tar.gz
[root@rpm-mssql ~]# cd freetds-0.64
[root@rpm-mssql freetds-0.64]# ./configure --with-tdsver=7.0 --with-unixODBC


以下的要在root用户下执行,尤其是make install

[root@rpm-mssql freetds-0.64]# make;make install
[root@rpm-mssql freetds-0.64]# make clean


ok,
现在已安装好啦。这时会在/usr/local/etc生成freetds.conf文件

[root@rpm-mssql freetds-0.64]# cd /usr/local/etc
[root@rpm-mssql etc]# ll
total 12
-rw-r--r-- 1 root root 3572 Jan 24 19:13 freetds.conf
-rw-r--r-- 1 root root 362 Jan 24 19:13 locales.conf
-rw-r--r-- 1 root root 219 Jan 24 19:13 pool.conf


可以使用ODBCConfig来配置啦
注,在安装unixODBC unixODBC-devel后,就会在/etc生成两个文件odbc.ini odbcinst.ini

[root@rpm-mssql freetds-0.64]# ll /etc/od
odbc.ini odbcinst.ini.rpmnew oddjobd.conf.d/
odbc.ini.rpmnew oddjob/
odbcinst.ini oddjobd.conf


2、测试和配置
A、安装好freetds后,先使用tsql来测试下:

[root@rpm-mssql etc]# /usr/local/bin/tsql -S 211.103.155.xxx -U sa Password:password (xxx是三个数字,为了安全,变了。而:后的password为真实的SA的密码)
locale is "en_US.UTF-8"
locale charset is "UTF-8"
Password: (这里还要再输入一次密码)
1>


如果你足够幸运,呵呵,就会出现“1>”说明你之前的编译正确啦。
接下来就开始真正的进入正题啦,配置freetds.conf
B
、编辑freetds.conf(经测试,这个步骤可以省去。因为装freetds的目的是为了它的驱动。实际上这也暗示着大家采用rpm包安装时需要做些什么啦)

[root@rpm-mssql etc]# vi /usr/local/etc/freetds.conf


加入如下代码,

[MySql2k] (在FreeTds0.64版本中,这个参数很重要。在“System DSN”中,需要用的到。这也是和之前版本的一些差别)
host = 211.103.155.xxx (这个是装有sql server 2k的服务器IP,SQL 2K5也能行)
port = 1433
tds version = 8.0


C
、配置/etc/odbc.ini /etc/odbcinst.ini (注,为了更直观,我使用X视窗的方式下图形配置,当然,我也会把经过图形配置后的ini文件拷配过来)
这里需要用到ODBCConfig /usr/bin/ODBCConfig

[root@rpm-mssql etc]# /usr/bin/ODBCConfig
ODBCConfig: cannot connect to X server


D
、切换到X WINDOWS,前面说过,使用的是GNOME,各位亦可以使用KDE。君不见unixODBC-kde就是为KDE专门做的嘛。

[root@rpm-mssql etc]# /usr/bin/ODBCConfig后,出现如下图,图示中有说明。但要声明的是,我使用的FreeTds的版本是0.64的,和前一版本0.63有些使用上的差别。主要是"Servername"的变化,以及"Setup"的变化。在接下来的一系列图示中,会分别说明。


安装FreeTds的目的,就是为了提供PHP连接MSSQL的驱动的。上面所有的动作,就是为此做准备的。驱动有了装载的路径,就要增加数据源,以使连接MSSQL成功。
接下来的EF就是重点的以图文并茂的方式来说明的。
E、图形设置Driver的过程,就是配置/etc/odbcinst.ini的过程。
freetds0.64版本增加了对64位数据库的支持。

下面的是图形配置后的odbcinst.ini的文件,其中MySql2k是新增加地:

[root@rpm-mssql ~]# cat /etc/odbcinst.ini
[PostgreSQL]
Description = ODBC for PostgreSQL
Driver = /usr/lib/libodbcpsqlS.so
Driver64 = /usr/lib
Setup = /usr/lib
Setup64 = /usr/lib
UsageCount = 1
CPTimeout =
CPReuse =
[MySql2k]
Description = v0.64 with Protocol v8.0
Driver = /usr/local/lib/libtdsodbc.so
Driver64 = /usr/local/lib/libtdsodbc.so
Setup = /usr/lib/libtdsS.so
Setup64 = /usr/lib/libtdsS.so
UsageCount = 1
CPTimeout =
CPReuse =


FDSN数据源建立及注意事项:
图形设置"System DSN"的过程,是配置/etc/odbc.ini文件的过程:

下面的是图形配置"System DSN"后,odbc.ini的文件,如果没有或是不想安装X 视窗的话,直接设置。

[root@rpm-mssql ~]# cat /etc/odbc.ini
[mssql]
Description = MySql2k
Driver = MySql2k
Servername = MySql2k (这里,不要设置IP地址什么的,要和FREETDS.CONF里的设置一样,至少我试的就是如此,在FREETDS0.63中并没有此现象。)
Database =
UID = sa
PWD =
Port = 1433


G、isql 测试:

成功了,呵呵,实际上这篇文章也可以就此打住啦。不过。还是实测下PHPMS SQL的效果吧
Hphp页面测试

[root@rpm-mssql ~]# vi /var/www/html/phpmssql.php




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论