1. 程式人生 > >linux下php安裝完成後如何整合mysql擴充套件

linux下php安裝完成後如何整合mysql擴充套件

問題背景
平常我們都是先安裝mysql,然後才能去安裝php。假如先安裝php,後安裝mysql,由於php需要連線mysql,因而在php引擎中需要配置使用mysql.so擴充套件。這時需要手動編譯生成mysql.so擴充套件。

解決方案
使用phpize工具能夠生成mysql.so,但是必須加上"--with-mysql=mysql客戶端的路徑"。也就是mysql.so模組必須用到mysql客戶端才行。
可以這樣理解,mysql.so內部會呼叫mysql客戶端,以便實現連線mysql資料庫伺服器。
我們常常用到的mysql_connect()可能就是呼叫了mysql客戶端才能完成連線資料庫的操作。

實踐生成mysql.so的過程


大體思路:需要用到php的原始碼包才行。通過原始碼包中提供的phpize檔案(一個專門掛接php擴充套件的工具),phpize的規則:去哪個目錄下執行phpize檔案,那麼就會在該目錄下生成一個configure檔案。

具體的安裝步驟如下
php安裝完成後新增mysql擴充套件基本步驟如下:

1、進入php原始碼目錄:
[[email protected]  /]# # cd cd /usr/local/php-5.3.28

2、再進入要新增的mysql擴充套件原始碼目錄:
[[email protected]  php-5.3.28]cd ext/mysql/
[[email protected]
mysql]# yum install autoconf (CentOS 5.4需安裝) 3、呼叫已經編譯好的php可執行程式phpize: [[email protected] mysql] /usr/local/php/bin/phpize 4、然後configure: [[email protected] mysql]# ./configure --with-php-config=/usr/local/php/bin/php-config --with-mysql=/usr/local/mysql/ --with-zlib-dir=/usr/local/lib 注意: /usr/local/mysql 為mysql的安裝目錄 /usr/local/lib/php/extensions/no-debug-non-zts-20090626/ 為php擴充套件的動態庫存放目錄 5、編譯安裝 [
[email protected]
mysql]#make [[email protected] mysql]#make install 6、編譯完成之後,將會自動把mysql.so放到了預設的php擴充套件目錄下(phpinfo可檢視,我的為 /usr/local/php/lib/php/extensions/no-debug-zts-20090626),再修改php.ini,去掉;extension=mysql.so前面的分號。如果沒有這句,需要自行新增。 不過有一點需要注意的是,生成的模組名叫mysql.so,跟php.ini裡面的php_mysql.so名字不一致,必須把mysql.so改名為php_mysql.so,也可修改php.ini中的檔名,總之檔名必須一致. 7、重啟apache: [[email protected] mysql] service httpd restart 或者apache沒有安裝成服務,則進入apache_home執行 [[email protected] mysql]bin/apachectl -k restart



測試php引擎是否成功載入該擴充套件

編寫檔案phpinfo.php,內容是:
<?php 
ehco phpinfo(); 
?>

執行後,可以看到有如下資訊顯示:

mysql
MySQL Support    enabled
Active Persistent Links     0
Active Links     0
Client API version     5.1.55
MYSQL_MODULE_TYPE     no value
MYSQL_SOCKET     /tmp/mysql.sock
MYSQL_INCLUDE     no value
MYSQL_LIBS     no value
通過這樣的方式可以確認,php引擎已經成功載入了mysql.so擴充套件。



已經生成的mysql.so。編寫php程式碼測試是否能連線mysql

測試.so是否能用變得非常必要。現在測試一下生成的mysql.so是否能用。
<?php
 $link=mysql_connect('192.168.150.214','root','123456');
 if(!$link) echo "connect error!";
 else echo "connected!";
 mysql_close();
 ?> 
執行後,輸出connected 說明連線成功!!!