安裝PHP
一、 下載
http://www.php.net/downloads.php
二、解壓
tar -zxvf php-5.3.16.tar.gzphp
獲取安裝php須要的支持文件:http://download.csdn.net/download/netlong339/1351852 libxml2-2.6.32.tar.gzhtml
安裝libxml2mysql
tar zxvf libxml2-2.6.32.tar.gz cd libxml2-2.6.32 ./configure --prefix=/usr/local/libxml2 make make install
若是安裝成功之後,在/usr/local/libxml2/目錄下將生成bin、include、lib、man和share五個目錄。在後面安裝PHP5源代碼包的配置時,會經過在configure命令的選項中加上"--with-libxml-dir=/usr/ local/libxml2"選項,用於指定安裝libxml2庫文件的位置linux
三、創建目標文件夾
mkdir /usr/local/php
也就是說等下安裝的php要安裝到這個文件夾裏面
四、配置
回到原來解壓後的文件夾
./configure --prefix=/usr/local/php --with-apxs2=/usr/local/apache/bin/apxs --with-libxml-dir=/usr/local/libxml2web
注意這裏有一個-with-apxs2=/usr/local/apache/bin/apxs選項,其中apxs是在安裝Apache時產生的,apxs
是一個爲Apache HTTP服務器編譯和安裝擴展模塊的工具,使之能夠用由mod_so
提供的LoadModule
指令在運行時加載到Apache服務器中。個人理解是經過這個工具把PHP模塊動態加載到Apache中sql
出現錯誤:configure: error: xml2-config not found. Please check your libxml2 installation.數據庫
運行yum install libxml2,而後再運行yum install libxml2-devel安裝完畢後,從新運行上面的./configure命令。apache
五、編譯
make
六、測試編譯
make test
七、安裝
make install瀏覽器
八、配置文件服務器
cp /usr/local/src/php-5.3.16/php.ini-development /usr/local/php/lib/php.ini
把原來位於源代碼裏面的php.ini-development拷貝到/usr/local/php/lib/php.ini下,而且重命名爲php.ini
9.重啓apache
十、測試
在apache的htdocs下創建一個php文件test.php,裏面的內容以下:
<?php
phpinfo();
?>
而後在瀏覽器裏輸入http://127.0.0.1/test.php
若是出現php的相關配置,成功,若是什麼都沒有輸入,說明失敗,從新以上步驟或者查找緣由
若是決定在安裝後改變配置選項,只需重複最後的三步configure, make, 以及 make install,而後須要從新啓動 Apache 使新模塊生效。Apache不須要從新編譯。
測試結果以下圖:
3、安裝MySql
一、下載
到官網下載mysql-5.1.65.tar.gz(注意是源碼包)
二、解壓
tar -zxvf mysql-5.1.65.tar.gz
三、創建目標文件夾
mkdir /usr/local/mysql
也就是說等下安裝的mysql要安裝到這個文件夾裏面
四、配置
./configure --prefix=/usr/local/mysql/
在./configure時出現錯誤:error: No curses/termcap library found
下載安裝相應軟件包
yum list|grep ncurses
yum -y install ncurses-devel
yum install ncurses-devel
五、編譯
make
六、安裝
make install
七、啓動
MySQL服務並不會自動啓動,還須要先初始化MySQL數據庫,操做以下:
cd /usr/local/mysql/bin
sudo ./mysql_install_db --user=root
注意,這裏最後的root是指能夠操做數據庫的用戶,能夠是當前用戶,也能夠新建用戶,與linux上的root用戶是兩回事,能夠本身取一個名字
./mysqld_safe --user=root & 這條命令負責啓動mysql服務的守護進程,此外最後的&時必須的,由於但願守護進程在後臺運行
這裏的root就是剛纔的那個
八、爲根用戶建立密碼
./mysqladmin -u root password ‘123456’
若是root已經設置過密碼,採用以下方法
./mysqladmin -u root password oldpass ‘123456’
九、測試
mysql -u root -p
會提示輸入密碼,就用剛纔設置的密碼
123456
若是出現mysql>,說明鏈接成功了,下面經過命令 建立一個數據庫、建一個表,增長一條記錄,爲後面的測試準備
mysql> create database gywtest;
mysql> use gywtest;
mysql> create table student(id int(4) not null primary key auto_increment,stuname char(20));
mysql> insert into student(stuname) values('Tom');
注意每條命令後面有個分號,若是上面的都成功,後面就能夠用這個測試。
4、將PHP與MySql結合起來
一、從新配置PHP,改變配置選項,只需重複PHP安裝時的最後的三步configure, make, 以及 make install,而後須要從新啓動 Apache 使新模塊生效,Apache不須要從新編譯。
二、配置
./configure --prefix=/usr/local/php --with-apxs2=/usr/local/apache2/bin/apxs --with-mysqli=/usr/local/mysql/bin/mysql_config 注意mysql_config 的路徑
三、編譯 make
四、安裝 make installe
五、測試 寫一個頁面test.php,放在apache的web目錄下,測試上面用命令建立的數據庫
<?php
$mysqli=new mysqli();
$mysqli->connect('localhost','root','123456','gywtest');
// 建立查詢
$sqlstr='select * from student';
//發送查詢給MySql
$result=$mysqli->query($sqlstr);
while($row=$result->fetch_object())
{
$name=$row->stuname;
echo $name;
}
?>
Fatal error: Class 'mysqli' not found in /home/lufangtao/Project/DB.php on line 3
解決方法:
/usr/local/php/bin/phpize 這裏回車運行
出錯:
Cannot find config.m4.
Make sure that you run './phpize' in the top level source directory of the module
解決方法:
PHP源碼包文件夾下的EXT文件夾就是放置着目前版本的可用擴展,CD進去看看都有哪些你須要的?應該看到mysqli文件夾了吧~~~
在當前目錄下執行phpize
[root@localhost mysqli]#/usr/local/php/bin/phpize
Configuring for:
PHP Api Version: 20090626
Zend Modeule Api No: 20090626
Zend Extension Api No: 220090626
Cannot find autoconf. Please check your autoconf installation and the
$PHP_AUTOCONF environment variable. Then, rerun this script.
解決方法:
yum install autoconf再次運行上面的命令便可。
[root@localhost mysqli]#./configure –prefix=/opt/mysqli –with-php-config=/opt/php/bin/php-config –with-mysqli=/opt/mysql/bin/mysql_config
[root@localhost mysqli]#make
[root@localhost mysqli]#make install
安裝完成後會有提示擴展所在目錄路徑,如:
/opt/php/lib/php/extensions/no-debug-zts-20090626php
所需的mysqli.so便會在此目錄下,接下來修改/opt/php/etc/下的php.ini文件,加入mysqli擴展,即加入以下一行:
extension=/opt/php/lib/php/extensions/no-debug-zts-20090626/mysqli.so
這裏仍是回出現錯誤:
參考博客http://www.cnblogs.com/wangtao_20/archive/2011/03/07/1973621.html
解決不用擴展鏈接MySQL的方法。
最終仍是沒有解決MySQLi鏈接的問題,可是能夠使用MySQL數據庫了,下面是測試程序
<?php $link=mysql_connect('localhost','root','123456'); if(!$link) echo "F!"; else echo "S!"; mysql_select_db("students") or die("Could not select database"); $query="SELECT * FROM student;"; $result=mysql_query($query) or die("Query failed"); print "<table>\n"; while ($line = mysql_fetch_array($result, MYSQL_ASSOC)) { print "\t<tr>\n"; foreach ($line as $col_value) { print "\t\t<td>$col_value</td>\n"; } print "\t</tr>\n"; } print "</table>\n"; /* 釋放資源 */ mysql_free_result($result); mysql_close(); ?> ~