chmod +x之后直接运行脚本报错:
: bad interpreter: No such file or directory
这是由于该文件是以DOS格式编辑的,Unix不认识,我们需要转换一下。
用Vi打开,
:set ff?查看一下是不是Dos的,
set ff=unix转换成Unix,
然后再运行下试试。
Sinatra没找到如何以后台模式启动,可能这不在它要考虑的范围内吧。
把下面这段Webrick的守护进程代码加进去,
最后再加上一句:
Daemon.start就OK了。
ps -ajx看一下:
PPID PID PGID SID TTY TPGID STAT UID TIME COMMAND
1 15755 15754 15754 ? -1 S 0 0:00 /usr/local/bin/ruby ./server.rb
典型的守护进程:)
class Daemon def Daemon.start exit!(0) if fork Process::setsid exit!(0) if fork Dir::chdir("/") File::umask(0) STDIN.reopen("/dev/null") STDOUT.reopen("/dev/null", "w") STDERR.reopen("/dev/null", "w") yield if block_given? end end
用的时候抄一下就行,哈哈哈哈。
不过要理解守护进程的实现原理,请只会傻写Java代码的同学们看《UNIX环境编程》 :)
================整理下之后==============
#!/usr/local/bin/ruby require 'rubygems' require 'sinatra/base' require 'rack' require 'open3' $build_sh = File.join("/home/admin/taiji/src/taiji/src/task","build.rb") class TaijiBuilderServer < Sinatra::Base get '/taiji' do "{stat:'Running'}" end get '/taiji/build' do if (params[:project_name] && params[:svn] && params[:project_id]) != nil then #另起一个进程处理更新SVN和编译以及部署、启动等操作,不能在Sinatra同进程中进行! Open3.popen3 %Q{ruby #{$build_sh} #{params[:project_name]} #{params[:svn]} #{params[:project_id]}} "{stat:'OK',params:'#{Rack::Request.new(env).params.inspect}',ts:'#{Time.now().to_s}',cmd:'ruby #{$build_sh} #{params[:project_name]} #{params[:svn]} #{params[:project_id]}'}" else "{stat:'Params Error'}" end end end class Daemon def Daemon.start exit!(0) if fork Process::setsid exit!(0) if fork Dir::chdir("/") File::umask(0) STDIN.reopen("/dev/null") #以下两个日志需要以a(追加)的方式打开日志文件,w将清空原有内容 #输出Sinatra默认输出 STDOUT.reopen("/home/admin/taiji/logs/build_stdout.log", "a+") #输出Error日志 STDERR.reopen("/home/admin/taiji/logs/build_stdout.log", "a+") yield if block_given? end end #启动精灵进程的同时启动Sinatra应用 Daemon.start{TaijiBuilderServer.run! :host => '10.2.226.20', :port => 9090}
翻了下以前的代码,发现Sinatra也可以这样使用:
Rack::Handler::Mongrel.run builder, :Port => 9292
这样的话估计会有原生的Mongrel或者Thin等守护进程的实现,
没必要为了实现一个小功能浪费那么多时间去学习了,我成不了专家,也没这打算。