搭建LAMP平台

--源码安装httpdmysqlphp

 

LAMP简介

LAMP是一个缩写,它指一组通常一起使用来运行动态网站或者服务器的自由软件:

    Linux,操作系统;

    Apache,网页服务器;

    MySQL,数据库管理系统(或者数据库服务器);

    PHPPHPHypertext Preprocessor)是一种脚本语言,主要用途是在于处理动态网页

虽然这些开放源代码程序本身并不是专门设计成同另几个程序一起工作的,但由于它们的廉价和普遍,这个组合开始流行(大多数Linux发行版本捆绑了这些软件)。当一起使用的时候,它们表现的像一个具有活力的解决方案包。

注:以下编译安装均是在Red Hat 5.4系统平台上进行的。

一、编译安装httpd-2.4.1

1、解决依赖关系

httpd-2.4.1需要较新版本的aprapr-util及其对应的devel包和pcre-devel软件包,共需要如下5个软件包:

apr-1.4.6-1.i386.rpmapr-devel-1.4.6-1.i386.rpmapr-util-1.4.1-1.i386.rpmapr-util-devel-1.4.1-1.i386.rpm

pcre-devel (此软件包系统光盘上就有。)

下载完成之后,使用“rpm -Uvh”进行升级、安装即可。

2、编译安装httpd-2.4.1

首先下载获得httpd-2.4.1源码包,而后执行如下命令进行编译安装过程:

 

  1. # tar xf httpd-2.4.1.tar.bz2 
  2.  
  3. # cd httpd-2.4.1 
  4.  
  5. # ./configure --prefix=/usr/local/apache --sysconfdir=/etc/httpd --enable-so --enable-ssl --enable-cgi --enable-rewrite --with-zlib 
  6.  
  7. # make && make install 

3、修改httpd的主配置文件,设置其Pid文件的路径

编辑/etc/httpd/httpd.conf,添加如下行即可:

PidFile  "/var/run/httpd.pid"

4、提供SysV服务脚本/etc/rc.d/init.d/httpd

提供了这个脚本便可以用#service命令管理httpd服务。此步骤也不是必须的,不提供脚本的话,可以到httpd的安装路径下的bin目录下执行httpd脚本管理httpd服务。内容如下:

 

  1. #!/bin/bash 
  2.  
  3.  
  4. # httpd        Startup script for the Apache HTTP Server 
  5.  
  6.  
  7. # chkconfig: - 85 15 
  8.  
  9. # description: Apache is a World Wide Web server.  It is used to serve \ 
  10.  
  11. #        HTML files and CGI. 
  12.  
  13. # processname: httpd 
  14.  
  15. # config: /etc/httpd/conf/httpd.conf 
  16.  
  17. # config: /etc/sysconfig/httpd 
  18.  
  19. # pidfile: /var/run/httpd.pid 
  20.  
  21. # Source function library. 
  22.  
  23. . /etc/rc.d/init.d/functions 
  24.  
  25. if [ -f /etc/sysconfig/httpd ]; then 
  26.  
  27.         . /etc/sysconfig/httpd 
  28.  
  29. fi 
  30.  
  31. # Start httpd in the C locale by default
  32.  
  33. HTTPD_LANG=${HTTPD_LANG-"C"
  34.  
  35. # This will prevent initlog from swallowing up a pass-phrase prompt if 
  36.  
  37. # mod_ssl needs a pass-phrase from the user
  38.  
  39. INITLOG_ARGS="" 
  40.  
  41. Set HTTPD=/usr/sbin/httpd.worker in /etc/sysconfig/httpd to use a server 
  42.  
  43. with the thread-based "worker" MPM; BE WARNED that some modules may not 
  44.  
  45. work correctly with a thread-based MPM; notably PHP will refuse to start. 
  46.  
  47. # Path to the apachectl script, server binaryand short-form for messages. 
  48.  
  49. apachectl=/usr/local/apache/bin/apachectl 
  50.  
  51. httpd=${HTTPD-/usr/local/apache/bin/httpd} 
  52.  
  53. prog=httpd 
  54.  
  55. pidfile=${PIDFILE-/var/run/httpd.pid} 
  56.  
  57. lockfile=${LOCKFILE-/var/lock/subsys/httpd} 
  58.  
  59. RETVAL=0 
  60.  
  61. start() { 
  62.  
  63.         echo -n $"Starting $prog: " 
  64.  
  65.         LANG=$HTTPD_LANG daemon --pidfile=${pidfile} $httpd $OPTIONS 
  66.  
  67.         RETVAL=$? 
  68.  
  69.         echo 
  70.  
  71.         [ $RETVAL = 0 ] && touch ${lockfile} 
  72.  
  73.         return $RETVAL 
  74.  
  75.  
  76. stop() { 
  77.  
  78. echo -n $"Stopping $prog: " 
  79.  
  80. killproc -p ${pidfile} -d 10 $httpd 
  81.  
  82. RETVAL=$? 
  83.  
  84. echo 
  85.  
  86. [ $RETVAL = 0 ] && rm -f ${lockfile} ${pidfile} 
  87.  
  88.  
  89. reload() { 
  90.  
  91.     echo -n $"Reloading $prog: " 
  92.  
  93.     if ! LANG=$HTTPD_LANG $httpd $OPTIONS -t >&/dev/nullthen 
  94.  
  95.         RETVAL=$? 
  96.  
  97.         echo $"not reloading due to configuration syntax error" 
  98.  
  99.         failure $"not reloading $httpd due to configuration syntax error" 
  100.  
  101.     else 
  102.  
  103.         killproc -p ${pidfile} $httpd -HUP 
  104.  
  105.         RETVAL=$? 
  106.  
  107.     fi 
  108.  
  109.     echo 
  110.  
  111.  
  112. # See how we were called. 
  113.  
  114. case "$1" in 
  115.  
  116.   start) 
  117.  
  118. start;; 
  119.  
  120.   stop) 
  121.  
  122. stop 
  123.  
  124. ;; 
  125.  
  126.   status) 
  127.  
  128.         status -p ${pidfile} $httpd 
  129.  
  130. RETVAL=$? 
  131.  
  132. ;; 
  133.  
  134.   restart) 
  135.  
  136. stop 
  137.  
  138. start 
  139.  
  140. ;; 
  141.  
  142.   condrestart) 
  143.  
  144. if [ -f ${pidfile} ] ; then 
  145.  
  146. stop 
  147.  
  148. start 
  149.  
  150. fi 
  151.  
  152. ;; 
  153.  
  154.   reload) 
  155.  
  156.         reload 
  157.  
  158. ;; 
  159.  
  160.   graceful|help|configtest|fullstatus) 
  161.  
  162. $apachectl $@ 
  163.  
  164. RETVAL=$? 
  165.  
  166. ;; 
  167.  
  168.   *) 
  169.  
  170. echo $"{Usage $prog start|stop|restart|condrestart|reload|status|fullstatus|graceful|help|configtest}" 
  171.  
  172. exit 1 
  173.  
  174. esac 
  175.  
  176. exit $RETVAL 

而后为此脚本赋予执行权限:

# chmod +x /etc/rc.d/init.d/httpd

加入服务列表:

# chkconfig --add httpd

使服务开机启动

#chkconfig httpd on

接下来就可以启动服务进行测试了。

5、将httpdman手册路径添加至man命令的查找路径

编辑/etc/man.config,添加如下行即可:

MANPATH  /usr/local/apache/man

6、将httpd的头文件路径添加至系统头文件路径/usr/include

这可以通过简单的创建链接实现:

# ln -sv /usr/local/apache/include  /usr/include/apache

7、修改PATH环境变量,让系统可以直接使用httpd的相关命令

编辑/etc/profile文件,添加如下一行:

PATH=$PATH:/usr/local/apache/bin

二、安装mysql-5.5.20

1、准备数据存放的文件系统

新建一个逻辑卷,并将其挂载至特定目录即可。

这里假设其逻辑卷的挂载目录为/mydata,而后需要创建/mydata/data目录做为mysql数据的存放目录。

  1. #pvcreate /dev/sda5 --这里假设将sda5分区作为物理卷 
  2.  
  3. #vgcreate myvg /dev/sda5 
  4.  
  5. #lvcreate -L 2G -n lv1 myvg --这里假设逻辑卷的大小为2G 

2、新建用户以安全方式运行进程

  1. # groupadd -r mysql 
  2.  
  3. # useradd -g mysql -r -s /sbin/nologin -M -d /mydata/data mysql 

将存放数据库的目录的属主、属组改为mysql用户,mysql组;

# chown -R mysql:mysql /mydata/data

3、安装并初始化mysql-5.5.20

首先下载平台对应的mysql版本,这里选择的为mysql-5.5.19-linux2.6-i686.tar.gz

  1. # tar xf mysql-5.5.19-linux2.6-i686.tar.gz -C /usr/local 
  2.  
  3. # cd /usr/local

为解压的目录创建软链接;

 

  1. # ln -sv mysql-5.5.19-linux2.6-i686  mysql 
  2.  
  3. # cd mysql  
  4.  
  5. # chown -R mysql:mysql  . 
  6.  
  7. # scripts/mysql_install_db --user=mysql --datadir=/mydata/data 
  8.  
  9. # chown -R root  . 

4、为mysql提供主配置文件

  1. # cd /usr/local/mysql 
  2.  
  3. # cp support-files/my-large.cnf  /etc/my.cnf 

修改此文件中的内容;

thread_concurrency = 2 --thread_concurrency的值为CPU个数乘以2

添加如下行指定mysql数据文件的存放路径:

datadir = /mydata/data

5、为mysql提供sysv服务脚本

  1. # cd /usr/local/mysql 
  2.  
  3. # cp support-files/mysql.server  /etc/rc.d/init.d/mysqld 

添加至服务列表

# chkconfig --add mysqld

# chkconfig mysqld on

而后就可以启动服务测试使用了。

为了使用mysql的安装符合系统使用规范,并将其开发组件导出给系统使用,这里还需要进行如下步骤:

6、输出mysqlman手册至man命令的查找路径

编辑/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的相关命令。

三、编译安装php-5.3.10

1、解决依赖关系

配置yum源(可以是本地系统光盘)后执行如下命令:

# yum -y groupinstall "X Software Development" 

如果想让编译的php支持mcrypt扩展,此处还需要下载如下两个rpm包并安装之:

libmcrypt-2.5.7-5.el5.i386.rpmlibmcrypt-devel-2.5.7-5.el5.i386.rpm

2、编译安装php-5.3.10

首先下载源码包至本地目录

  1. # tar xf php-5.3.10.tar.bz2 
  2.  
  3. # cd php-5.3.10 
  4.  
  5. # ./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 --with-mcrypt 

说明:如果前面第1步解决依赖关系时安装mcrypt相关的两个rpm包,此./configure命令还可以带上--with-mcrypt选项以让php支持mycrpt扩展。

# make && make intall

3、为php提供配置文件

# cp php.ini-production /usr/local/php/lib/php.ini

4、 编辑apache配置文件httpd.conf

使apache支持php 

 # vim /etc/httpd/httpd.conf

 1、添加如下二行

  

  1. AddType application/x-httpd-php  .php 
  2.  
  3.    AddType application/x-httpd-php-source  .phps 

 2、定位至DirectoryIndex index.html 

   修改为:

    DirectoryIndex  index.php  index.html

而后重新启动httpd,或让其重新载入配置文件即可测试php是否已经可以正常使用。

测试php是否工作正常:

/usr/local/apache/htdocs添加index.php内容如下:

  1. <?php 
  2.  
  3. phpinfo(); 
  4.  
  5. ?> 

访问该网页,若网页中出现php的相关信息则说明php已正确安装。

测试php能否连到数据库:

更改index.php 内容如下:

  1. <?php 
  2.  
  3. $link=mysql_connect('172.16.13.1','root','');--指定数据库的ip地址,用户名,密码 
  4.  
  5. if ($link) 
  6.  
  7.   echo "success."
  8.  
  9. else 
  10.  
  11.   echo "faliure."
  12.  
  13. mysql_close(); 
  14.  
  15. ?> 

访问该网页,若网页中出现“success”则说明php可以连上数据库了