問題背景
平常我們都是先安裝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 說明連接成功!!!