編譯安裝LAMP

一、什麼是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();

?>

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章