linux下為已經編譯好的php環境添加mysql擴展(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源代碼目錄:
[root@localhost  /]# # cd cd /usr/local/php-5.3.28

2、再進入要添加的mysql擴展源碼目錄:
[root@localhost  php-5.3.28]cd ext/mysql/
[root@localhost  mysql]# yum install autoconf  (CentOS 5.4需安裝)

3、調用已經編譯好的php可執行程序phpize:
[root@localhost  mysql] /usr/local/php/bin/phpize

4、然后configure:
[root@localhost 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、編譯安裝
[root@localhost mysql]#make 
[root@localhost 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:
[root@localhost mysql] service httpd restart
或者apache沒有安裝成服務,則進入apache_home執行
[root@localhost 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 說明連接成功!!!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM