Centos下搭建LAMP
Centos 搭建LAMP
安裝roundcube,首先需要先搭建一個 LAMP 運行環(huán)境,
LAMP 是Linux, Apache, MySQL, PHP 的首字母縮寫,也就是在一臺 CentOS5.3 服務(wù)器上安裝帶有PHP5 和 Mysql 支持 Apache 的網(wǎng)站服務(wù)器。
1. 假設(shè)你已經(jīng)有一臺安裝了 Linux 系統(tǒng)的服務(wù)器,系統(tǒng)可以使 CentOS5.3 ,也可以是 Ubuntu 9.04 。這次是用 CentOS5.3 做例子。
2. 安裝 Apache2
一般來說,Apache2 已經(jīng)包含在 CentOS 軟件包中了,系統(tǒng)可以默認(rèn)安裝完畢,當(dāng)然你可以使用下面的命令就能輕松安裝它:
- yum install httpd
系統(tǒng)會提示已需要安裝的版本并自動安裝,如有更新,系統(tǒng)會顯示需要更新的版本。
如已經(jīng)安裝完畢將顯示下述信息:
- Package httpd-2.2.3-22.el5.centos.2.i386 already installed and latest version
- Nothing to do
安裝 Apache 后,你可以啟動:
- /etc/init.d/httpd start
可以查看運行狀態(tài):
- /etc/init.d/httpd status
- httpd is running...
現(xiàn)在可以在瀏覽器中打開 http://localhost 或 http://127.0.0.1 ,看到 Apache 2 Test Page 頁面。
修改配置文件:
- nano /etc/httpd/conf/httpd.conf
可以修改偵聽端口 80 -> 8080 :
#Listen 12.34.56.78:80
Listen 8080
你可以重啟動服務(wù):
/etc/init.d/httpd restart
接著繼續(xù)再了解一下 apache2 這個版本的結(jié)構(gòu),這有助于我們配置應(yīng)用:
/etc/httpd/conf/httpd.conf :最主要的配置文件;
/etc/httpd/conf.d/*.conf :這個是 CentOS 的特色,如果你不想修改原始配置文件 httpd.conf 的話,其他配置的在此獨立配置,啟動 apache 時,這個文件就會被讀入到主要配置文件;
/usr/lib/httpd/modules :apache 支持很多的模塊,您想要使用的模塊默認(rèn)都放置在此目錄;
/var/www/html :這里是 CentOS 默認(rèn)的“首頁”目錄;
/var/www/error :默認(rèn)的系統(tǒng)錯誤信息,主機(jī)設(shè)置錯誤或瀏覽器端要求的數(shù)據(jù)錯誤,在瀏覽器上出現(xiàn)的錯誤提示就以這里的信息為主;
/var/www/icons :提供 apache 的一些小圖標(biāo);
/var/www/cgi-bin :默認(rèn)一些可執(zhí)行的 CGI 程序放置的目錄;
/var/log/httpd :日志文件目錄,這里的文件很容易變的很大,需要提供足夠的空間;
/usr/sbin/apachectl :這是 Apache 的主要執(zhí)行文件,這個執(zhí)行文件其實是 shell script ,它可以主動檢測系統(tǒng)上的一些設(shè)置值,好讓您啟動 Apache 時更簡單;
/usr/sbin/httpd :這是主要的 apache 的二進(jìn)制文件;
/usr/bin/htpasswd :當(dāng)您想登陸某些網(wǎng)頁時,需要輸入賬號與密碼。那么Apache本身就提供一個最基本的密碼保護(hù)方式,該密碼的產(chǎn)生就是通過這個命令實現(xiàn)的。
3. 安裝 MySQL5.0
目前 MySQL 官方網(wǎng)站的版本已經(jīng)到了5.1.39 ,CentOS 綁定版本還是 5.0 ,感覺還是用較低版本穩(wěn)定。
執(zhí)行下面的命令來安裝 MySQl :
- yum install mysql mysql-server
然后啟動 MySQL 服務(wù)器:
/etc/init.d/mysqld start
運行下面的命令來為 root 用戶設(shè)置一個密碼(否則的話任何人都可以訪問你的MySQL數(shù)據(jù)庫!):
- mysqladmin -u root -p password bianjie1234
Enter password: 一般初始密碼為空
如果初始密碼不為空或已忘記密碼,你可以使用以下的方法來重置 root 用戶的密碼:
- /etc/init.d/mysqld stop
- Stopping MySQL: [ OK ]
- mysqld_safe --user=mysql --skip-grant-tables --skip-networking &
- [1] 16356
- Starting mysqld daemon with databases from /var/lib/mysql
重置 root 用戶密碼:
- mysql -u root mysql
- mysql> update user set passwordpassword=password('bianjie1234') where user='root';
- mysql> FLUSH PRIVILEGES;
- mysql> quit
- Bye
這樣你的 root 用戶密碼已經(jīng)被成功重置,然后停止安全模式的運行,重新正常啟動 MySQL:
- /etc/init.d/mysqld stop
- STOPPING server from pid file /var/run/mysqld/mysqld.pid
- 091015 16:57:28 mysqld ended
- Stopping MySQL: [ OK ]
- [1]+ Done mysqld_safe --user=mysql --skip-grant-tables --skip-networking
- /etc/init.d/mysqld start
若需要為 root 用戶設(shè)置一個新密碼,運行下面的命令:
mysqladmin -u root -p password bianjie1234(新密碼)
Enter password:輸入密碼
操作 MySQL
mysql -u root -p
Enter password:輸入密碼
Welcome to the MySQL monitor...
...
Server version: 5.0.77...
...
mysql>
MySQL 有幾個重要目錄與文件:
/etc/my.cnf :這是Mysql的配置文件,包括 mysql 數(shù)據(jù)庫的優(yōu)化;
/usr/lib/mysql :這個目錄是 MySQL 數(shù)據(jù)庫放置的位置,務(wù)必在備份時將此目錄完整的備份下來。
4. 安裝 PHP5
使用下列命令來安裝 PHP5 和 Apache 的 PHP5 模塊:
- yum install php
然后需要必須重新啟動 Apache :
- /etc/init.d/httpd restart
這個安裝比較簡單,完成后可以測試一下。Apache 網(wǎng)站的默認(rèn)文檔的路徑是 /var/www/html ,在這個目錄里創(chuàng)建一個簡單文件 info.php ,并且在瀏覽器中調(diào)用 http://localhost/info.php 將會顯示很多 PHP5 的安裝信息。
nano /var/www/html/info.php
phpinfo();
?>
PHP5 正在工作,你會看到很多模塊都可以在 PHP5 中使用了,而 MySQL 并沒有在這里被列出來,這意味著 PHP5 并不支持MySQL,你還需要安裝 php-mysql 這個包。
5. 使得 PHP5 支持 MySQL
yum search ph
選擇你所需的安裝包,然后通過下列命令安裝他們:
- yum install php-mysql php-gd php-imap php-ldap php-odbc php-pear php-xml php-xmlrpc
- yum install php-mysql
然后重新啟動 Apache2 :
- /etc/init.d/httpd restart
在瀏覽器中重新加載 http://localhost/info.php 這個頁面,你就能看到多了剛剛安裝的 MySQL 模塊。
6. 設(shè)置 Apache2 和 MySQL 開機(jī)啟動
- chkconfig --levels 3 httpd on
- chkconfig --list httpd
- httpd 0:off 1:off 2:off 3:on 4:off 5:off 6:off
- chkconfig --levels 3 mysqld on
- chkconfig --list mysqld
- mysqld 0:off 1:off 2:off 3:on 4:off 5:off 6:off
好了,一個 LAMP 服務(wù)器搭建就完成了!
【編輯推薦】