一、什麼是LAMP
LAMP(Linux-Apache-MySQL-PHP)網站架構是目前國際流行的Web框架,該框架包括:Linux操作系統,Apache網絡服務器,MySQL數據庫,Perl、PHP或者Python編程語言,所有組成產品均是開源軟件,是國際上成熟的架構框架,很多流行的商業應用都是採取這個架構,和Java/J2EE架構相比,LAMP具有Web資源豐富、輕量、快速開發等特點,微軟的.NET架構相比,LAMP具有通用、跨平臺、高性能、低價格的優勢,因此LAMP無論是性能、質量還是價格都是企業搭建網站的首選平臺。
1、操作系統
Linux操作系統有很多個不同的發行版,如Red Hat Enterprise Linux、SUSE Linux Enterprice、Debian、Ubuntu、CentOS等,每一個發行版都有自己的特色,比如RHEL的穩定,Ubuntu的易用。(因爲這裏以RHEL爲例)
2、Web服務器和PHP加速
Apache是LAMP架構最核心的Web Server,提供服務httpd。開源、穩定、模塊豐富是Apache的優勢。但Apache的缺點是有些臃腫,內存和CPU開銷大,性能上有損耗,不如一些輕量級的Web服務器(例如nginx)高效,輕量級的Web服務器對於靜態文件的響應能力來說遠高於Apache服務器。
Apache做爲Web Server是負載PHP的最佳選擇,如果流量很大的話,可以採用nginx來負載非PHP的Web請求。nginx是一個高性能的HTTP和反向代理服務器,Nginx以它的穩定性、豐富的功能集、示例配置文件和低系統資源的消耗而聞名。Nginx不支持PHP和CGI等動態語言,但支持負載均衡和容錯,可和Apache配合使用,是輕量級的HTTP服務器的首選。
PHP的加速使用eAccelerator加速器,eAccelerator是一個自由開放源碼PHP加速器,優化和動態內容緩存,提高了性能PHP腳本的緩存性能,使得PHP腳本在編譯的狀態下,對服務器的開銷幾乎完全消除。它還有對腳本起優化作用,以加快其執行效率。使PHP程序代碼執效率能提高1-10倍。
3、數據庫
開源的數據庫中,MySQL在性能、穩定性和功能上是首選,可以達到百萬級別的數據存儲,網站初期可以將MySQL和Web服務器放在一起,但是當訪問量達到一定規模後,應該將MySQL數據庫從Web Server上獨立出來,在單獨的服務器上運行,同時保持Web Server和MySQL服務器的穩定連接。
當數據庫訪問量達到更大的級別,可以考慮使用MySQL Cluster等數據庫集羣或者庫表散列等解決方案。
綜上所述,基於LAMP架構設計具有成本低廉、部署靈活、快速開發、安全穩定等特點,是Web網絡應用和環境的優秀組合。
二、編譯安裝httpd 2.4.1、 mysql-5.5.19 、php-5.3.10:
(一) 編譯安裝apache (httpd-2.4.1)
1.解決依賴關係
httpd-2.4.1需要較新版本的apr和apr-util,因此需要事先對其進行升級。這裏使用直接升級rpm包的方式。
共需要如下4個軟件包:
apr-1.4.6-1.i386.rpm
apr-devel-1.4.6-1.i386.rpm
apr-util-1.4.1-1.i386.rpm
apr-util-devel-1.4.1-1.i386.rpm
#rpm –Uvh apr-1.4.6-1.i386.rpm apr-devel-1.4.6-1.i386.rpm apr-util-1.4.1-1.i386.rpm apr-util-devel-1.4.1-1.i386.rpm
注意:httpd-2.4.1編譯過程也要依賴於pcre-devel軟件包和"Development Tools" "Development Libraries"需要事先安裝。但應先檢查是否配置yum源。若沒有,以下提供創建本地yum源的示例:
#mkdir –pv /media/cdrom
# mount /dev/cdrom /media/cdrom
# cd /etc/yum.repos.d
# mv rhel-debuginfo.repo rhel-debuginfo.repo.bak //備份系統自帶的配置文件,也可以刪除
# vim local.repo //新建一個yum配置文件,並把以下內容寫入到該文件
[Server]
name=Server
baseurl=file:///media/cdrom/Server
gpgcheck=0
enabled=1
[VT]
name=VT
baseurl=file:///media/cdrom/VT
gpgcheck=0
enabled=1
[Cluster]
name=Cluster
baseurl=file:///media/cdrom/Cluster
gpgeheck=0
[ClusterStorage]
name=ClusterStorage
baseurl=file:///media/cdrom/ClusterStorage
gpgcheck=0
enabled=1
# yum -y grouplist "Development Libraries" "Development Tools" pcre-devel
2.以httpd-2.4.1.tar.bz2 軟件包爲例安裝
解壓目標文件
# tar xf httpd-2.4.1.tar.bz2
解壓後會自動生成目錄httpd-2.4.1,並切換至此目錄
# cd httpd-2.4.1
編譯安裝
# ./configure --prefix=/usr/local/apache --sysconfdir=/etc/httpd --enable-so --enable-ssl --enable-cgi --enable-rewrite --with-zlib
# make
# make install
3、修改httpd的主配置文件,設置其Pid文件的路徑
#vim /etc/httpd/httpd.conf
編輯/etc/httpd/httpd.conf,添加如下行即可:
PidFile "/var/run/httpd.pid"
4、提供SysV服務腳本/etc/rc.d/init.d/httpd,內容如下:
#vim /etc/rc.d/init.d/httpd
將以下內容添加至此文件中
#!/bin/bash
#
# httpd Startup script for the Apache HTTP Server
#
# chkconfig: - 85 15
# description: Apache is a World Wide Web server. It is used to serve \
# HTML files and CGI.
# processname: httpd
# config: /etc/httpd/conf/httpd.conf
# config: /etc/sysconfig/httpd
# pidfile: /var/run/httpd.pid
# Source function library.
. /etc/rc.d/init.d/functions
if [ -f /etc/sysconfig/httpd ]; then
. /etc/sysconfig/httpd
fi
# Start httpd in the C locale by default.
HTTPD_LANG=${HTTPD_LANG-"C"}
# This will prevent initlog from swallowing up a pass-phrase prompt if
# mod_ssl needs a pass-phrase from the user.
INITLOG_ARGS=""
# Set HTTPD=/usr/sbin/httpd.worker in /etc/sysconfig/httpd to use a server
# with the thread-based "worker" MPM; BE WARNED that some modules may not
# work correctly with a thread-based MPM; notably PHP will refuse to start.
# Path to the apachectl script, server binary, and short-form for messages.
apachectl=/usr/local/apache/bin/apachectl
httpd=${HTTPD-/usr/local/apache/bin/httpd}
prog=httpd
pidfile=${PIDFILE-/var/run/httpd.pid}
lockfile=${LOCKFILE-/var/lock/subsys/httpd}
RETVAL=0
start() {
echo -n $"Starting $prog: "
LANG=$HTTPD_LANG daemon --pidfile=${pidfile} $httpd $OPTIONS
RETVAL=$?
echo
[ $RETVAL = 0 ] && touch ${lockfile}
return $RETVAL
}
stop() {
echo -n $"Stopping $prog: "
killproc -p ${pidfile} -d 10 $httpd
RETVAL=$?
echo
[ $RETVAL = 0 ] && rm -f ${lockfile} ${pidfile}
}
reload() {
echo -n $"Reloading $prog: "
if ! LANG=$HTTPD_LANG $httpd $OPTIONS -t >&/dev/null; then
RETVAL=$?
echo $"not reloading due to configuration syntax error"
failure $"not reloading $httpd due to configuration syntax error"
else
killproc -p ${pidfile} $httpd -HUP
RETVAL=$?
fi
echo
}
# See how we were called.
case "$1" in
start)
start
;;
stop)
stop
;;
status)
status -p ${pidfile} $httpd
RETVAL=$?
;;
restart)
stop
start
;;
condrestart)
if [ -f ${pidfile} ] ; then
stop
start
fi
;;
reload)
reload
;;
graceful|help|configtest|fullstatus)
$apachectl $@
RETVAL=$?
;;
*)
echo$"Usage:$prog{start|stop|restart|condrestart|reload|status|fullstatus|graceful|help|configtest}"
exit 1
esac
exit $RETVAL
而後爲此腳本賦予執行權限:
# chmod +x /etc/rc.d/init.d/httpd
加入服務列表:
# chkconfig --add httpd
#chkconfig httpd on
接下來就可以啓動服務進行測試了。
#service httpd start
查看默認服務端口80是否被監聽:
#netstat -tnlp
查看在此目錄/var/www/html下是否存在主頁面 index.html文件,然後在瀏覽器地址欄中輸入服務器所在的地址,查看是否能訪問此頁面。
(一) 安裝mysql-5.5.19
1、準備數據存放的文件系統
新建一個邏輯卷,
#fdisk /dev/sda
n ;新建
e ;選擇邏輯分區
n ;在邏輯分區上新建邏輯卷
+10G ;劃分10G 的分區
t ;修改分區類型
5 ;選擇第幾塊磁盤
8e ;邏輯分區對應的類型號
w ;保存退出
同步磁盤信息
#partprobe /dev/sda
創建物理卷
#pvcreate /dev/sda5
創建卷組myvg
#vgcreate myvg /dev/sda5
創建邏輯卷mysql
#lvcreate -L 2G -n mysql myvg
格式化分區爲ext3
#mke2fs -j /dev/myvg/mysql
編輯開機自動掛載選項
#vim /etc/fstab
/dev/myvg/mysql /mydata ext3 defaults 0 0
#mkdir -pv /mydata/data
這裏假設其邏輯卷的掛載目錄爲/mydata,而後需要創建/mydata/data目錄做爲mysql數據的存放目錄。
2、新建用戶以安全方式運行進程:
# groupadd -r mysql
# useradd -g mysql -r -s /sbin/nologin -M -d /mydata/data mysql
# chown -R mysql:mysql /mydata/data
3、安裝並初始化mysql-5.5.19
解壓目標文件:
# tar xf mysql-5.5.19-linux2.6-i686.tar.gz -C /usr/local
# cd /usr/local/
# ln -sv mysql-5.5.19-linux2.6-i686 mysql
# cd mysql
# chown -R mysql:mysql .
# scripts/mysql_install_db --user=mysql --datadir=/mydata/data (以mysql身份初始化)
# chown -R root .
4、爲mysql提供主配置文件:
# cd /usr/local/mysql
# cp support-files/my-large.cnf /etc/my.cnf
並修改此文件中thread_concurrency的值爲你的CPU個數乘以2,比如這裏使用如下行:
thread_concurrency = 2
另外還需要添加如下行指定mysql數據文件的存放位置:
datadir = /mydata/data
5、爲mysql提供sysv服務腳本:
# cd /usr/local/mysql
# cp support-files/mysql.server /etc/rc.d/init.d/mysqld
添加至服務列表:
# chkconfig --add mysqld
# chkconfig mysqld on
而後就可以啓動服務測試使用了。
爲了使用mysql的安裝符合系統使用規範,並將其開發組件導出給系統使用,這裏還需要進行如下步驟:
6、輸出mysql的man手冊至man命令的查找路徑:
#vim /etc/man.config,添加如下行即可:
MANPATH /usr/local/mysql/man
7、輸出mysql的頭文件至系統頭文件路徑/usr/include:
這可以通過簡單的創建鏈接實現:
# ln -sv /usr/local/mysql/include /usr/include/mysql
8、輸出mysql的庫文件給系統庫查找路徑:
# echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf
而後讓系統重新載入系統庫:
# ldconfig
9、修改PATH環境變量,讓系統可以直接使用mysql的相關命令。
#vim /etc/profile
此時也可以把apache的環境變量寫在此處
PATH=$PATH:/usr/local/mysql/bin:/usr/local/apache/bin
(二) 編譯安裝php-5.3.10
1、解決依賴關係:
# yum -y groupinstall "X Software Development"
2、編譯安裝php-5.3.10
# tar xf php-5.3.10.tar.bz2
# cd php-5.3.10
# ./configure --prefix=/usr/local/php --with-mysql=/usr/local/mysql --with-openssl --with-mysqli=/usr/local/mysql/bin/mysql_config --enable-mbstring --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --with-apxs2=/usr/local/apache/bin/apxs
# make
# make test
# make intall
爲php提供配置文件:
# cp php.ini-production /usr/local/php/lib/php.ini
3、 編輯apache配置文件httpd.conf,以apache支持php
# vim /etc/httpd/httpd.conf
1、添加如下二行
AddType application/x-httpd-php .php
AddType application/x-httpd-php-source .phps
2、定位至DirectoryIndex index.html
修改爲:
DirectoryIndex index.php index.html
而後重新啓動httpd,或讓其重新載入配置文件即可測試php是否已經可以正常使用。
#getenforce
#setenforce 0
#service httpd configtest
#service httpd restart
在/usr/html新建index.php的測試頁面,測試php是否能正常工作:
#vim index.php
<html><body><h1>It works!</h1></body></html>
<?php
$conn=mysql_connect('localhost','root','');
if ($conn)
echo "Success...";
else
echo "Failure...";
mysql_close();
?>