编译安装LAM(MySQL)P


  Linux+Apache+MySQL+PHP,其中MySQL逐渐被Mariadb取代。这里依旧使用MySQL进行编译,MySQL在国内下载镜像站点,目前好像就只有mirrors.sohu.com依旧提供。这里都是选择的比较稳定的版本进行编译。

  一、环境和软件包版本介绍

   1. Linux :
        [root@localhost ~]# cat /etc/redhat-release 
        CentOS release 6.8 (Final)
        [root@localhost ~]# uname -r
        2.6.32-642.el6.x86_64
   2.Apache : 2.4版本
        [root@localhost ~]#  ls httpd-2.4.10.tar.bz2 
        httpd-2.4.10.tar.bz2
   3.MySQL : MySQL 5.5.52,据说MySQL8.0版本出来,很久不更新,一次更新就跨越多个版本。。不过绝大部分公司都转向了Mariadb,这里使用MySQL也只是学习一下怎么构建这个平台,随后将有基于Mariadb的平台构建。
        [root@localhost ~]# ls mysql-5.5.52-linux2.6-x86_64.tar.gz 
        mysql-5.5.52-linux2.6-x86_64.tar.gz
   4.PHP : PHP5.6.26
        [root@localhost ~]# ls php-5.6.26.tar.bz2 
        php-5.6.26.tar.bz2

  二、前期准备和Apache编译

   1.下载开发包组
        [root@localhost ~]# yum groupinstall -y "Development Tools"
        [root@localhost ~]# yum groupinstall -y "Server Platform Development"
   2.解决以来关系,Aapache编译需要依赖,apr、apr-util、pcre-devel
#安装pcre开发包
[root@localhost ~]# yum install -y pcre-devel
#编译安装apr程序包
[root@localhost ~]# tar -xf apr-1.5.0.tar.bz2 
[root@localhost ~]# cd apr-1.5.0
[root@localhost apr-1.5.0]# ./configure --prefix=/usr/local/apr
[root@localhost apr-1.5.0]#make&&make install
#编译安装apr-util程序包
[root@localhost ~]# tar xf apr-util-1.5.2.tar.bz2 
[root@localhost ~]# cd apr-util-1.5.2
[root@localhost apr-util-1.5.2]# ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr
[root@localhost apr-util-1.5.2]#make&&make install
#编译安装httpd程序包
[root@localhost ~]# tar xf httpd-2.4.10.tar.bz2 
[root@localhost ~]# cd httpd-2.4.9
[root@localhost httpd-2.4.10]# ./configure --prefix=/usr/local/apache --sysconfdir=/etc/httpd --enable-so --enable-ssl --enable-cgi --enable-rewrite --with-zlib --with-pcre --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util --enable-modules=most --enable-mpms-shared=all --with-mpm=event
#导出库文件,man文档和添加当前二进制程序路径到PATH环境变量

#导出库文件
[root@localhost httpd-2.4.10]# cd /usr/include/
[root@localhost include]# ln -sv /usr/local/apache/include/  httpd
`httpd' -> `/usr/local/apache/include/'
#添加man文档路径
[root@localhost man]# vim /etc/man.config

#添加二进制程序路径
[root@localhost man]# vim /etc/profile.d/httpd.sh

[root@localhost man]# . /etc/profile.d/httpd.sh
[root@localhost man]# echo $PATH
/usr/local/apache/bin:/usr/lib64/qt-3.3/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin

#修改配置文件和添加服务脚本
#这里只需要将原rpm包的启动脚本拷贝进来,进行简单修改即可

[root@localhost init.d]# vim httpd

#添加脚本,并且启动程序
[root@localhost init.d]# chkconfig --add httpd 
[root@localhost init.d]# chkconfig --list httpd
httpd           0:off   1:off   2:off   3:off   4:off   5:off   6:off
[root@localhost init.d]# service httpd start
如果你一直按照这个过程操作过来,有可能出现
[root@localhost htdocs]# service httpd status
httpd dead but subsys locked
这时请将原来的paifile 的路径在启动服务脚本httpd和配置文件httpd.conf中修改为PidFile=/var/run/httpd.pid
补充:
(1)构建MPM为静态模块
在全部平台中,MPM都可以构建为静态模块。在构建时选择一种MPM,链接到服务器中。如果要改变MPM,必须重新构建。为了使用指定的MPM,请在执行configure脚本 时,使用参数 --with-mpm=NAME。NAME是指定的MPM名称。编译完成后,可以使用 ./httpd -l 来确定选择的MPM。 此命令会列出编译到服务器程序中的所有模块,包括 MPM。
(2)构建 MPM 为动态模块
在Unix或类似平台中,MPM可以构建为动态模块,与其它动态模块一样在运行时加载。 构建 MPM 为动态模块允许通过修改LoadModule指令内容来改变MPM,而不用重新构建服务器程序。在执行configure脚本时,使用--enable-mpms-shared选项即可启用此特性。当给出的参数为all时,所有此平台支持的MPM模块都会被安装。还可以在参数中给出模块列表。默认MPM,可以自动选择或者在执行configure脚本时通过--with-mpm选项来指定,然后出现在生成的服务器配置文件中。编辑LoadModule指令内容可以选择不同的MPM

  三、MySQL编译安装

MySQ的数据文件我们应该单独放在一个可以扩展的分区上面,因为随着时间增长他会逐渐变大

   1. 创建逻辑分区
[root@localhost ~]# fdisk /dev/sdb
#注意:修改分区类型8e
[root@localhost ~]# pvcreate /dev/sdb5
[root@localhost ~]# vgcreate data /dev/sdb5
[root@localhost ~]# lvcreate -n mydata -L 6G data
[root@localhost ~]# mkfs.ext4  /dev/mapper/data-mydata 
#文件的系统其他属性根据实际需要自行制定,这里使用默认
[root@localhost ~]# mount /dev/mapper/data-mydata /data
[root@localhost data]# mkdir data
#作为数据库存放目录
[root@localhost data]# groupadd -r mysql
[root@localhost data]# useradd -r -g mysql -s /sbin/nologin -M -d /data/data mysql
#创建用户和用户组
[root@localhost data]# tar xf /root/mysql-5.5.52-linux2.6-x86_64.tar.gz -C /usr/local
#解压MySQL压缩文件
[root@localhost local]# ln -sv mysql-5.5.52-linux2.6-x86_64/ mysql
`mysql' -> `mysql-5.5.52-linux2.6-x86_64/'
#创建软连接便于管理
[root@localhost mysql]# chown -R mysql. .
[root@localhost mysql]# scripts/mysql_install_db --user=mysql --data=/data/data
[root@localhost mysql]#  chown -R root  .
#记得属主修改回来,为了安全。
[root@localhost local]# cd mysql
[root@localhost support-files]# cp my-large.cnf  /etc/my.cnf
#这里根据你的需要拷贝配置文件一下红圈内都是配置文件
#并修改此文件中thread_concurrency的值为你的CPU个数乘以2,比如这里使用如下行:
thread_concurrency = 2
#另外还需要添加如下行指定mysql数据文件的存放位置:
datadir = /mydata/data

[root@localhost data]# chown -R mysql. /data #将数据库文件的属主和属组都设置为mysql [root@localhost mysql]# cp support-files/mysql.server /etc/init.d/mysqld [root@localhost mysql]# chmod +x /etc/init.d/mysqld [root@localhost mysql]# chkconfig --add /etc/init.d/mysqld [root@localhost mysql]# chkconfig --list mysqld #这里可以测试启动,不过还没添加mysql的man文档,命令路径,头文件,库文件 

[root@localhost local]# cd /usr/include/
[root@localhost include]# ln -sv /usr/local/mysql/include/ mysql

[root@localhost lib]# vim /etc/ld.so.conf.d/mysql.conf

[root@localhost lib]# ldconfig 
[root@localhost lib]# vim /etc/profile.d/mysqld.sh

[root@localhost lib]# . /etc/profile.d/mysqld.sh

可以尝试启动,如果存在错误,就在/data/data/localhost.localdomain.err查看为什么启动错误,这个文件存在未指定的数据库存放路径下,文件名为你的主机名.err。

可以开始登陆mysql,登陆上mysql后,我们需要将所有的匿名账户删除,把所有的账户都设置密码,具体操作如下。
        # 所有语句均是SQL语句,需要在mysql客服端执行。
        use mysql
        SELECT user,host,password FROM user;
        DROP USER ''@'localhost';
        UPDATE user SET password=PASSWORD('114477') WHERE user='root';
        FLUSH PRIVILEGES;
        #操作完后我们发现需要密码登陆,为了方便我们也可以在家目录下创建一个隐藏文件。
        [root@localhost ~]# vim .my.cnf
        #如此再次登陆mysql发现就不需要密码了


  四、PHP编译安装

   1.PHP编译安装还需要依赖'Desktop Platform Development'
[root@localhost yum.repos.d]# yum groupinstall -y 'Desktop Platform Development'
[root@localhost yum.repos.d]# yum -y install bzip2-devel libmcrypt-devel
[root@localhost ~]# tar xf php-5.4.26.tar.bz2
[root@localhost ~]# cd php-5.4.26
[root@localhost php-5.4.26]# ./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
[root@localhost php-5.4.26]# make
#make 结束后,会提示你让你make test,但是我尝试几次make test 都失败了,错误提示各种各样,百思不得其解。换了php版本依旧这样,最后在网上求助一网友,他告诉我直接make && make install ,不用make test 。结果居然成功,没有报错。
[root@localhost php-5.4.26]# make install
[root@localhost php-5.4.26]# 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
如下图

[root@localhost ~]# cd /usr/local/apache/htdocs/ [root@localhost htdocs]# mv index.html index.php [root@localhost htdocs]# vim index.php 

[root@localhost ~]#  ab -c 100 -n 1000 http://192.168.32.5/index.php
#进行压力测试,结果如下
Server Software:        Apache/2.4.10 
#服务器Apache版本
Server Hostname:        192.168.32.5
#服务器主机名
Server Port:            80
#服务器开启端口
Document Path:          /index.php
#请求的文件的相对路径
Document Length:        69411 bytes
#请求的文件的大小
Concurrency Level:      100
#并发用户数
Time taken for tests:   3.910 seconds
#测试一共使用时间
Complete requests:      1000
#测试完成的请求个数
Failed requests:        96
   (Connect: 0, Receive: 0, Length: 96, Exceptions: 0)
#测试失败的个数
Write errors:           0
#写错误
Total transferred:      69592892 bytes
#总共传送的字节,包括首部因此HTML大
HTML transferred:       69410892 bytes
#传送的HTML的字节
Requests per second:    255.73 [#/sec] (mean)
#吞吐率
#概念:服务器并发处理能力的量化描述,单位是reqs/s,指的是某个并发用户数下单位时间内处理的请求数。某个并发用户数下单位时间内能处理的最大请求数,称之为最大吞吐率。
#计算公式:总请求数 / 处理完成这些请求数所花费的时间。
Time per request:       391.040 [ms] (mean)
#用户平均请求等待时间,计算公式:处理完成所有请求数所花费的时间/ (总请求数 / 并发用户数)
Time per request:       3.910 [ms] (mean, across all concurrent requests)
#服务器平均请求等待时间,计算公式:处理完成所有请求数所花费的时间 / 总请求数
Transfer rate:          17379.75 [Kbytes/sec] received
#平均每秒网络上的流量,可以帮助排除是否存在网络流量过大导致响应时间延长的问题
Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    2   3.5      1      18
#连接
Processing:     6  287 413.1    159    3138
#处理
Waiting:        3  269 415.6    142    3137
#等待 
Total:          7  289 413.4    160    3148
#
Percentage of the requests served within a certain time (ms)
  50%    160
  66%    203
  75%    232
  80%    268
  90%   1007
  95%   1111
  98%   1184
  99%   3014
 100%   3148 (longest request)
#//整个场景中所有请求的响应情况。在场景中每个请求都有一个响应时间,其中50%的用户响应时间小于160 毫秒,60% 的用户响应时间小于203 毫秒,最大的响应时间小于3148 毫秒。由于对于并发请求,cpu实际上并不是同时处理的,而是按照每个请求获得的时间片逐个轮转处理的,所以基本上第一个Time per request时间约等于第二个Time per request时间乘以并发请求数

  五、启用xcache加速

#1.安装xcache
[root@localhost ~]# tar xf xcache-3.2.0.tar.gz 
[root@localhost ~]# cd xcache-3.2.0
[root@localhost xcache-3.2.0]# /usr/local/php/bin/phpize
#切记这个命令需要在被扩展的目录下才能执行,不然他会提示错误 
[root@localhost xcache-3.2.0]# ./configure --enable-xcache --with-php-config=/usr/local/php/bin/php-config
[root@localhost xcache-3.2.0]# make && make install
#Installing shared extensions:     /usr/local/php/lib/php/extensions/no-debug-zts-20131226/
#将这条路径复制到一个文本文件中,随后会用到

#2、编辑php.ini,整合php和xcache:
#首先将xcache提供的样例配置导入php.ini
[root@localhost xcache-3.2.0]# mkdir /etc/php.d
[root@localhost xcache-3.2.0]# cp xcache.ini /etc/php.d
[root@localhost xcache-3.2.0]#vim /etc/php.d/xcache.ini

注意:如果php.ini文件中有多条zend_extension指令行,要确保此新增的行排在第一位。

  五、PHP-fpm编译安装

[root@localhost ~]# yum -y groupinstall "X Software Development
#httpd和mysql的编译还是前面的操作
如果想让编译的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)版本和你当前服务的版本相通的rpm包

#1.开始编译
[root@localhost ~]#tar xf php-5.4.26.tar.bz2
[root@localhost ~]# cd php-5.4.26
[root@localhost php-5.4.26]# ./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
#说明:如果使用PHP5.3以上版本,为了链接MySQL数据库,可以指定mysqlnd,这样在本机就不需要先安装MySQL或MySQL开发包了。mysqlnd从php 5.3开始可用,可以编译时绑定到它(而不用和具体的MySQL客户端库绑定形成依赖),但从PHP 5.4开始它就是默认设置了。
#e.g. # ./configure --with-mysql=mysqlnd --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd

[root@localhost php-5.4.26]# cp php.ini-production /etc/php.ini

2、配置php-fpm

#为php-fpm提供SysV init脚本,并将其添加至服务列表:
[root@localhost php-5.4.26]# cp sapi/fpm/init.d.php-fpm  /etc/rc.d/init.d/php-fpm
#源码目录下
[root@localhost php-5.4.26]# chmod +x /etc/rc.d/init.d/php-fpm
[root@localhost php-5.4.26]# chkconfig --add php-fpm
[root@localhost php-5.4.26]# chkconfig php-fpm on

#编辑php-fpm的配置文件:
[root@localhost php-5.4.26]#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了:
[root@localhost php-5.4.26]#service php-fpm start
#接下来可以启动测试。
#在加上xcache会更加提高效率,将前面的xcache编译执行一次
执行编译完成后,因为php是通过php-fpm管理,重新启动php-fpm即可

总结:

  1.本次实验中遇到了编译httpd出错,当时解决方案是将--enable-mpms-shared=most,这个参数改为--enable-mpms-shared=all

  2.遇到不知道如何使用MySQL,完全不熟悉MySQL语句。和mysql完全启动不起来,然后根据/data/data/localhost.localdomain.err查看为什么启动错误,这个文件存在未指定的数据库存放路径下,文件名为你的主机名.err。发现pid文件路径写错了。MySQL服务脚本无法创建pid文件。

  3.编译安装xcache出错,原因因为/usr/local/php/bin/phpize这个命令需在被扩展的模块的源码目录下才能执行。

  4.存在疑问,是php-fpm这个如何在不同主机上面配置,需要进一步学习。