Linux CentOS 7 安裝php

安裝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();
?>
~

複製代碼

 

相關文章
相關標籤/搜索