asp.net – 通过nginx和ServiceStack对fastcgi-mono-server进行小负载测试后出现
我试图在nginx和fastcgi-mono-server下运行ServiceStack的webservice API. 服务器启动正常,API已启动并正在运行.我可以通过ServiceStack分析器在浏览器中看到响应时间,它们的运行时间不超过10毫秒. 但是一旦我使用“siege”进行小负载测试(使用10个连接只有500个请求),我就开始获得502 Bad Gateway.要恢复,我必须重新启动fastcgi-mono-server. nginx服务器很好. fastcgi-mono-server是在这个小负载后停止响应的服务器. 我已经尝试使用tcp和unix套接字(我知道unix套接字的权限问题,但我已经修复了). 这是我的配置:
要启动fastcgi-mono-server:
编辑: 我还测试了Mono的所有可能的Web服务器配置:控制台应用程序,apache mod_mono,nginx fast_cgi和proxy_pass模块.在Mono 3.2.3 Mac OS X下的一些请求之后,所有这些都出现了同样的崩溃问题. 我能够在Linux机器上测试相同的配置,并且没有任何问题. 所以在Mac OS X上运行时似乎是一个Mono / ASP.NET问题. 最佳答案 编辑:我确实在原始问题中看到在Linux下运行没有问题,但是,在“高负载”情况下(即50个并发请求),我在Linux上也遇到了困难,所以这也可能适用于OS X. . 我深入研究了这个问题,我找到了一个解决方案 – 我在负载测试我的简单hello world应用程序时不再收到502 Bad Gateway错误.我在Ubuntu 13.10上测试了每一个,并在/ opt / mono中安装了Mono 3.2.3. 使用“/ verbose = True / printlog = True”启动mono-fastcgi-4服务器时,您会注意到以下输出:
重要的是“最大连接”和“最大请求”.这些基本上告诉了mono-fastcgi服务器能够处理多少活动TCP连接和请求 – 在本例中为1024. 我的NGINX配置如下:
所以我有4个工人,每个工人可以有1024个连接.因此,NGINX很乐意接受4096个并发连接,然后发送到mono-fastcgi(他们只希望处理1024个conns).因此,mono-fastcgi正在“保护自己”并停止提供请求.有两种解决方案: >降低NGINX可以接受的请求数量 通过将NGINX配置更改为以下内容,可以简单地解决1:
但是,这很可能意味着您无法最大限度地利用计算机上的资源. 2.解决方案有点棘手.首先,mono-fastcgi必须多次启动.为此,我创建了以下脚本(在应该启动的网站内):
这启动了4个mono-fastcgi工作者,每个工作者可以接受1024个连接.那么NGINX应该配置如下:
这将NGINX配置为一个4“上游工作者”池,它将在round-robin fashion中使用.现在,当我用Boom并发200分钟对我的服务器进行锤击1分钟时,这一切都很好(也就是说根本没有502). 我希望你能以某种方式将它应用到你的代码并使东西工作:) P.S: 您可以下载我用于测试here的Hello World ServiceStack代码. 你可以下载我的完整NGINX.config here. 虽然有一些路径需要调整,但它应该是一个很好的基础. (编辑:莱芜站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- ruby-on-rails – Capistrano NGINX Passenger Restart Rai
- node.js-同一VPS上的PHP网站和Nodejs应用
- Nginx配置未针对浏览器更新
- NGINX proxy_pass删除路径前缀并解析DNS
- 身份验证 – Jenkins/Nginx – Double提示基本身份验证,为什
- linux – 我可以在相同的服务器上运行Apache和Nginx,在同一
- Nginx http_status_module统计信息
- 如何在浏览器,nginx服务器中强制下载文件
- nginx – PHP FPM,位置嵌套与unnested以避免代码执行
- nginx – 服务器上的高内存使用量 – 无法确定进程