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