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即可
总结: