An extension to the OMF RC, which provides support for the Structure Health Monitoring (SHM) project.
Install it as:
$ gem install omf_rc_shm --no-ri --no-rdoc
(if the above command returns that it cannot download data from https://rubygems.org, then try again with the additional option --source http://rubygems.org
and discard any subsequent SSL warning)
Setup startup script
$ install_omf_rc -c -i
This installs a generic OMF RC configuration file in /etc/omf_rc/config.yml
, you should modify it following the SHM-specific configuration example:
---
:uri: local://local
:environment: production
:debug: false
:resources:
- :type: shm_node
:uid: <%= ip = `ifconfig br0`.match(/inet addr:(\d*\.\d*\.\d*\.\d*)/)[1].split('.') ; 'node' + (ip[2].to_i*256+ip[3].to_i).to_s.rjust(4,'0') %>
:app_definition_file: /etc/omf_rc/scheduled_app.rb
:ruby_path: /usr/local/bin/ruby
:watchdog_timer: 15
:add_default_factories: false
:factories:
- :require: omf_rc_shm
Where
:uri:
is the URI for the communication scheme to use, e.g.local://local
(= no communication) orxmpp://user:password@some.xmpp.server
(= use XMPP server at some.xmpp.server):uid:
is the ID given to this resource (e.g. the above example constructs an ID similar to 'node1234' based on the IP address of the 'br0' interface):app_definition_file:
is the path to the file with the default application schedule:ruby_path:
where to find the ruby binary:watchdog_timer:
number of second between each watchdog timer top-up (comment that parameter to disable the watchdog timer)
The default schedule for the applications to run is in a file located at the path assigned to the above :app_definition_file:
parameter. You should create such a file following the default application schedule example:
Example:
defApplication("my_app_name") do |a|
a.binary_path = "/usr/bin/my_app"
a.schedule = "*/5 * * * *"
a.timeout = 20
a.parameters = {
udp_target_host: { cmd: "--udp-target", value: "0.0.0.0", mandatory: true },
udp_target_port: { cmd: "--udp-port", value: 5000, mandatory: true }
}
a.use_oml = true
a.oml = {
experiment: "my_experiment_#{Time.now.to_i}",
id: "some_ID",
collection: [
{
url: "tcp:0.0.0.0:3003",
streams: [
{ mp: "udp_in", samples: 1 },
{ mp: "udp_out", samples: 1 }
]
}
]
}
end
Where
binary_path
is local path to the application's binaryschedule
is the definition of the schedule to run the application on. It can be either the string 'in X' which means that the application will be started X minutes after its definition has been processed; or a cron-type formatted schedule (see crontab manual)timeout
the time in second after which the application should be stopped, set to 0 to let the application stop by itselfparameters
the list of command line parameters that this application accepts, see the OMF Documentation for more detailuse_oml
enable OML instrumentationoml
OML instrumentation parameters, see the OML Config Documentation for more detail. NOTE: if the sub-parameterid:
is missing, the:uid:
for this resource will be used by default, as requested by the SHM team.
Additional definition for application to be schedule may be added following the above definition in the same file.
The RC with SHM extension should start up automatically during boot.
However, if you need to start it manually you may use the command omf_rc -c <path_to_config_file>
- Fork it
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create new Pull Request