ホームページ >データベース >mysql チュートリアル >SQL Relay开源的数据库池连接代理服务器

SQL Relay开源的数据库池连接代理服务器

WBOY
WBOYオリジナル
2016-06-07 15:15:521463ブラウズ

一、SQL Relay是什么? SQL Relay是一个开源的数据库池连接代理服务器 二、SQL Relay支持哪些数据库? * Oracle * MySQL * mSQL * PostgreSQL * Sybase * MS SQL Server * IBM DB2 * Interbase * Sybase * SQLite * Lago * ODBC * MS Access 三、安装和配置

一、SQL Relay是什么?

SQL Relay是一个开源的数据库池连接代理服务器


二、SQL Relay支持哪些数据库?

<span> * Oracle<br>* MySQL<br>* mSQL<br>* PostgreSQL<br>* Sybase<br>* MS SQL Server<br>* IBM DB2<br>* Interbase<br>* Sybase<br>* SQLite<br>* Lago<br>* ODBC<br>* MS Access</span>


三、安装和配置;

不说废话了,开始安装SQL Relay,到 http://sqlrelay.sourceforge.net/ 去下载相应的软件
安装SQL Relay需要先安装Rudiments, 在 http://sqlrelay.sourceforge.net/download.html 可以找到


1、安装Rudiments:

<span># tar vxzf rudiments-0.28.2.tar.gz<br># cd rudiments-0.28.2<br># ./configure --prefix=/usr/local/rudiments<br># make<br># make install</span>

至此,rudiments安装结束


2、安装SQL Relay:

<span># tar vxzf sqlrelay-0.36.4.tar.gz<br># cd sqlrelay-0.36.4<br># ./configure --prefix=/usr/local/sqlrelay --with-rudiments-prefix=/usr/local/rudiments --with-mysql-prefix=MySQL安装路径 --with-freetds-prefix=FreeTDS安装路径 --with-oracle-home=Oracle安装路径 --with-php-prefix=PHP安装路径<br># make<br># make install</span>

安装结束,以上编译参数根据个人需要来设定,因为我同时需要Oracle SQLserver MySQL,所以才加了这么多参数的

3、设置PHP:

修改php.ini

<span>extension_dir = "./"</span>

把以上内容修改为:

<span>extension_dir = "/usr/local/php/lib/php/extensions/no-debug-non-zts-20050922"</span>

根据PHP安装的路径来修改,并不是每个版本的PHP都是这个路径
在php.ini中添加如下内容

<span>extension=sql_relay.so</span>

接下来,介绍SQL Relay如何连接SQL Server
修改FreeTDS的配置文件freetds.conf
加入如下内容:

<span>[msde]<br>host = 172.16.20.203<br>port =1433<br>tds version = 8.0<br>client charset = GB2312</span>

请根据个人需求来修改


4、修改SQL Relay的配置文件

<span># cd /usr/local/sqlrelay/etc<br># cp sqlrelay.conf.example sqlrelay.conf</span>

把sqlrelay.conf的内容改为:

<span><?xml version="1.0"?><br><br><br><br><br><br><br><br><br><br><br></span>


四、启动SQL Relay,并测试;


1、启动 SQL Relay

<span># export PATH=$PATH:/usr/local/sqlrelay/bin<br># sqlr-start -id msdetest</span>


2、使用SQL工具:

<span># sqlrsh -id msdetest</span>

可以直接输入SQL语句

停止SQL Relay:

<span># sqlr-stop msdetest</span>


3、测试PHP:

写一个PHP文件,内容如下:

<span><br>$con=sqlrcon_alloc("msdetest",9000,"/tmp/msdetest.socket","sa","sa",0,1);<br>$cur=sqlrcur_alloc($con);<br>sqlrcur_sendQuery($cur,"select * from t_gifts");<br>for ($row=0; $row<sqlrcur_rowcount></sqlrcur_rowcount>for ($col=0; $col<sqlrcur_colcount></sqlrcur_colcount>echo sqlrcur_getField($cur,$row,$col);<br>echo ",";<br>}<br>echo "<br>\n";<br>}<br>sqlrcur_free($cur);<br>sqlrcon_free($con);<br>?></span>

执行这个PHP文件,看看能不能出现数据
全文结束~~

 

参考:http://hi.baidu.com/mrvsumbeujeinxe/item/8ba0c60888cf47c490571896

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。