--源码安装httpd,mysql,php
LAMP是一个缩写,它指一组通常一起使用来运行动态网站或者服务器的自由软件:
Linux,操作系统;
Apache,网页服务器;
MySQL,数据库管理系统(或者数据库服务器);
PHP (PHP:Hypertext Preprocessor)是一种脚本语言,主要用途是在于处理动态网页。
虽然这些开放源代码程序本身并不是专门设计成同另几个程序一起工作的,但由于它们的廉价和普遍,这个组合开始流行(大多数Linux发行版本捆绑了这些软件)。当一起使用的时候,它们表现的像一个具有活力的解决方案包。
注:以下编译安装均是在Red Hat 5.4系统平台上进行的。
httpd-2.4.1需要较新版本的apr、apr-util及其对应的devel包和pcre-devel软件包,共需要如下5个软件包:
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
pcre-devel (此软件包系统光盘上就有。)
下载完成之后,使用“rpm -Uvh”进行升级、安装即可。
首先下载获得httpd-2.4.1源码包,而后执行如下命令进行编译安装过程:
- # tar xf httpd-2.4.1.tar.bz2
- # 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
编辑/etc/httpd/httpd.conf,添加如下行即可:
PidFile "/var/run/httpd.pid"
提供了这个脚本便可以用#service命令管理httpd服务。此步骤也不是必须的,不提供脚本的话,可以到httpd的安装路径下的bin目录下执行httpd脚本管理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
接下来就可以启动服务进行测试了。
编辑/etc/man.config,添加如下行即可:
MANPATH /usr/local/apache/man
这可以通过简单的创建链接实现:
# ln -sv /usr/local/apache/include /usr/include/apache
编辑/etc/profile文件,添加如下一行:
PATH=$PATH:/usr/local/apache/bin
新建一个逻辑卷,并将其挂载至特定目录即可。
这里假设其逻辑卷的挂载目录为/mydata,而后需要创建/mydata/data目录做为mysql数据的存放目录。
- #pvcreate /dev/sda5 --这里假设将sda5分区作为物理卷
- #vgcreate myvg /dev/sda5
- #lvcreate -L 2G -n lv1 myvg --这里假设逻辑卷的大小为2G
- # groupadd -r mysql
- # useradd -g mysql -r -s /sbin/nologin -M -d /mydata/data mysql
将存放数据库的目录的属主、属组改为mysql用户,mysql组;
# chown -R mysql:mysql /mydata/data
首先下载平台对应的mysql版本,这里选择的为mysql-5.5.19-linux2.6-i686.tar.gz,
- # 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
- # chown -R root .
- # cd /usr/local/mysql
- # cp support-files/my-large.cnf /etc/my.cnf
修改此文件中的内容;
thread_concurrency = 2 --thread_concurrency的值为CPU个数乘以2
添加如下行指定mysql数据文件的存放路径:
datadir = /mydata/data
- # cd /usr/local/mysql
- # cp support-files/mysql.server /etc/rc.d/init.d/mysqld
添加至服务列表
# chkconfig --add mysqld
# chkconfig mysqld on
而后就可以启动服务测试使用了。
为了使用mysql的安装符合系统使用规范,并将其开发组件导出给系统使用,这里还需要进行如下步骤:
编辑/etc/man.config,添加如下行即可:
MANPATH /usr/local/mysql/man
这可以通过简单的创建链接实现
# ln -sv /usr/local/mysql/include /usr/include/mysql
# echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf
而后让系统重新载入系统库:
# ldconfig
让系统可以直接使用mysql的相关命令。
配置yum源(可以是本地系统光盘)后执行如下命令:
# yum -y groupinstall "X Software Development"
如果想让编译的php支持mcrypt扩展,此处还需要下载如下两个rpm包并安装之:
libmcrypt-2.5.7-5.el5.i386.rpm,libmcrypt-devel-2.5.7-5.el5.i386.rpm
首先下载源码包至本地目录
- # 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 --with-mcrypt
说明:如果前面第1步解决依赖关系时安装mcrypt相关的两个rpm包,此./configure命令还可以带上--with-mcrypt选项以让php支持mycrpt扩展。
# make && make intall
# cp php.ini-production /usr/local/php/lib/php.ini
4、 编辑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是否已经可以正常使用。
测试php是否工作正常:
在/usr/local/apache/htdocs添加index.php内容如下:
- <?php
- phpinfo();
- ?>
访问该网页,若网页中出现php的相关信息则说明php已正确安装。
测试php能否连到数据库:
更改index.php 内容如下:
- <?php
- $link=mysql_connect('172.16.13.1','root','');--指定数据库的ip地址,用户名,密码
- if ($link)
- echo "success.";
- else
- echo "faliure.";
- mysql_close();
- ?>
访问该网页,若网页中出现“success”则说明php可以连上数据库了