nginx+php-FastCGI+mysql性能测试

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:
 
照着张宴的那篇经典的nginx配置文章做的,主要是记录一下自己步骤和测试。
 
准备系统和软件就不写了。
 
一、安装PHP 5.2.8(FastCGI模式)
1、编译安装PHP 5.2.8所需的支持库:
与原文相同。
2、rpm安装msyql
3、编译安装PHP 5.2.8(FastCGI模式)
原来的改成:#./configure --prefix=/usr/local/php --with-config-file-path=/etc/php --with-mysql=/usr/lib/mysql --with-mysqli=/usr/bin/mysql_config --with-iconv-dir=/usr/local --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --disable-rpath --enable-discard-path --enable-safe-mode --enable-bcmath --enable-shmop --enable-sysvsem --enable-inline-optimization --with-curl --with-curlwrappers --enable-mbregex --enable-fastcgi --enable-fpm --enable-force-cgi-redirect --enable-mbstring --with-mcrypt --with-gd --enable-gd-native-ttf --with-openssl --with-mhash --enable-pcntl --enable-sockets
修改的内容为:#./configure --prefix=/usr/local/php --with-config-file-path=/etc/php --with-mysql=/usr/lib/mysql --with-mysqli=/usr/bin/mysql_config
注意缺少东西时:
#rpm -ivh libjpeg-devel…….rpm
#rpm -ivh libpng-devel…….rpm
#yum install freetype-devel
配置文件位置改为:/etc/php
#mkdir /etc/php -p
#cp php.ini-dist /etc/php/php.ini
4、编译安装PHP5扩展模块
#tar zxf memcache-2.2.4.tgz
#cd memcache-2.2.4/
#/usr/local/php/bin/phpize 注意缺少东西时:#rpm -ivh imake #rpm -ivh autoconf
#./configure --with-php-config=/usr/local/php/bin/php-config
#make
#make install
#cd ../
#tar jxf eaccelerator-0.9.5.3.tar.bz2
#cd eaccelerator-0.9.5.3
#/usr/local/php/bin/phpize
#./configure --enable-eaccelerator=shared --with-php-config=/usr/local/php/bin/php-config
#make
#make install
#cd ../
#tar zxf PDO_MYSQL-1.0.2.tgz
#cd PDO_MYSQL-1.0.2
#/usr/local/php/bin/phpize
#./configure --with-php-config=/usr/local/php/bin/php-config --with-pdo-mysql 注意这里没有制定目录。
#make
#make install
#cd ../
5、修改php.ini文件
手工修改:查找/usr/local/webserver/php/etc/php.ini中的extension_dir = "./"
修改为extension_dir = "/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613"
并在此行后增加以下几行,然后保存:
extension = "memcache.so"
extension = "pdo_mysql.so"
再查找output_buffering = Off
修改为output_buffering = .
6、配置eAccelerator加速PHP:
#mkdir -p /mnt/eaccelerator_cache
#vi /etc/php/php.ini 用shift+g到文件尾,添加:
[eaccelerator]
zend_extension="/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/eaccelerator.so"
eaccelerator.shm_size="64" (由于是虚拟机所以调小了)
eaccelerator.cache_dir="/mnt/eaccelerator_cache"
eaccelerator.enable="1"
eaccelerator.optimizer="1"
eaccelerator.check_mtime="1"
eaccelerator.debug="0"
eaccelerator.filter=""
eaccelerator.shm_max="0"
eaccelerator.shm_ttl="300"
eaccelerator.shm_prune_period="120"
eaccelerator.shm_only="0"
eaccelerator.compress="1"
eaccelerator.compress_level="9"
其他与原文相同。
7、修改/usr/local/php/etc/php-fpm.conf:
主要修改pid和log文件位置、max_children、rlimit_files、display_errors等以适应虚拟机内存大小。
8、启动php-cgi进程,监听127.0.0.1的9000端口,由于是虚拟机所以调小了max_children,所以现在启动了32个进程,用户为apache。
#ulimit -SHn 51200 ulimit是控制shell启动进程所占用的资源的命令,这里没有使用;还是出于实验环境是虚拟机的原因。
#/usr/local/php/sbin/php-fpm start
9、本来apache的,结果到这时才发现apache+FastCGI不是简单的加入下面的这几行就可以的。
FastCgiServer /usr/local/bin/php
AddHandler php-fastcgi .php
Action php-fastcgi /php-cgi/php
AddType application/x-httpd-php .php
apache说FastCgiServer是错误命令。
改成测试Nginx+FastCGI的速度。
二、安装Nginx 0.7.31
1、安装Nginx所需的pcre库:
与原文相同。
2、安装Nginx:
tar zxf nginx-0.7.31.tar.gz
cd nginx-0.7.31/
./configure --user=www --group=www --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module
make && make install
cd ../
3、创建Nginx日志目录
#mkdir /var/log/nginx -p
#chmod +w /var/log/nginx
#chown -R www:www /var/log/nginx
4、创建Nginx配置文件
除目录不同外其他与原文相同。
5、启动并配置自动启动
#vi /etc/rc.local 加入下面两行
/usr/local/php/sbin/php-fpm start
/usr/local/nginx/sbin/nginx
三、测试
1、准备phpspeed
#unzip phpspeed_v1_beta3.zip
#mv phpspeed /var/www/html
#cd phpspeed
#vi phpspeed/config_db.php
修改登陆phpspeed的用户名密码、登陆mysql的用户名密码。
config_db.php中有两组用户名密码,一组登陆phpspeed软件、一组phpspeed用于登陆数据库。
2、安装phpspeed
打开ie输入 [url]http://www.domain.com/phpspeed[/url]
按照提示安装数据库、添加数据库表。
3、使用phpspeed进行测试
安装数据库、添加数据库表完成后重新输入 [url]http://www.domain.com/phpspeed[/url]会看到类似论坛的页面。
右上角输入用户名密码(在config_db.php中配置的那个)登陆phpspeed。
使用方法看到界面不用说就会了。
4、使用tuning-primer.sh进行测试
运行tuning-primer.sh脚本,运行完成后会给出建议。
我发现我的机器没有配置query_cache_size
配置成4MB后再用phpspeed测试时,有一个指标提高了2-3倍。









本文转自 sharkyan 51CTO博客,原文链接:http://blog.51cto.com/sharkyan/127686,如需转载请自行联系原作者
目录
相关文章
|
29天前
Mybatis+mysql动态分页查询数据案例——测试类HouseDaoMybatisImplTest)
Mybatis+mysql动态分页查询数据案例——测试类HouseDaoMybatisImplTest)
20 1
|
29天前
|
Java 关系型数据库 数据库连接
Mybatis+MySQL动态分页查询数据经典案例(含代码以及测试)
Mybatis+MySQL动态分页查询数据经典案例(含代码以及测试)
24 1
原生php实现列表接口+分页接口+排序接口组合使用+包括测试数据(不加任何封装)
原生php实现列表接口+分页接口+排序接口组合使用+包括测试数据(不加任何封装)
原生php实现列表接口+分页接口+排序接口组合使用+包括测试数据(不加任何封装)
|
3月前
|
关系型数据库 MySQL PHP
|
8天前
|
PHP
web简易开发——通过php与HTML+css+mysql实现用户的登录,注册
web简易开发——通过php与HTML+css+mysql实现用户的登录,注册
|
1月前
|
NoSQL 关系型数据库 MySQL
Docker安装详细步骤及相关环境安装配置(mysql、jdk、redis、自己的私有仓库Gitlab 、C和C++环境以及Nginx服务代理)
Docker安装详细步骤及相关环境安装配置(mysql、jdk、redis、自己的私有仓库Gitlab 、C和C++环境以及Nginx服务代理)
204 0
|
1月前
|
NoSQL Java 应用服务中间件
使用innoSetup将mysql+nginx+redis+jar包打包成windows安装包
使用innoSetup将mysql+nginx+redis+jar包打包成windows安装包
使用innoSetup将mysql+nginx+redis+jar包打包成windows安装包
|
1月前
|
监控 关系型数据库 MySQL
Flink CDC产品常见问题之使用3.0测试mysql到starrocks启动报错如何解决
Flink CDC(Change Data Capture)是一个基于Apache Flink的实时数据变更捕获库,用于实现数据库的实时同步和变更流的处理;在本汇总中,我们组织了关于Flink CDC产品在实践中用户经常提出的问题及其解答,目的是辅助用户更好地理解和应用这一技术,优化实时数据处理流程。
|
2月前
|
监控 关系型数据库 MySQL
PHP与MySQL的结合:实现局域网上网行为监控软件的数据库管理
在当今信息化时代,网络安全日益成为重要的话题。为了有效监控和管理局域网上网行为,开发一个基于PHP和MySQL的数据库管理系统是一个理想的选择。本文将介绍如何结合PHP和MySQL,开发一款简单而高效的局域网上网行为监控软件,并重点关注数据库管理方面的实现。
191 0