Class: DRMAA::Session
- Inherits:
-
Object
- Object
- DRMAA::Session
- Defined in:
- lib/ood_core/job/adapters/drmaa.rb
Overview
DRMAA Session
Direct Known Subclasses
Instance Attribute Summary collapse
-
#retry ⇒ Object
Returns the value of attribute retry.
Instance Method Summary collapse
-
#finalize(id) ⇒ Object
close DRMAA session.
-
#hold(job = ALL_JOBS) ⇒ Object
put specified job or all session jobs in hold state.
-
#initialize(contact = "") ⇒ Session
constructor
initialize DRMAA session.
-
#job_ps(job) ⇒ Object
get job state.
-
#release(job = ALL_JOBS) ⇒ Object
release hold state for specified job or all session jobs.
-
#resume(job = ALL_JOBS) ⇒ Object
resume specified job or all session jobs.
-
#retry_until ⇒ Object
non-zero retry interval causes DRMAA::DRMAATryLater be handled transparently.
-
#run(t) ⇒ Object
submits job described by JobTemplate ‘t’ and returns job id as string.
-
#run_bulk(t, first, last, incr = 1) ⇒ Object
submits bulk job described by JobTemplate ‘t’ and returns an array of job id strings.
-
#suspend(job = ALL_JOBS) ⇒ Object
suspend specified job or all session jobs.
-
#sync(jobs, timeout = -1)) ⇒ Object
synchronize with specified session jobs returns false in case of a timeout.
-
#sync!(jobs, timeout = -1)) ⇒ Object
synchronize with specified session jobs and dispose any job finish information returns false in case of a timeout.
-
#sync_all(timeout = -1,, dispose = false) ⇒ Object
synchronize with all session jobs returns false in case of a timeout.
-
#sync_all!(timeout = -1)) ⇒ Object
synchronize with all session jobs and dispose any job finish information returns false in case of a timeout.
-
#terminate(job = ALL_JOBS) ⇒ Object
terminate specified job or all session jobs.
-
#wait(job, timeout = -1)) ⇒ Object
wait for job and return JobInfo.
-
#wait_any(timeout = -1)) ⇒ Object
wait for any job of this session and return JobInfo.
-
#wait_each(timeout = -1)) ⇒ Object
run block with JobInfo to finish for each waited session job or return JobInfo array if no block was passed.
Constructor Details
Instance Attribute Details
#retry ⇒ Object
Returns the value of attribute retry.
718 719 720 |
# File 'lib/ood_core/job/adapters/drmaa.rb', line 718 def retry @retry end |
Instance Method Details
#finalize(id) ⇒ Object
close DRMAA session
728 729 730 731 |
# File 'lib/ood_core/job/adapters/drmaa.rb', line 728 def finalize(id) # STDERR.puts "... exiting DRMAA" DRMAA.exit end |
#hold(job = ALL_JOBS) ⇒ Object
put specified job or all session jobs in hold state
828 829 830 |
# File 'lib/ood_core/job/adapters/drmaa.rb', line 828 def hold(job = ALL_JOBS) DRMAA.control(job, DRMAA::ACTION_HOLD) end |
#job_ps(job) ⇒ Object
get job state
843 844 845 |
# File 'lib/ood_core/job/adapters/drmaa.rb', line 843 def job_ps(job) DRMAA.job_ps(job) end |
#release(job = ALL_JOBS) ⇒ Object
release hold state for specified job or all session jobs
833 834 835 |
# File 'lib/ood_core/job/adapters/drmaa.rb', line 833 def release(job = ALL_JOBS) DRMAA.control(job, DRMAA::ACTION_RELEASE) end |
#resume(job = ALL_JOBS) ⇒ Object
resume specified job or all session jobs
823 824 825 |
# File 'lib/ood_core/job/adapters/drmaa.rb', line 823 def resume(job = ALL_JOBS) DRMAA.control(job, DRMAA::ACTION_RESUME) end |
#retry_until ⇒ Object
non-zero retry interval causes DRMAA::DRMAATryLater be handled transparently
734 735 736 737 738 739 740 741 742 743 744 745 746 747 |
# File 'lib/ood_core/job/adapters/drmaa.rb', line 734 def retry_until if @retry == 0 job = yield else begin job = yield rescue DRMAA::DRMAATryLater STDERR.puts "... sleeping" sleep @retry retry end end return job end |
#run(t) ⇒ Object
submits job described by JobTemplate ‘t’ and returns job id as string
750 751 752 |
# File 'lib/ood_core/job/adapters/drmaa.rb', line 750 def run(t) retry_until { DRMAA.run_job(t.ptr) } end |
#run_bulk(t, first, last, incr = 1) ⇒ Object
submits bulk job described by JobTemplate ‘t’ and returns an array of job id strings
756 757 758 |
# File 'lib/ood_core/job/adapters/drmaa.rb', line 756 def run_bulk(t, first, last, incr = 1) retry_until { DRMAA.run_bulk_jobs(t.ptr, first, last, incr) } end |
#suspend(job = ALL_JOBS) ⇒ Object
suspend specified job or all session jobs
818 819 820 |
# File 'lib/ood_core/job/adapters/drmaa.rb', line 818 def suspend(job = ALL_JOBS) DRMAA.control(job, DRMAA::ACTION_SUSPEND) end |
#sync(jobs, timeout = -1)) ⇒ Object
synchronize with specified session jobs returns false in case of a timeout
813 814 815 |
# File 'lib/ood_core/job/adapters/drmaa.rb', line 813 def sync(jobs, timeout = -1) DRMAA.synchronize(jobs, timeout, false) end |
#sync!(jobs, timeout = -1)) ⇒ Object
synchronize with specified session jobs and dispose any job finish information returns false in case of a timeout
807 808 809 |
# File 'lib/ood_core/job/adapters/drmaa.rb', line 807 def sync!(jobs, timeout = -1) DRMAA.synchronize(jobs, timeout, true) end |
#sync_all(timeout = -1,, dispose = false) ⇒ Object
synchronize with all session jobs returns false in case of a timeout
801 802 803 |
# File 'lib/ood_core/job/adapters/drmaa.rb', line 801 def sync_all(timeout = -1, dispose = false) DRMAA.synchronize([ ALL_JOBS ], timeout, dispose) end |
#sync_all!(timeout = -1)) ⇒ Object
synchronize with all session jobs and dispose any job finish information returns false in case of a timeout
795 796 797 |
# File 'lib/ood_core/job/adapters/drmaa.rb', line 795 def sync_all!(timeout = -1) DRMAA.synchronize([ ALL_JOBS ], timeout, true) end |
#terminate(job = ALL_JOBS) ⇒ Object
terminate specified job or all session jobs
838 839 840 |
# File 'lib/ood_core/job/adapters/drmaa.rb', line 838 def terminate(job = ALL_JOBS) DRMAA.control(job, DRMAA::ACTION_TERMINATE) end |
#wait(job, timeout = -1)) ⇒ Object
wait for job and return JobInfo
766 767 768 |
# File 'lib/ood_core/job/adapters/drmaa.rb', line 766 def wait(job, timeout = -1) DRMAA.wait(job, timeout) end |
#wait_any(timeout = -1)) ⇒ Object
wait for any job of this session and return JobInfo
761 762 763 |
# File 'lib/ood_core/job/adapters/drmaa.rb', line 761 def wait_any(timeout = -1) DRMAA.wait(ANY_JOB, timeout) end |
#wait_each(timeout = -1)) ⇒ Object
run block with JobInfo to finish for each waited session job or return JobInfo array if no block was passed
772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 |
# File 'lib/ood_core/job/adapters/drmaa.rb', line 772 def wait_each(timeout = -1) if ! block_given? ary = Array.new end while true begin info = DRMAA.wait(ANY_JOB, timeout) rescue DRMAAInvalidJobError break end if block_given? yield info else ary << info end end if ! block_given? return ary end end |