lamp-优化

目录



I.php的工作模式

回目录

phplamp环境下共有三种工作模式:

  • CGI模式
  • apache模块
  • FastCGI模式

CGI模式下运行PHP,性能不是很好。作为apache的模块方式运行,在以前的课程中编译安装lamp已经介绍过了。FastCGI的方式和apache模块的不同点在于:FastCGI方式PHP是一处独立的进程,所有PHP子进程都由PHP的一个叫作php-fpm的组件负责管理;而apache模块化方式运行的PHP,则是apache负责调用PHP完成工作。PHPFastCGI方式性能要比apache模块化方式强很多,今天我们以FastCGI方式编译安装lamp

FastCGI工作机制

回目录

首先客户端发起请求,请求分为2种,一种是静态请求它可以直接由Apache直接响应返回;另一种是动态的请求,如其中包含中php或者Perl这种脚本解释性语言,则由Apache服务器通过fastcgi协议调用php服务器执行并返回给Apache由Apache返回解释执行后的结果,如果这个过程中涉及到对数据的操作,此时php服务器还会还会通过mysql协议调用mysql服务器。



II.编译环境及各软件版本

回目录

Linux Web服务器 Php Mysql数据库 xcache
Centos7.2 Httpd-2.4.23 php-5.4.26 Mysql5.7 xcache-3.1.0

主机规划

至少3台主机,操作系统都是centos7.2.网段在192.168.197.0/24网关192.168.197.2 分配如下:

  • 1台httpd服务器(192.168.31.83
  • 1台php服务器 (192.168.31.141
  • 1台mysql服务器(192.168.31.225

i.编译安装LAMP

回目录

编译安装apache(请参考前面apache的安装) 编译安装mysql(请参考mysql安装) FastCGI方式安装php

ii.解决依赖关系

回目录

[root@phpserver ~]# yum -y install libxml2-devel lzip2-devel libcurl-devel libmcrypt-devel openssl-devel bzip2-devel

安装libmcrypt

[root@phpserver ~]# tar zxf libmcrypt-2.5.7.tar.gz 
[root@phpserver ~]# cd libmcrypt-2.5.7/
[root@phpserver libmcrypt-2.5.7]# ./configure --prefix=/usr/local/libmcrypt && make && make install

iii.编译安装php

回目录

[root@phpserver ~]# tar zxf php-5.6.27.tar.gz
[root@phpserver ~]# cd php-5.6.27/
[root@phpserver php-5.6.27]# ./configure --prefix=/usr/local/php5.6 --with-mysql=mysqlnd --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd --with-openssl --enable-fpm --enable-sockets --enable-sysvshm --enable-mbstring --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --with-mhash --with-mcrypt=/usr/local/libmcrypt --with-config-file-path=/etc --with-config-file-scan-dir=/etc/php.d --with-bz2 --enable-maintainer-zts
[root@phpserver php-5.6.27]# make && make install

相关选项的解释

回目录

  • --prefix=/usr/local/php5.6 //安装位置
  • --with-mysql=mysqlnd //支持mysql
  • --with-pdo-mysql=mysqlnd //支持pdo模块
  • --with-mysqli=mysqlnd //支持mysqli模块 注:上面的三选项的作用:数据库与php不在一个服务器上,指定此种方式,安装数据库连接驱动

  • --with-openssl //支持openssl模块

  • --enable-fpm //支持fpm模式
  • --enable-sockets //启用socket支持
  • --enable-sysvshm //启用系统共享内存支持
  • --enable-mbstring //多字节字串、像我们的中文就是多字节字串
  • --with-freetype-dir //支持freetype、就要装freetype-devel、跟字体相关的、字体解析工具
  • --with-jpeg-dir
  • --with-png-dir 注:上面的二选项的作用:处理jpeg、png图片的、php可以动态生成jpeg图片

  • --with-zlib //是个压缩库、在互联网传输时用来压缩传输的

  • --with-libxml-dir=/usr //这个libxml是用来解析xml的、指定/usr下
  • --enable-xml //支持xml的
  • --with-mhash //支持mhash
  • --with-mcrypt=/usr/local/libmcrypt //libmcrypt-devel这个程序包所指定的
  • --with-config-file-path=/etc //指定配置文件的存放路径的
  • --with-config-file-scan-dir=/etc/php.d //配置文件扫描路径
  • --with-bz2 //支持BZip2

为了支持apache的workerevent这两个MPM,编译时使用了--enable-maintainer-zts选项如果使用PHP5.3以上版本,为了链接MySQL数据库,可以指定mysqlnd,这样在本机就不需要先安装MySQL或MySQL开发包了。mysqlndphp 5.3开始可用,可以编译时绑定到它(而不用和具体的MySQL客户端库绑定形成依赖),但从PHP 5.4开始它就是默认设置了。

iv.提供php配置文件

回目录

[root@phpserver php-5.6.27]# cp php.ini-production /etc /php.ini

v.为php-fpm提供脚本

回目录

[root@phpserver php-5.6.27]# cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm
[root@phpserver php-5.6.27]# chmod +x /etc/init.d/php-fpm 
[root@phpserver php-5.6.27]# chkconfig --add php-fpm
[root@phpserver php-5.6.27]# chkconfig php-fpm on

vi.提供php-fpm配置文件并编辑

回目录

# cp /usr/local/php5.6/etc/php-fpm.conf.default /usr/local/php5.6/etc/php-fpm.conf
[root@phpserver ~]# vi /usr/local/php5.6/etc/php-fpm.conf

修改内容如下

pid = run/php-fpm.pid
listen = 192.168.31.141:9000
pm.max_children = 50
pm.start_servers = 5
pm.min_spare_servers = 5
pm.max_spare_servers = 35

启动php-fpm服务

[root@phpserver ~]# service  php-fpm start
Starting php-fpm  done
[root@phpserver ~]# netstat -anpt | grep php-fpm
tcp        0      0 0.0.0.0:9000            0.0.0.0:*               LISTEN      25456/php-fpm: mast 
[root@phpserver ~]# firewall-cmd --permanent --add-port=9000/tcp
success
[root@phpserver ~]# firewall-cmd --reload
Success

在该主机上新建虚拟主机目录用于存放网页文件

[root@phpserver ~]# mkdir -p /var/www/benet

至此php安装配置完毕,下面配置apache通过fastcgi协议调用php

vii.配置apache(切换到apache主机上操作)

回目录

在Apache2.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
[root@www ~]# apachectl -M | grep proxy
 proxy_module (shared)
 proxy_fcgi_module (shared)

建立一个目录作为虚拟主机的家目录

[root@www ~]# mkdir -p /var/www/benet

编辑主配置文件httpd.conf,开启虚拟主机

启用Include conf/extra/httpd-vhosts.conf 同时定位AddType;添加下面两行:让apache能识别php格式的页面

AddType application/x-httpd-php .php
AddType application/x-httpd-php-source .phps

并且定位至DirectoryIndex :支持php格式的主页 DirectoryIndex index.php index.html #添加index.php(最好添加在最前面)

配置虚拟主机支持使用fcgi

[root@www ~]# vi /usr/local/http-2.4.23/conf/extra/httpd-vhosts.conf
<VirtualHost *:80>
    ServerAdmin [email protected]
    DocumentRoot "/var/www/benet"
    ServerName www.benet.com
    ServerAlias benet.com
    ErrorLog "logs/benet.com-error_log"
    CustomLog "logs/benet.com-access_log" common
    ProxyRequests Off
    ProxyPassMatch  ^/(.*\.php(/.*)?)$  fcgi://192.168.31.141:9000/var/www/benet/$1
    #<LocationMatch "^(.*\.php(/.*)?)$">
    #  ProxyPass fcgi://192.168.31.141:9000/var/www/benet
    #</LocationMatch>
    <Directory "/var/www/benet">
       Options  FollowSymLinks
       AllowOverride None
       Require all granted
    </Directory>
</VirtualHost>

其中:

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

特别注意的是,/var/www/benet部分需要与<VirtualHost >中的DocumentRoot 后的路径一致ProxyPassMatch只有满足特定正则模式的内容才会匹配并执行此规则,这里的模式是,^/(.*\.php(/.*)?)$从网站(虚拟主机 <VirtualHost >的根目录开始,匹配任何以.php结尾,或者在 .php之后紧跟一个 /再跟别的内容的路径。^ (caret)$ (dollar)标志要匹配的路径的开始和结束( )括号里的内容可以用 $1来表示,以方便后面引用它。

fcgi:// 192.168.31.141:9000通过mod_proxy_fcgi来转发的代理,使用fastCGI协议,转到 PHP-FPM监听的端口。

/path/to/your/documentroot/非常重要!必须与虚拟主机的路径匹配,且必须是对应 php文件在操作系统中的绝对路径。否则会找不到文件。

$1可以从原始请求扩展成整个请求路径的变量,这里指代前面( )里面匹配的那个路径(uri)

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


III.测试LAMP环境

回目录

mysql主机上创建用于php服务器连接的mysql账户

mysql> grant all on *.* to testuser@'%' identified by '123456;

注意防火墙要允许mysql连接。

php服务器上的/var/www/benet目录下创建.php的测试页:

[root@phpserver ~]# cat /var/www/benet/index.php 
<?php
phpinfo();
?>
[root@phpserver ~]# cat /var/www/benet/test1.php 
<?php
$link=mysql_connect('192.168.31.225','testuser','123456');
if ($link)echo "connection success......";
mysql_close();
?>

测试访问php测试页:

5

6

看到上面两个测试页说明apachephpmysql之间可以协同工作了。

i.压力测试

回目录

网站性能压力测试是服务器网站性能调优过程中必不可缺少的一环。只有让服务器处在高压情况下,才能真正体现出软件、硬件等各种设置不当所暴露出的问题。

性能测试工具目前最常见的有以下几种:abhttp_loadwebbenchsiege。今天我们专门来介绍ababapache自带的压力测试工具。ab非常实用,它不仅可以对apache服务器进行网站访问压力测试,也可以对或其它类型的服务器进行压力测试。比如nginxtomcatIIS等。

下面我们开始介绍有关ab命令的使用:

1.ab的原理
2.ab的安装
3.ab参数说明
4.ab性能指标
5.ab实际使用
6.测试nginx性能

1.ab的原理

回目录

abapachebench命令的缩写。

ab的原理:ab命令会创建多个并发访问线程,模拟多个访问者同时对某一URL地址进行访问。它的测试目标是基于URL的,因此,它既可以用来测试apache的负载压力,也可以测试nginx、lighthttp、tomcat、IIS等其它Web服务器的压力。

ab命令对发出负载的计算机要求很低,它既不会占用很高CPU,也不会占用很多内存。但却会给目标服务器造成巨大的负载,其原理类似CC攻击。自己测试使用也需要注意,否则一次上太多的负载。可能造成目标服务器资源耗完,严重时甚至导致死机。

2.ab的安装

回目录

ab的安装非常简单,如果是源码安装apache的话,那就更简单了。apache安装完毕后ab命令存放在apache安装目录的bin目录下。如下:

/usr/local/http2.4.23/bin/ab

如果apache 是通过yumRPM包方式安装的话,ab命令默认存放在/usr/bin目录下。如下:

which ab

注意:如果不想安装apache但是又想使用ab命令的话,我们可以直接安装apache的工具包httpd-tools。如下:

yum -y install httpd-tools

查看ab是否安装成功,可以切换到上述目录下,使用ab –V命令进行检测。如下:

[root@www ~]# /usr/local/http-2.4.23/bin/ab -V
This is ApacheBench, Version 2.3 <$Revision: 1748469 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

3.ab参数说明

回目录

有关ab命令的使用,我们可以通过帮助命令进行查看。如下:

[root@cent05 ~]# ab --help

下面我们对这些参数,进行相关说明。如下:

  • -n:在测试会话中所执行的请求个数(即总请求数)。
  • -c:一次产生的请求个数(即并发用户数)。
[root@www ~]# ab -c 500 -n 10000 http://192.168.31.83/index.html
This is ApacheBench, Version 2.3 <$Revision: 1748469 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking 192.168.31.83 (be patient)
Completed 1000 requests
Completed 2000 requests
Completed 3000 requests
Completed 4000 requests
Completed 5000 requests
Completed 6000 requests
Completed 7000 requests
Completed 8000 requests
Completed 9000 requests
Completed 10000 requests
Finished 10000 requests


Server Software:        Apache
Server Hostname:        192.168.31.83
Server Port:            80

Document Path:          /index.html    #请求的资源
Document Length:        312 bytes   #HTTP响应数据的正文长度

Concurrency Level:      500   #并发个数(并发用户数)
Time taken for tests:   1.452 seconds   #所有这些请求处理完成所花费的时间 
Complete requests:      10000    #完成请求数
Failed requests:        0          #失败的请求数
Non-2xx responses:      10000
Total transferred:      4760000 bytes  #表示所有请求的响应数据长度总和,包括每个HTTP响应数据的头信息和正文数据的长度。注意这里不包括HTTP请求数据的长度,仅仅为web服务器流向用户PC的应用层数据总长度。 
HTML transferred:       3120000 bytes   # 表示所有请求的响应数据中正文数据的总和,也就是减去了Total transferred中HTTP响应数据中的头信息的长度。
Requests per second:    7530.93 [#/sec] (mean)    #吞吐量-每秒请求数。计算公式:Complete requests/Time taken for tests
Time per request:       66.393 [ms] (mean) #用户平均请求等待时间,计算公式:Time token for tests/(Complete requests/Concurrency Level)。
Time per request:       0.133 [ms] (mean, across all concurrent requests)  #服务器平均请求等待时间,计算公式:Time taken for tests/Complete requests。
Transfer rate:          3500.71 [Kbytes/sec] received #表示这些请求在单位时间内从服务器获取的数据长度,计算公式:Total trnasferred/ Time taken for tests,这个统计很好的说明服务器的处理能力达到极限时,其出口宽带的需求量。(即平均每秒网络上的流量)

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:       10   27   7.3     27      48
Processing:     4   37  36.5     32     439
Waiting:        2   27  37.0     21     435
Total:         30   64  37.6     60     470

Percentage of the requests served within a certain time (ms)
  50%     60
  66%     63
  75%     64
  80%     66
  90%     71
  95%     76
  98%     89
  99%    261
 100%    470 (longest request)

这部分数据用于描述每个请求处理时间的分布情况,比如以上测试,80%的请求处理时间都不超过66ms,这个处理时间是指前面的Time per request,即对于单个用户而言,平均每个请求的处理时间。

继续压力测试 我们再来进行一次压力测试,此时并发用户数为1000,其他条件不变,查看两次测试结果的吞吐量差别

4.ab性能指标

回目录

在进行性能测试过程中有几个指标比较重要:

4.1 吞吐率(Requests per second

回目录

服务器并发处理能力的量化描述,单位是reqs/s,指的是在某个并发用户数下单位时间内处理的请求数。某个并发用户数下单位时间内能处理的最大请求数,称之为最大吞吐率。 记住:吞吐率是基于并发用户数的。这句话代表了两个含义:

  • a、吞吐率和并发用户数相关
  • b、不同的并发用户数下,吞吐率一般是不同的

计算公式:总请求数/处理完成这些请求数所花费的时间,即

Request per second=Complete requests/Time taken for tests

必须要说明的是,这个数值表示当前机器的整体性能,值越大越好。

4.2 并发连接数(The number of concurrent connections

回目录

并发连接数指的是某个时刻服务器所接受的请求数目,简单的讲,就是一个会话。

4.3 并发用户数(Concurrency Level

回目录

要注意区分这个概念和并发连接数之间的区别,一个用户可能同时会产生多个会话,也即连接数。

4.4 用户平均请求等待时间(Time per request

回目录

计算公式:处理完成所有请求数所花费的时间/(总请求数/并发用户数),即:

Time per request=Time taken for tests/(Complete requests/Concurrency Level)

4.5 服务器平均请求等待时间(Time per request:across all concurrent requests

回目录

计算公式:处理完成所有请求数所花费的时间/总请求数,即:

Time taken for/testsComplete requests

可以看到,它是吞吐率的倒数。 同时,它也等于用户平均请求等待时间/并发用户数,即

Time per request/Concurrency Level

ii.CentOS7.2下安装php加速软件Xcache(在php主机上完成下面的操作)

回目录

说明:

  • php安装目录:/usr/local/php5.6
  • php.ini配置文件路径:/etc/php.ini
  • php网页根目录:/var/www/benet

1.安装xcache

回目录

wget http://xcache.lighttpd.net/pub/Releases/3.2.0/xcache-3.2.0.tar.gz #下载

[root@phpserver ~]# tar zxf xcache-3.2.0.tar.gz    #解压
[root@phpserver ~]# cd xcache-3.2.0/    #进入安装目录
[root@phpserver xcache-3.2.0]# /usr/local/php5.6/bin/phpize #用phpize生成configure配置文件
[root@phpserver xcache-3.2.0]# ./configure --enable-xcache --enable-xcache-coverager --enable-xcache-optimizer --with-php-config=/usr/local/php5.6/bin/php-config  #配置
[root@phpserver xcache-3.2.0]# make && make install  #编译、安装

Installing shared extensions:     /usr/local/php5.6/lib/php/extensions/no-debug-zts-20131226/

安装完成之后,出现下面的界面,记住以下路径,后面会用到

/usr/local/php5.6/lib/php/extensions/no-debug-zts-20131226/

2.创建xcache缓存文件

回目录

# touch /tmp/xcache
# chmod 777 /tmp/xcache

3.拷贝xcache后台管理程序到网站根目录

回目录

[root@phpserver xcache-3.2.0]# cp -r htdocs/ /var/www/benet/xcache

4.配置php支持xcache

回目录

vi / etc/php.ini #编辑配置文件,在最后一行添加以下内容

[xcache-common]
extension = /usr/local/php5.6/lib/php/extensions/no-debug-zts-20131226/xcache.so
[xcache.admin]
xcache.admin.enable_auth = Off
[xcache]
xcache.shm_scheme ="mmap"
xcache.size=60M
xcache.count =1
xcache.slots =8K
xcache.ttl=0
xcache.gc_interval =0
xcache.var_size=64M
xcache.var_count =1
xcache.var_slots =8K
xcache.var_ttl=0
xcache.var_maxttl=0
xcache.var_gc_interval =300
xcache.test =Off
xcache.readonly_protection = Off
xcache.mmap_path ="/tmp/xcache"
xcache.coredump_directory =""
xcache.cacher =On
xcache.stat=On
xcache.optimizer =Off
[xcache.coverager]
xcache.coverager =On
xcache.coveragedump_directory =""

xcache目录拷贝到apache主机的网页文档目录下

[root@phpserver ~]# scp -r /var/www/benet/xcache/ [email protected]:/var/www/benet/

5.测试

回目录

service php-fpm restart #重启php-fpm

浏览器打开网站根目录下面的xcache

http:// http://192.168.31.83/xcache  

可以看到如下页面:

7

至此,Linux下安装php加速软件Xcache教程完成

执行ab压力测试

执行第一次压力测试:

[root@www ~]# ab -c 100 -n 1000 http://192.168.31.83/index.php
This is ApacheBench, Version 2.3 <$Revision: 1748469 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking 192.168.31.83 (be patient)
Completed 100 requests
Completed 200 requests
Completed 300 requests
Completed 400 requests
Completed 500 requests
Completed 600 requests
Completed 700 requests
Completed 800 requests
Completed 900 requests
Completed 1000 requests
Finished 1000 requests


Server Software:        Apache
Server Hostname:        192.168.31.83
Server Port:            80

Document Path:          /index.php
Document Length:        85006 bytes

Concurrency Level:      100
Time taken for tests:   1.773 seconds
Complete requests:      1000
Failed requests:        368
   (Connect: 0, Receive: 0, Length: 368, Exceptions: 0)
Total transferred:      85259504 bytes
HTML transferred:       85013504 bytes
Requests per second:    563.88 [#/sec] (mean)
Time per request:       177.344 [ms] (mean)
Time per request:       1.773 [ms] (mean, across all concurrent requests)
Transfer rate:          46948.95 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    1   2.7      0      16
Processing:    31  167  73.7    140     406
Waiting:       23  162  73.1    136     401
Total:         40  168  73.0    141     406

Percentage of the requests served within a certain time (ms)
  50%    141
  66%    152
  75%    176
  80%    188
  90%    294
  95%    389
  98%    396
  99%    400
 100%    406 (longest request)

执行第二次压力测试

[root@www ~]# ab -c 100 -n 1000 http://192.168.31.83/index.php
This is ApacheBench, Version 2.3 <$Revision: 1748469 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking 192.168.31.83 (be patient)
Completed 100 requests
Completed 200 requests
Completed 300 requests
Completed 400 requests
Completed 500 requests
Completed 600 requests
Completed 700 requests
Completed 800 requests
Completed 900 requests
Completed 1000 requests
Finished 1000 requests


Server Software:        Apache
Server Hostname:        192.168.31.83
Server Port:            80

Document Path:          /index.php
Document Length:        85006 bytes

Concurrency Level:      100
Time taken for tests:   1.264 seconds
Complete requests:      1000
Failed requests:        316
   (Connect: 0, Receive: 0, Length: 316, Exceptions: 0)
Total transferred:      85257983 bytes
HTML transferred:       85011983 bytes
Requests per second:    790.93 [#/sec] (mean)
Time per request:       126.434 [ms] (mean)
Time per request:       1.264 [ms] (mean, across all concurrent requests)
Transfer rate:          65852.24 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    1   2.7      0      11
Processing:    33  120  20.6    120     180
Waiting:       28  115  20.0    115     179
Total:         44  121  19.2    121     180

Percentage of the requests served within a certain time (ms)
  50%    121
  66%    124
  75%    127
  80%    128
  90%    147
  95%    159
  98%    166
  99%    169
 100%    180 (longest request)

查看xcache的命中率:

8

回目录


results matching ""

    No results matching ""