nginx+php-FastCGI+mysql性能测试

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介:
 
照着张宴的那篇经典的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,如需转载请自行联系原作者
目录
打赏
0
0
0
0
235
分享
相关文章
ELK实现nginx、mysql、http的日志可视化实验
通过本文的步骤,你可以成功配置ELK(Elasticsearch, Logstash, Kibana)来实现nginx、mysql和http日志的可视化。通过Kibana,你可以直观地查看和分析日志数据,从而更好地监控和管理系统。希望这些步骤能帮助你在实际项目中有效地利用ELK来处理日志数据。
231 90
MySQL原理简介—3.生产环境的部署压测
本文介绍了Java系统和数据库在高并发场景下的压测要点: 1. 普通系统在4核8G机器上每秒能处理几百个请求 2. 高并发下数据库建议使用8核16G或更高配置的机器 3. 数据库部署后需进行基准压测,以评估其最大承载能力 4. QPS和TPS的区别及重要性 5. 压测时需关注IOPS、吞吐量、延迟 6. 除了QPS和TPS,还需监控CPU、内存、磁盘IO、网络带宽 7. 影响每秒可处理并发请求数的因素包括线程数、CPU、内存、磁盘IO和网络带宽 8. Sysbench是数据库压测工具,可构造测试数据并模拟高并发场景 9. 在增加线程数量的同时,必须观察机器的性能,确保各硬件负载在合理范围
164 72
源码编译安装LAMP(HTTP服务,MYSQL ,PHP,以及bbs论坛)
通过以上步骤,你可以成功地在一台Linux服务器上从源码编译并安装LAMP环境,并配置一个BBS论坛(Discuz!)。这些步骤涵盖了从安装依赖、下载源代码、配置编译到安装完成的所有细节。每个命令的解释确保了过程的透明度,使即使是非专业人士也能够理解整个流程。
47 18
使用崖山YMP 迁移 Oracle/MySQL 至YashanDB 23.2 验证测试
这篇文章是作者尚雷关于使用崖山YMP迁移Oracle/MySQL至YashanDB 23.2的验证测试分享。介绍了YMP的产品信息,包括架构、版本支持等,还详细阐述了外置库部署、YMP部署、访问YMP、数据源管理、任务管理(创建任务、迁移配置、离线迁移、校验初始化、一致性校验)及MySQL迁移的全过程。
PHP与MySQL动态网站开发实战指南####
【10月更文挑战第21天】 本文将深入浅出地探讨如何使用PHP与MySQL构建一个动态网站,从环境搭建到项目部署,全程实战演示。无论你是编程新手还是希望巩固Web开发技能的老手,都能在这篇文章中找到实用的技巧和启发。我们将一起探索如何通过PHP处理用户请求,利用MySQL存储数据,并最终呈现动态内容给用户,打造属于自己的在线平台。 ####
190 0
如何排查和解决PHP连接数据库MYSQL失败写锁的问题
通过本文的介绍,您可以系统地了解如何排查和解决PHP连接MySQL数据库失败及写锁问题。通过检查配置、确保服务启动、调整防火墙设置和用户权限,以及识别和解决长时间运行的事务和死锁问题,可以有效地保障应用的稳定运行。
173 25
PHP与MySQL动态网站开发实战指南####
——深入探索LAMP栈下的高效数据交互与处理技巧 ####
PHP与MySQL动态网站开发:从基础到实践####
本文将深入探讨PHP与MySQL的结合使用,展示如何构建一个动态网站。通过一系列实例和代码片段,我们将逐步了解数据库连接、数据操作、用户输入处理及安全防护等关键技术点。无论您是初学者还是有经验的开发者,都能从中获益匪浅。 ####
PHP与MySQL动态网站开发实战指南####
深入探索PHP与MySQL的协同工作机制,本文旨在通过一系列实战案例,揭示构建高效、稳定且用户友好的动态网站的秘诀。从环境搭建到数据交互,再到最佳实践分享,本文为开发者提供了一条清晰的学习路径,助力其在LAMP(Linux, Apache, MySQL, PHP/Perl/Python)栈上实现技术飞跃。 ####
php实现一个简单的MySQL分页
通过本文的详细步骤和代码示例,我们实现了一个简单的PHP MySQL分页功能。主要步骤包括计算总记录数、设置分页参数、查询当前页的数据以及生成分页链接。这种分页方式适用于大多数Web应用,能够有效提升用户体验和页面响应速度。
123 4

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等