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擴展基本步驟以下:php

一、進入php源代碼目錄:
[root@localhost  /]# # cd cd /usr/local/php-5.3.28

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

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

四、而後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擴展的動態庫存放目錄

五、編譯安裝
[root@localhost mysql]#make 
[root@localhost mysql]#make install

六、編譯完成以後,將會自動把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中的文件名,總之文件名必須一致.

七、重啓apache:
[root@localhost mysql] service httpd restart
或者apache沒有安裝成服務,則進入apache_home執行
[root@localhost mysql]bin/apachectl -k restart



測試php引擎是否成功加載該擴展mysql

編寫文件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代碼測試是否能鏈接mysqlsql

測試.so是否能用變得很是必要。如今測試一下生成的mysql.so是否能用。
<?php
 $link=mysql_connect('192.168.150.214','root','123456');
 if(!$link) echo "connect error!";
 else echo "connected!";
 mysql_close();
 ?> 
運行後,輸出connected 說明鏈接成功!!!

相關文章
相關標籤/搜索