浏览 1783 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2009-08-10
最后修改:2009-08-13
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等守护进程的实现, 没必要为了实现一个小功能浪费那么多时间去学习了,我成不了专家,也没这打算。 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |