我在 centos 6.2 上运行的 nginx 1.0.15 网络服务器设置了 mono 2.11。我从源代码构建它,xps2、xps4 和 fastcgi-mono-server2 按预期工作。问题是当我尝试运行 fastcgi-mono-server4 时。当我跑步时:
fastcgi-mono-server4 /applications=site:/:/srv/www/html/ /socket=tcp:127.0.0.1:9000 /loglevels=Debug /printlog=true
这是我从 fastcgi-mono-server2 得到的:
[2012-06-06 23:51:07Z] Debug Record received. (Type: BeginRequest, ID: 1, Length: 8)
[2012-06-06 23:51:07Z] Debug Record received. (Type: Params, ID: 1, Length: 801)
[2012-06-06 23:51:07Z] Debug Record received. (Type: Params, ID: 1, Length: 0)
[2012-06-06 23:51:07Z] Debug Read parameter. (QUERY_STRING = )
[2012-06-06 23:51:07Z] Debug Read parameter. (REQUEST_METHOD = GET)
[2012-06-06 23:51:07Z] Debug Read parameter. (CONTENT_TYPE = )
[2012-06-06 23:51:07Z] Debug Read parameter. (CONTENT_LENGTH = )
[2012-06-06 23:51:07Z] Debug Read parameter. (SCRIPT_NAME = /)
[2012-06-06 23:51:07Z] Debug Read parameter. (REQUEST_URI = /)
[2012-06-06 23:51:07Z] Debug Read parameter. (DOCUMENT_URI = /)
[2012-06-06 23:51:07Z] Debug Read parameter. (DOCUMENT_ROOT = /srv/www/html)
[2012-06-06 23:51:07Z] Debug Read parameter. (SERVER_PROTOCOL = HTTP/1.1)
[2012-06-06 23:51:07Z] Debug Read parameter. (GATEWAY_INTERFACE = CGI/1.1)
[2012-06-06 23:51:07Z] Debug Read parameter. (SERVER_SOFTWARE = nginx/1.0.15)
[2012-06-06 23:51:07Z] Debug Read parameter. (REMOTE_ADDR = 192.168.128.121)
[2012-06-06 23:51:07Z] Debug Read parameter. (REMOTE_PORT = 62326)
[2012-06-06 23:51:07Z] Debug Read parameter. (SERVER_ADDR = 192.168.128.125)
[2012-06-06 23:51:07Z] Debug Read parameter. (SERVER_PORT = 80)
[2012-06-06 23:51:07Z] Debug Read parameter. (SERVER_NAME = site)
[2012-06-06 23:51:07Z] Debug Read parameter. (REDIRECT_STATUS = 200)
[2012-06-06 23:51:07Z] Debug Read parameter. (PATH_INFO = )
[2012-06-06 23:51:07Z] Debug Read parameter. (SCRIPT_FILENAME = /srv/www/html/)
[2012-06-06 23:51:07Z] Debug Read parameter. (HTTP_HOST = site)
[2012-06-06 23:51:07Z] Debug Read parameter. (HTTP_USER_AGENT = Mozilla/5.0 (Windows NT 6.1; WOW64; rv:13.0) Gecko/20100101 Firefox/13.0)
[2012-06-06 23:51:07Z] Debug Read parameter. (HTTP_ACCEPT = text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8)
[2012-06-06 23:51:07Z] Debug Read parameter. (HTTP_ACCEPT_LANGUAGE = en-us,en;q=0.5)
[2012-06-06 23:51:07Z] Debug Read parameter. (HTTP_ACCEPT_ENCODING = gzip, deflate)
[2012-06-06 23:51:07Z] Debug Read parameter. (HTTP_CONNECTION = keep-alive)
[2012-06-06 23:51:07Z] Debug Read parameter. (HTTP_COOKIE = ASP.NET_SessionId=0176BE8FC161E702439D3C91)
[2012-06-06 23:51:07Z] Debug Record received. (Type: StandardInput, ID: 1, Length: 0)
[2012-06-06 23:51:08Z] Debug Record sent. (Type: StandardOutput, ID: 1, Length: 196)
[2012-06-06 23:51:08Z] Debug Record sent. (Type: StandardOutput, ID: 1, Length: 128)
[2012-06-06 23:51:08Z] Debug Record sent. (Type: StandardOutput, ID: 1, Length: 0)
[2012-06-06 23:51:08Z] Debug Record sent. (Type: EndRequest, ID: 1, Length: 8)
这就是我从 fastcgi-mono-server4 得到的:
[2012-06-06 23:50:52Z] Debug Record received. (Type: BeginRequest, ID: 1, Length: 8)
[2012-06-06 23:50:52Z] Debug Record received. (Type: Params, ID: 1, Length: 801)
[2012-06-06 23:50:52Z] Debug Record received. (Type: Params, ID: 1, Length: 0)
[2012-06-06 23:50:52Z] Debug Read parameter. (QUERY_STRING = )
[2012-06-06 23:50:52Z] Debug Read parameter. (REQUEST_METHOD = GET)
[2012-06-06 23:50:52Z] Debug Read parameter. (CONTENT_TYPE = )
[2012-06-06 23:50:52Z] Debug Read parameter. (CONTENT_LENGTH = )
[2012-06-06 23:50:52Z] Debug Read parameter. (SCRIPT_NAME = /)
[2012-06-06 23:50:52Z] Debug Read parameter. (REQUEST_URI = /)
[2012-06-06 23:50:52Z] Debug Read parameter. (DOCUMENT_URI = /)
[2012-06-06 23:50:52Z] Debug Read parameter. (DOCUMENT_ROOT = /srv/www/html)
[2012-06-06 23:50:52Z] Debug Read parameter. (SERVER_PROTOCOL = HTTP/1.1)
[2012-06-06 23:50:52Z] Debug Read parameter. (GATEWAY_INTERFACE = CGI/1.1)
[2012-06-06 23:50:52Z] Debug Read parameter. (SERVER_SOFTWARE = nginx/1.0.15)
[2012-06-06 23:50:52Z] Debug Read parameter. (REMOTE_ADDR = 192.168.128.121)
[2012-06-06 23:50:52Z] Debug Read parameter. (REMOTE_PORT = 62326)
[2012-06-06 23:50:52Z] Debug Read parameter. (SERVER_ADDR = 192.168.128.125)
[2012-06-06 23:50:52Z] Debug Read parameter. (SERVER_PORT = 80)
[2012-06-06 23:50:52Z] Debug Read parameter. (SERVER_NAME = site)
[2012-06-06 23:50:52Z] Debug Read parameter. (REDIRECT_STATUS = 200)
[2012-06-06 23:50:52Z] Debug Read parameter. (PATH_INFO = )
[2012-06-06 23:50:52Z] Debug Read parameter. (SCRIPT_FILENAME = /srv/www/html/)
[2012-06-06 23:50:52Z] Debug Read parameter. (HTTP_HOST = site)
[2012-06-06 23:50:52Z] Debug Read parameter. (HTTP_USER_AGENT = Mozilla/5.0 (Windows NT 6.1; WOW64; rv:13.0) Gecko/20100101 Firefox/13.0)
[2012-06-06 23:50:52Z] Debug Read parameter. (HTTP_ACCEPT = text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8)
[2012-06-06 23:50:52Z] Debug Read parameter. (HTTP_ACCEPT_LANGUAGE = en-us,en;q=0.5)
[2012-06-06 23:50:52Z] Debug Read parameter. (HTTP_ACCEPT_ENCODING = gzip, deflate)
[2012-06-06 23:50:52Z] Debug Read parameter. (HTTP_CONNECTION = keep-alive)
[2012-06-06 23:50:52Z] Debug Read parameter. (HTTP_COOKIE = ASP.NET_SessionId=0176BE8FC161E702439D3C91)
[2012-06-06 23:50:53Z] Debug Record received. (Type: StandardInput, ID: 1, Length: 0)
[2012-06-06 23:50:53Z] Debug Record sent. (Type: EndRequest, ID: 1, Length: 8)
我看不出我做错了什么。任何帮助都会很棒。
编辑:返工,现在我收到错误网关的 502 错误。日志看起来仍然一样。
查看我的 Nginx 错误日志,发现许多这样的条目:
2012/06/18 13:56:01 [error] 3108#0: *4 connect() failed (111: Connection refused) while connecting to upstream, client: 192.168.128.121, server: site, request: "GET / HTTP/1.1", upstream: "fastcgi://127.0.0.1:9000", host: "site"
无论 fastcgi-mono-server4 是否打开,我都会得到相同的响应。它现在总是显示 502 错误。
我的示例 MVC3 应用程序在来自 badgerports.org 的 Mono 2.10.8.1 上运行良好(我使用 ubuntu)。
从源代码安装 Mono 2.11.2 后,同一个应用程序将始终返回 502 Bad Gateway,就像您的情况一样。
我的 nginx 日志如下所示:
在将 printlog 选项设置为 true 的情况下调用 fastcgi-mono-server4 之后
它会在访问 localhost:8000/ 后生成此堆栈跟踪
这是我的一些配置:
-
-
我在这里找到了解决我的问题的方法:bugzilla.xamarin.com/show_bug.cgi?id=2876(让我感到困扰的是它应该在 2012 年 2 月得到修复 - 我编译的单声道是在 6 月 afaik 发布的,但它没有开箱即用)
我根据那里找到的修复单声道安装的建议制作了一个脚本,只需将 PREFIX 变量指向您的单声道目录并运行它:
在此之后,应用程序“工作”了,但还没有完成。它不再是 502,我得到了一个很好的堆栈跟踪...
所以我自己还有一些事情要弄清楚,但我希望这对你有所帮助。