天天看點

編譯安裝LAMP

一、什麼是LAMP

 LAMP(Linux-Apache-MySQL-PHP)網站架構是目前國際流行的Web架構,該架構包括:Linux作業系統,Apache網絡伺服器,MySQL資料庫,Perl、PHP或者Python程式設計語言,所有組成産品均是開源軟體,是國際上成熟的架構架構,很多流行的商業應用都是采取這個架構,和Java/J2EE架構相比,LAMP具有Web資源豐富、輕量、快速開發等特點,微軟的.NET架構相比,LAMP具有通用、跨平台、高性能、低價格的優勢,是以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

[Cluster]

name=Cluster

baseurl=file:///media/cdrom/Cluster

gpgeheck=0

[ClusterStorage]

name=ClusterStorage

baseurl=file:///media/cdrom/ClusterStorage

# 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

        echo $"not reloading due to configuration syntax error"

        failure $"not reloading $httpd due to configuration syntax error"

    else

        killproc -p ${pidfile} $httpd -HUP

    fi

    echo

# See how we were called.

case "$1" in

  start)

         start

         ;;

  stop)

         stop

  status)

        status -p ${pidfile} $httpd

  restart)

  condrestart)

         if [ -f ${pidfile} ] ; then

                   stop

                   start

         fi

  reload)

        reload

  graceful|help|configtest|fullstatus)

         $apachectl $@

  *)

         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服務腳本:

# 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 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)

else

mysql_close();

上一篇: LAMP編譯安裝
下一篇: 編譯安裝lamp

繼續閱讀