windows 下 php+nginx 并发上不去,求解决办法

MMDD0827 2012-04-05 09:39:31
RT
目前 ,当并发达到20 之后, 打开php 页面将会变得很慢,再多了 ,就彻底 报 500 了。这个时候,系统的cpu 跟 内存 并且都不高
下面是nginx 的配置文件:


worker_processes 1;

error_log logs/error.log crit;

pid ../data/nginx.pid;

events {
worker_connections 1024;
}


http {
include mime.types;
default_type application/octet-stream;

access_log off;
# log_format processtime '"$request" $status $request_time ';
# access_log logs/access.log processtime;

sendfile on;
#tcp_nopush on;

#keepalive_timeout 0;
keepalive_timeout 120;

#gzip on;

server {
include port.conf;
client_max_body_size 20m;

rewrite ^/netcenter/(.+)$ /$1;
rewrite ^/(.+)\.(asmx|aspx)$ /$1.php;

location / {
include root.conf;
}

location = / {
include root.conf;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME index.php;
include fastcgi_params;
}

location ~* \.(php|asmx|aspx)$ {
include root.conf;
fastcgi_pass 127.0.0.1:9000;
fastcgi_param SCRIPT_FILENAME $fastcgi_script_name;
include fastcgi_params;
}
}
}



哦 ,补充一下 ,希望达到的并发 至少 应该在200以上的 ~ 这个要求应该不高啊
...全文
511 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
cckoldy 2014-05-16
  • 打赏
  • 举报
回复
真的没人能解决吗?要老夫出马了!windowsg下nginx+php(fashcgi方式)默认是单进程单线程的,所有的并发请求要排队处理,如果有一个页面处理需要很长时间,其他的请求就要排队等候,导致了访问速度奇慢
MMDD0827 2012-04-10
  • 打赏
  • 举报
回复
没有人嘛?
MMDD0827 2012-04-06
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 的回复:]

我用nginx的时候总是不稳定,搞了很久没弄好,后来用apache做服务器,nginx做的反向代理。
[/Quote]
回复3楼:
那你用nginx 的时候 ,出去 不稳定的因素, 他的并发 你怎么解决的呀 ?
MMDD0827 2012-04-05
  • 打赏
  • 举报
回复
2L 你看清问题撒~
我的是并发上不去 而不是要限制啊……
钛元素 2012-04-05
  • 打赏
  • 举报
回复
如何Nginx限制同一个ip的连接数,限制并发数目

1.添加limit_zone
这个变量只能在http使用
vi /usr/local/nginx/conf/nginx.conf
limit_zone ctohome_zone $remote_addr 10m;

2.添加limit_conn
这个变量可以在http, server, location使用
我只限制一个站点,所以添加到server里面
vi /usr/local/nginx/conf/host/www.ctohome.com.conf
limit_conn ctohome_zone 2;

3.重启nginx
killall -HUP nginx

Nginx限制流量/限制带宽?

关于limit_zone:http://wiki.nginx.org/NginxHttpLimitZoneModule
关于limit_rate和limit_conn:http://wiki.nginx.org/NginxHttpCoreModule
nginx可以通过HTTPLimitZoneModule和HTTPCoreModule两个组件来对目录进行限速。

http {
limit_zone one $binary_remote_addr 10m;
server {
location /download/ {
limit_conn ctohome_zone 2;

limit_rate 300k;
}
}
}

limit_zone,是针对每个IP定义一个存储session状态的容器。这个示例中定义了一个10m的容器,按照32bytes/session,可以处理320000个session。

limit_conn ctohome_zone 2;
限制每个IP只能发起2个并发连接。

limit_rate 300k;
对每个连接限速300k. 注意,这里是对连接限速,而不是对IP限速。如果一个IP允许两个并发连接,那么这个IP就是限速limit_rate×2。
ngx_http_limit_zone_module
ivan_070 2012-04-05
  • 打赏
  • 举报
回复
我用nginx的时候总是不稳定,搞了很久没弄好,后来用apache做服务器,nginx做的反向代理。

5,655

社区成员

发帖
与我相关
我的任务
社区描述
Web开发应用服务器相关讨论专区
社区管理员
  • 应用服务器社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧