设为首页 收藏本站
查看: 716|回复: 0

手动编译搭建LAMP服务器

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-1-19 11:16:00 | 显示全部楼层 |阅读模式
  一、我使用的搭建环境是Centos6.6 x86-64 mini版的系统;最小版安装有很多软件没有提供,我们可以通过yum软件库进行安装,到现在LAMP服务器的“L”(linux)我们已经准备好了,那么下一步我们是需要下载apache的httpd软件,下载地址是httpd.apache.org,现在apache维护的httpd有2.0,、2.2、2.4几个分支版本,每个版本的功能官网写的很清楚,我这里不再赘述,我所选择的是httpd的最新版本2.4.10,下面我们进行httpd的编译过程讲解;    因为httpd可以在各种操作系统,各种硬件架构上运行,是因为httpd运行在apr(Apache Portable Runtime)虚拟机上面,针对不同平台和操作系统开发apr,所有首先在我们按照httpd之前应该先安装apr,我们不使用软件包自带的apr软件,好像是版本有点低,httpd2.4.10需要的apr版本最低是1.4,我们去官网下载最新版本的apr和apr-util,下载地址是apr.apache.org;
# wget http://apache.fayea.com//httpd/httpd-2.4.10.tar.bz2
# wget http://mirrors.cnnic.cn/apache//apr/apr-1.5.1.tar.bz2
# wget http://mirrors.cnnic.cn/apache//apr/apr-util-1.5.4.tar.bz2
# tar -xf httpd-2.4.10.tar.bz2
# tar -xf apr-1.5.1.tar.bz2
# tar -xf apr-util-1.5.4.tar.bz2

安装开发库
# yum install gcc -y
进行软件的编译
# cd apr-1.5.1
# ./configure --prefix=/usr/local/apr
# make
# make install

# cd apr-util-1.5.4
# ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr
# make
# make install

因为httpd需要重写功能,所有需要安装pcre库
# yum install -y pcre-devel
然而我在编译的时候出现checking for OpenSSL version >= 0.9.8a... FAILED
是因为我们的mini版本没有安装openssl的开发库,所有要先安装开发库
# yum install openssl-devel.x86_64 -y

# cd httpd-2.4.10
# ./configure --prefix=/usr/local/apache --sysconfdir=/etc/httpd --enable-so --enable-rewirte --enable-ssl --enable-cgi --enable-cgid --enable-modules=most --enable-mods-shared=most --enable-mpms-shared=all --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util
# make
# make install

关闭SELinux
# setenforce 0

把httpd的二进制执行文件添加到环境变量里面
# vim /etc/profile.d/httpd.sh
添加如下内容 export PATH=$PATH:/usr/local/apache/bin

把httpd的man文件加入系统里面,首先安装man工具
# yum install man -y
# vim /etc/man.config
添加如下内容 MANPATH /usr/local/apache/man
给httpd添加一个SysV风格的脚步放到/etc/init.d/目录下面,到此为止httpd安装完成了;

Mysql的安装可以rpm安装,可以使用通用二进制包安装,也可以使用源码编译安装,鉴于源码编译太耗费时间,我们这使用通用二进制格式包安装,软件包可以在mysql官网下载到,我们现在使用的版本是mysql-5.5.20-linux2.6-x86_64.tar.gz
# tar xf mysql-5.5.20-linux2.6-x86_64.tar.gz -C /usr/local
# cd /usr/local
# ln -s mysql-5.5.20-linux2.6-x86_64 mysql
# groupadd -r mysql
# useradd -g mysql -r -s /sbin/nologin mysql
# cd mysql
# chown -R mysql:mysql *
创建一个逻辑卷给Mysql数据存放位置
# pvcreate /dev/sda5
# vgcreate myvg /dev/sda5
# lvcreate -n mysql -L 5G myvg
# mkfs.ext4 /dev/myvg/mysql
# vim /etc/fstab
# mkdir /data
添加 /dev/myvg/mysql         /data                   ext4    defaults        0 0
# mount -a
# mkdir /data/mysql
# chown mysql.mysql /data/mysql
# chmod o-x /data/mysql
# cd /usr/local/mysql
# ./scripts/mysql_install_db --user=mysql --datadir=/data/mysql/
# chown -R root *

添加二进制程序环境变量
# vim /etc/profile.d/mysql.sh
添加如下 export PATH=$PATH:/usr/local/mysql/bin

添加帮助文件
# vim /etc/man.config
添加如下内容 MANPATH /usr/local/mysql/man

把mysql的库文件加入到系统库文件目录搜索里面
# vim /etc/ld.so.conf.d/mysql.conf
添加如下内容 /usr/local/mysql/lib

添加头文件
# ln -s /usr/local/mysql/include /usr/include/mysql

添加启动脚本
# cp support-files/mysql.server /etc/init.d/mysqld
# chkconfig --add mysqld

添加配置文件
# cp support-files/my-large.cnf /etc/my.cnf
在配置文件里面添加 datadir = /data/mysql

现在可以启动Mysql服务了;

可以为mysql添加密码
# mysqladmin -uroot password '123456'

下面我们进行最后一项php的编译安装,我们选择的php版本是5.4.36
下载php源码包
# wget http://cn2.php.net/distributions/php-5.4.36.tar.bz2
如果想让编译的php支持mcrypt扩展,此处还需要下如下两个rpm包并安装之:
  libmcrypt-2.5.8-9.el6.rpm
  libmcrypt-devel-2.5.8-9.el6.rpm
因为这两个软件包自带的软件库没有,所有我们更新增加yum源
rpm -ivh http://download4.fedora.redhat.c ... ease-6-8.noarch.rpm
# yum install -y libmcrypt libmcrypt-devel

说明:
这些没有自带的包我们也可以到网站去查询下载地址,比如:http://rpmfind.net;在里面我们可以查询到支持各种硬件平台的rpm软件包。


# cd php-5.4.36

下面开始进行编译
# ./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  --enable-sockets --with-apxs2=/usr/local/apache/bin/apxs --with-mcrypt  --with-config-file-path=/etc --with-config-file-scan-dir=/etc/php.d --with-bz2  --enable-maintainer-zts

说明:

1、这里为了支持apache的worker或event这两个MPM,编译时使用了--enable-maintainer-zts选项。
2、--with-apxs2=/usr/local/apache/bin/apxs 这里是让php以httpd的模块模式运行,如果使用FastCGI模式运行的话需改为 --enable-fpm
3、如果使用PHP5.3以上版本,为了链接MySQL数据库,可以指定mysqlnd,这样在本机就不需要先安装MySQL或MySQL开发包了。mysqlnd从php 5.3开始可用,可以编译时绑定到它(而不用和具体的MySQL客户端库绑定形成依赖),但从PHP 5.4开始它就是默认设置了。
# ./configure --with-mysql=mysqlnd --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd

注意:
我在编译中出现了一个错误configure: error: xml2-config not found. Please check your libxml2 installation.
在这里我们首先应该提交安装libxml2,然后再进行编译;
# yum install libxml2 libxml2-devel -y

紧接着又出现错误,出现这么多错误的原因是因为我们安装的linux是mini版,好多软件并没有预装的,安装之前我们也不知道哪些软件存在,哪些软件不存在,只能出现一个问题解决一个问你
错误:configure: error: Please reinstall the BZip2 distribution
# yum install bzip2-devel.x86_64 -y

后面一切顺利,直接到编译配置结束,
# make
# make install

为php提供好配置文件,在php源文件目录下面
# cp php.ini-production /etc/php.ini

编辑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是否已经可以正常使用。

   具体apache的配置我们这里不在陈述,可以更改中心主机的路径,配置虚拟主机,加载需要的模块等等;

   到现在为止LAMP环境是搭建好了,下面我们进行测试,看看我们的php是否可以连接数据库;在index.php里面填写上如下内容:

<?php
   $conn=mysql_connect('localhost','root','123456');
   if ($conn)
      echo "Success.....";
   else
      echo "Failure.....";
phpinfo();
?>
当数据库开启的时候显示Success....,数据库关闭的时候显示Failure...。

下面我们为php安装XCache


XCache 是一个开源的 php的opcode 缓存器/优化器, 这意味着他能够提高您服务器上的 PHP 性能. 他通过把编译 PHP 后的数据缓冲到共享内存从而避免重复的编译过程, 能够直接使用缓冲区已编译的代码从而提高速度. 通常能够提高您的页面生成速率 2 到5 倍, 降低服务器负载.

我们下载最新版本的XCache
# wget http://xcache.lighttpd.net/pub/Releases/3.2.0/xcache-3.2.0.tar.gz
# tar xf xcache-3.2.0.tar.gz
# cd xcache-3.2.0
# /usr/local/php/bin/phpize
然后却出现了错误:

Cannot find autoconf. Please check your autoconf installation and the
$PHP_AUTOCONF environment variable. Then, rerun this script.

原因是因为我还是有软件包没有安装

[iyunv@localhost xcache-3.2.0]# yum install autoconf -y

[iyunv@localhost xcache-3.2.0]# ./configure --enable-xcache --with-php-config=/usr/local/php/bin/php-config

[iyunv@localhost xcache-3.2.0]# make

[iyunv@localhost xcache-3.2.0]# make install

为xcache提供配置文件
[iyunv@localhost xcache-3.2.0]# mkdir /etc/php.d
[iyunv@localhost xcache-3.2.0]# cp xcache.ini /etc/php.d/

到此为止xcache安装完成


第二部分、配置apache-2.4.10与fpm方式的php-5.4.36

一、apache、MySQL的安装与前一部分相同;请根据其进行安装;

二、编译安装php-5.4.36

1、解决依赖关系:

如果想让编译的php支持mcrypt扩展,此处还需要下载如下两个rpm包并安装之:
libmcrypt-2.5.7-5.el5.i386.rpm
libmcrypt-devel-2.5.7-5.el5.i386.rpm
mhash-0.9.9-1.el5.centos.i386.rpm
mhash-devel-0.9.9-1.el5.centos.i386.rpm

2、编译安装php-5.4.36

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

# tar xf php-5.4.36.tar.bz2
# cd php-5.4.36
# ./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  --enable-sockets --enable-fpm --with-mcrypt  --with-config-file-path=/etc --with-config-file-scan-dir=/etc/php.d --with-bz2

# make
# make intall

为php提供配置文件:
# cp php.ini-production /etc/php.ini

3、配置php-fpm

为php-fpm提供Sysv init脚本,并将其添加至服务列表:
# cp sapi/fpm/init.d.php-fpm  /etc/rc.d/init.d/php-fpm
# chmod +x /etc/rc.d/init.d/php-fpm
# chkconfig --add php-fpm
# chkconfig php-fpm on

为php-fpm提供配置文件:
# cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf

编辑php-fpm的配置文件:
# vim /usr/local/php/etc/php-fpm.conf
配置fpm的相关选项为你所需要的值,并启用pid文件(如下最后一行):
pm.max_children = 50
pm.start_servers = 5
pm.min_spare_servers = 2
pm.max_spare_servers = 8
pid = /usr/local/php/var/run/php-fpm.pid

接下来就可以启动php-fpm了:
# service php-fpm start

使用如下命令来验正(如果此命令输出有中几个php-fpm进程就说明启动成功了):
# ps aux | grep php-fpm

默认情况下,fpm监听在127.0.0.1的9000端口,也可以使用如下命令验正其是否已经监听在相应的套接字。
# netstat -tnlp | grep php-fpm
tcp        0      0 127.0.0.1:9000              0.0.0.0:*                   LISTEN      689/php-fpm

三、配置httpd-2.4.10

1、启用httpd的相关模块

在Apache httpd 2.4以后已经专门有一个模块针对FastCGI的实现,此模块为mod_proxy_fcgi.so,它其实是作为mod_proxy.so模块的扩充,因此,这两个模块都要加载
LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so


2、配置虚拟主机支持使用fcgi

在相应的虚拟主机中添加类似如下两行。
ProxyRequests Off
ProxyPassMatch ^/(.*\.php)$ fcgi://127.0.0.1:9000/PATH/TO/DOCUMENT_ROOT/$1

例如:
<VirtualHost *:80>
    DocumentRoot "/www/html"
    ServerName hebrxz.com
    ServerAlias www.hebrxz.com

ProxyRequests Off
ProxyPassMatch ^/(.*\.php)$ fcgi://127.0.0.1:9000/www/html/$1

    <Directory "/www/html">
        Options none
        AllowOverride none
        Require all granted
    </Directory>
</VirtualHost>

ProxyRequests Off:关闭正向代理
ProxyPassMatch:把以.php结尾的文件请求发送到php-fpm进程,php-fpm至少需要知道运行的目录和URI,所以这里直接在fcgi://127.0.0.1:9000后指明了这两个参数,其它的参数的传递已经被mod_proxy_fcgi.so进行了封装,不需要手动指定。

3、编辑apache配置文件httpd.conf,让apache能识别php格式的页面,并支持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

补充:Apache httpd 2.4以前的版本中,要么把PHP作为Apache的模块运行,要么添加一个第三方模块支持PHP-FPM实现。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-41068-1-1.html 上篇帖子: LNMP高并发时502 下篇帖子: XAMPP在启动apache时443端口被占用 服务器
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表