jack 发表于 2013-2-5 01:29:27

Win32 service

Mongrel在windows 2003 服务器上以 service的方式运行时,经常会出现Errno::EINVAL (Invalid argument)类错误,一般在post数据的时候特别容易出现. 解决办法有以下几种.


1. 有个比较简单的解决办法,就是把start_form_tag改成form.这样的确很难再出现这个问题.
2. mongrel以console的方式来运行.
3. 重新定向stderr和stdout到某个指定的文件.


下面来说下,为什么会出现这个错误.仔细观察下这些错误发生时的提示,比如有一个函数在里面 puts函数.
错误发生的更本原因也是这个函数.

   这个函数在调用的时候,要拥到stderr,和stdout,但是这两个对象是pipe. 如果是控制台模式下,stderr,和stdout管道是一定存在,并且可以访问到的. 但是win32 services下面,是没有stderr和stdout的.所以调用puts函数必然出错.
   
   各位可以试下,随便写个页面,里面放上puts函数,放到 win32,mongrel service模式下面去运行,就会出现Errno::EINVAL (Invalid argument)错误.

   如果要根本上解决这个问题,最好的办法还是重定向 stderr,stdout. 可以在environment.rb中加入
STDOUT.reopen("c:\log\stdout.log") 日志路径随你们工程环境来修改. stderr的重定向代码也一样.就不多写了.
页: [1]
查看完整版本: Win32 service