Linux下安裝、配置PHP環境和MySQL數據庫?

Tags: 數據庫, 環境,

參考別人的做法,遇到問題上網查,下面就是安裝步驟.

工具/原料

平臺:VMware上虛擬的centos4.7

宿主機:windows

安裝Apache2.2.22

到官網下載

解壓 tar -zxvf httpd-2.2.22.tar.gz

建立目標文件夾(注意以下所有操作都時在root用戶下執行的) mkdir /usr/local/apache2 也就是說等下安裝的apache2要安裝到這個文件夾裡面

配置 回到原來解壓之後產生的文件夾 ./configure --prefix=/usr/local/apache2 --enable-module=shared 要加上後面的參數,否則無法使用php,-enable-module=shared表示Apache可以動態的加載模塊

這一步,出現了很多問題:

第一個錯誤為:

checking for APR... no configure: error: APR not found. Please read the documentation.解決方法:download the latest versions of both APR and APR-Util from Apache APR, unpack them into ./srclib/apr and ./srclib/apr-util (be sure the domain names do not have version numbers; for example, the APR distribution must be under ./srclib/apr/)

then do

./configure --with-included-apr

另外一種解決方法為:分別安裝APR和APR-util,安裝方法為:首先下載這兩個文件,然後解壓,進入解壓後目錄,然後把APR和APR-util分別安裝到/usr/local/文件夾的apr和apr-util文件夾下。APR的具體安裝方法為:[[email protected] 52lamp]# tar -zxvf apr-1.4.2.tar.gz //unzip -o apr-1.4.2.zip[[email protected] 52lamp]# cd apr-1.4.2[[email protected] apr-1.4.2]# ./configure --prefix=/usr/local/apr[[email protected] apr-1.4.2]# make[[email protected] apr-1.4.2]# make install安裝Apr-util 在./confiure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr其他步驟類似。

第二個錯誤為:no acceptable C compiler found in $Path直接運行 yum install gcc,安裝Gcc即可第三個問題為:pcre-config for libpcre not found解決方法就是 下載prce安裝包,和APR類似,安裝到/usr/local/pcre文件夾下面即可。PS:fedora下安裝c++編譯器g++的命令為:yum install gcc-c++ 。

編譯 make

安裝 make install

啟動,重啟和停止 ,先切換到安裝完成後的目錄/usr/local/apache2/bin ./apachectl -k start ./apachectl -k restart ./apachectl -k stop

配置文件(滿足最基本的配置) 編輯 /usr/local/apache2/conf/httpd.conf 文件 找到: AddType application/x-compress .Z AddType application/x-gzip .gz .tgz 在後面添加: AddType application/x-httpd-php .php(使Apcche支持PHP) AddType application/x-httpd-php-source .php5 找到: DirectoryIndex index.html 添加: DirectoryIndex index.html index.php 找到: #ServerName www.example.com:80 修改為: ServerName 127.0.0.1:80或者ServerName localhost:80 記得要去掉前面的“#”

測試 在瀏覽器裡輸入 如果出現It Works!說明成功。

Linux下安裝、配置PHP環境和MySQL數據庫

修改默認的Web站點目錄

默認的目錄為 "/usr/local/apache2/htdocs",修改apache的配置文件httpd.conf,比如在新建一個 /home/gyw/WebSite的目錄作為apache的站點目錄

找到DocumentRoot這一行修改為:DocumentRoot "/home/gyw/WebSite"

找到 這一行修改為:

測試:修改到文件夾出現錯誤:

“You don't have permission to access /index.html on this server.”

解決方法:

更改文件權限;chmod 755 index.html

打開apache配置文件httpd.conf,找到這麼一段: Options FollowSymLinks AllowOverride None Order deny,allow deny from all Satisfy all

測試結果如下:

Linux下安裝、配置PHP環境和MySQL數據庫

安裝PHP

下載 解壓 tar -zxvf php-5.3.16.tar.gz建立目標文件夾 mkdir /usr/local/php 也就是說等下安裝的php要安裝到這個文件夾裡面

配置 回到原來解壓後的文件夾 ./configure --prefix=/usr/local/php --with-apxs2=/usr/local/apache/bin/apxs

注意這裡有一個-with-apxs2=/usr/local/apache/bin/apxs選項,其中apxs是在安裝Apache時產生的,apxs是一個為Apache HTTP服務器編譯和安裝擴展模塊的工具,使之可以用由mod_so提供的LoadModule指令在運行時加載到Apache服務器中。我的理解是通過這個工具把PHP模塊動態加載到Apache中

出現錯誤:configure: error: xml2-config not found. Please check your libxml2 installation.

運行yum install libxml2,然後再運行yum install libxml2-devel安裝完畢後,重新運行上面的./configure命令。

編譯 make 測試編譯 make test 安裝 make install

、配置文件

cp /usr/local/src/php-5.3.16/php.ini-development /usr/local/php/lib/php.in

把原來位於源代碼裡面的php.ini-development拷貝到/usr/local/php/lib/php.ini下,並且重命名為php.ini

重啟apache

測試 在apache的htdocs下建立一個php文件test.php,裡面的內容如下: 然後在瀏覽器裡輸入 如果出現php的相關配置,成功,如果什麼都沒有輸入,說明失敗,重新以上步驟或者查找原因

如果決定在安裝後改變配置選項,只需重複最後的三步configure, make, 以及 make install,然後需要重新啟動 Apache 使新模塊生效。Apache不需要重新編譯。

測試結果如下圖:

Linux下安裝、配置PHP環境和MySQL數據庫

安裝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');

注意每條命令後面有個分號,如果上面的都成功,後面就可以用這個測試。

將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目錄下,測試上面用命令創建的數據庫

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

[[email protected] 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再次運行上面的命令即可。

[[email protected] mysqli]#./configure –prefix=/opt/mysqli –with-php-config=/opt/php/bin/php-config –with-mysqli=/opt/mysql/bin/mysql_config

[[email protected] mysqli]#make

[[email protected] 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

安裝完成!

Linux下安裝、配置PHP環境和MySQL數據庫

相關問題答案