Ruby prog не запускается как LaunchDaemon - PullRequest
0 голосов
/ 07 декабря 2010

У меня есть программа ruby, довольно простая, просто выполняет поиск DNS на нескольких хостах.Программа отлично работает с терминала (Mac OS X 10.6.5), Ruby 1.9.2 с использованием RVM.

Я хотел бы запустить это по расписанию и хотел бы загрузить LaunchDaemon для этого.Программа не запускается как LauanchDaemon, и выходные файлы создаются, но пустые, поэтому я не вижу ошибок.Я подозреваю, что это как-то связано с includeами.

Вот plist (он загружается нормально и пытается запустить, что подтверждается созданием обоих выходных файлов):

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
  <dict>
    <key>Label</key>
    <string>com.jsw.ping</string>
    <key>RunAtLoad</key>
    <true/>
    <key>Debug</key>
    <true/>
    <key>StandardOutPath</key>
    <string>/var/jsw/logs/ping.txt</string>
    <key>EnvironmentVariables</key>
        <dict>
            <key>PATH</key>
                <string>/Users/scott/.rvm/gems/ruby-1.9.2-p0/bin:/Users/scott/.rvm/gems/ruby-1.9.2-p0@global/bin:/Users/scott/.rvm/rubies/ruby-1.9.2-p0/bin:/Users/scott/.rvm/gems/ruby-1.9.2-p0@rails3/bin:/Users/scott/.rvm/gems/ruby-1.9.2-p0@global/bin:/Users/scott/.rvm/rubies/ruby-1.9.2-p0/bin:/Users/scott/.rvm/bin:/usr/local/maven/bin:/usr/local/bin:/usr/local/sbin:/usr/local/mysql/bin:/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin:/usr/local/git/bin:/usr/X11/bin</string>
        </dict>
    <key>StandardErrorPath</key>
    <string>/var/jsw/logs/ping.err.txt</string>
    <key>ProgramArguments</key>
    <array>
        <string>ping.rb</string>
    </array>
    <key>StartInterval</key>
      <integer>1800</integer>
    <key>WorkingDirectory</key>
        <string>/Library/WebServer/vHosts/scripts/ping/</string>
   <key>UserName</key>
       <string>scott</string>
  </dict>
</plist>

Программа на Ruby:

#!/Users/scott/.rvm/rubies/ruby-1.9.2-p0/bin/ruby
require 'rubygems'  
require 'active_record'
require 'yaml'  
require 'dnsruby'
include Dnsruby


dbconfig = YAML::load(File.open('database.yml'))
ActiveRecord::Base.establish_connection(dbconfig)

# flush cache
rslt = `dscacheutil -flushcache`

Dnsruby::DNS.open 
rslvr = Dnsruby::DNS.new

now = DateTime.now.to_s
mysqlDT = now.gsub("T", " ")
puts mysqlDT


class Host < ActiveRecord::Base  
end  
class Ip < ActiveRecord::Base  
end  

Host.find_each do |svr|
  ip = rslvr.getaddress(svr.host).to_s
  svr.lastIP = ip
  svr.save
  Ip.create(:ip => ip, :host => svr.host, :DT => mysqlDT, :hostID => svr.id)
end

1 Ответ

0 голосов
/ 08 декабря 2010

Основная проблема заключалась в том, что задание LaunchDaemon запускалось из оболочки, которая не настроила RVM должным образом, и, следовательно, не удалось найти включенные классы. Поскольку в моей системе нет устаревших программ Ruby, я удалил RVM и установил Ruby 1.9.2 в / usr / local / bin в моей системе, а затем переустановил гемы.

Вторая проблема (без регистрации) была связана с ошибкой прав доступа.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...