编译安装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();

?>

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