diff options
author | Alejandro Pulver <alepulver@FreeBSD.org> | 2006-10-06 02:32:32 +0000 |
---|---|---|
committer | Alejandro Pulver <alepulver@FreeBSD.org> | 2006-10-06 02:32:32 +0000 |
commit | 60356915691d093c5aefefe3db3b9fd4b7628856 (patch) | |
tree | b0c050f44c52296bfdb8ad3732cabea1c9c0d563 /sysutils/torque | |
parent | 7996676565c41226325902093f636c66da667f49 (diff) |
TORQUE is an open source resource manager providing control over
batch jobs and distributed compute nodes. It is a community effort
based on the original *PBS project and, with more than 1,200 patches,
has incorporated significant advances in the areas of scalability,
fault tolerance, and feature extensions contributed by NCSA, OSC,
USC , the U.S. Dept of Energy, Sandia, PNNL, U of Buffalo, TeraGrid,
and many other leading edge HPC organizations.
WWW: http://www.clusterresources.com/pages/products/torque-resource-manager.php
PR: ports/103296
Submitted by: trasz
Notes
Notes:
svn path=/head/; revision=174608
Diffstat (limited to 'sysutils/torque')
-rw-r--r-- | sysutils/torque/Makefile | 66 | ||||
-rw-r--r-- | sysutils/torque/distinfo | 3 | ||||
-rw-r--r-- | sysutils/torque/files/patch-fifo-Makefile.in | 11 | ||||
-rw-r--r-- | sysutils/torque/files/patch-mom_mach.c | 361 | ||||
-rw-r--r-- | sysutils/torque/files/patch-pbs_mkdirs.in | 19 | ||||
-rw-r--r-- | sysutils/torque/files/pbs_mom.sh.in | 27 | ||||
-rw-r--r-- | sysutils/torque/files/pbs_sched.sh.in | 27 | ||||
-rw-r--r-- | sysutils/torque/files/pbs_server.sh.in | 27 | ||||
-rw-r--r-- | sysutils/torque/files/pkg-message.in | 40 | ||||
-rw-r--r-- | sysutils/torque/pkg-descr | 9 | ||||
-rw-r--r-- | sysutils/torque/pkg-plist | 73 |
11 files changed, 663 insertions, 0 deletions
diff --git a/sysutils/torque/Makefile b/sysutils/torque/Makefile new file mode 100644 index 000000000000..e3b50afac9f7 --- /dev/null +++ b/sysutils/torque/Makefile @@ -0,0 +1,66 @@ +# New ports collection makefile for: torque +# Date created: 20 Jul 2006 +# Whom: trasz +# +# $FreeBSD$ +# + +PORTNAME= torque +PORTVERSION= 2.1.2 +CATEGORIES= sysutils parallel +MASTER_SITES= http://www.clusterresources.com/downloads/torque/ + +MAINTAINER= trasz@pin.if.uz.zgora.pl +COMMENT= Open source resource manager + +RESTRICTED= Redistribution is only permitted for non-commercial, non-profit purposes +GNU_CONFIGURE= yes +CONFIGURE_ARGS= --with-rcp=scp +USE_GMAKE= yes +USE_RC_SUBR= pbs_server.sh pbs_sched.sh pbs_mom.sh +SUB_FILES= pkg-message +USE_LDCONFIG= yes + +MAN1= qalter.1 qdel.1 qhold.1 qmove.1 qmsg.1 qorder.1 qrerun.1 \ + qrls.1 qselect.1 qsig.1 qstat.1 qsub.1 pbs.1 pbsdsh.1 \ + nqs2pbs.1 basl2c.1 xpbs.1 xpbsmon.1 qmgr.1 + +MAN3= rpp.3 tm.3 pbs_alterjob.3 pbs_connect.3 pbs_default.3 \ + pbs_deljob.3 pbs_disconnect.3 pbs_geterrmsg.3 pbs_holdjob.3 \ + pbs_locate.3 pbs_manager.3 pbs_movejob.3 pbs_msgjob.3 \ + pbs_orderjob.3 pbs_rerunjob.3 pbs_rescquery.3 \ + pbs_rescreserve.3 pbs_rlsjob.3 pbs_runjob.3 pbs_selectjob.3 \ + pbs_selstat.3 pbs_sigjob.3 pbs_stagein.3 pbs_statjob.3 \ + pbs_statnode.3 pbs_statque.3 pbs_statserver.3 pbs_submit.3 \ + pbs_terminate.3 + +MAN7= pbs_job_attributes.7 pbs_queue_attributes.7 \ + pbs_server_attributes.7 pbs_resources_aix4.7 \ + pbs_resources_digitalunix.7 pbs_resources_aix5.7 \ + pbs_resources_darwin.7 pbs_resources_freebsd.7 \ + pbs_resources_fujitsu.7 pbs_resources_hpux10.7 \ + pbs_resources_hpux11.7 pbs_resources_irix5.7 \ + pbs_resources_irix6.7 pbs_resources_irix6array.7 \ + pbs_resources_linux.7 pbs_resources_netbsd.7 \ + pbs_resources_solaris5.7 pbs_resources_solaris7.7 \ + pbs_resources_sp2.7 pbs_resources_sunos4.7 \ + pbs_resources_unicos8.7 pbs_resources_unicosmk2.7 + +MAN8= pbs_mom.8 pbsnodes.8 pbs_sched_basl.8 pbs_sched_cc.8 \ + pbs_sched_tcl.8 pbs_server.8 qdisable.8 qenable.8 \ + qrun.8 qstart.8 qstop.8 qterm.8 + +MLINKS= pbs_sched_cc.8 pbs_sched.8 \ + pbs_resources_freebsd.7 pbs_resources.7 + +.include <bsd.port.pre.mk> + +.if ${OSVERSION} < 500000 +BROKEN= Doesn't build on 4.x +.endif + +post-install: + ${INSTALL_SCRIPT} ${WRKSRC}/torque.setup ${EXAMPLESDIR} + @${CAT} ${PKGMESSAGE} + +.include <bsd.port.post.mk> diff --git a/sysutils/torque/distinfo b/sysutils/torque/distinfo new file mode 100644 index 000000000000..fc5de70bb324 --- /dev/null +++ b/sysutils/torque/distinfo @@ -0,0 +1,3 @@ +MD5 (torque-2.1.2.tar.gz) = f1b37efb5d4770a0105c66294a05d140 +SHA256 (torque-2.1.2.tar.gz) = c7bade897fc12f27f128e4081c8ed1f3137bf42684ca239c48b18eb01314710a +SIZE (torque-2.1.2.tar.gz) = 2686724 diff --git a/sysutils/torque/files/patch-fifo-Makefile.in b/sysutils/torque/files/patch-fifo-Makefile.in new file mode 100644 index 000000000000..3a196cb805f9 --- /dev/null +++ b/sysutils/torque/files/patch-fifo-Makefile.in @@ -0,0 +1,11 @@ +--- src.orig/scheduler.cc/samples/fifo/Makefile.in Wed Jul 19 22:47:42 2006 ++++ src/scheduler.cc/samples/fifo/Makefile.in Wed Jul 19 22:59:44 2006 +@@ -132,7 +132,7 @@ + XPBSMON_DIR = $(libdir)/xpbsmon + + # Support files used by the scheduler +-schedprivdir = $(PBS_SERVER_HOME)/sched_priv ++schedprivdir = ${prefix}/share/examples/torque/var/spool/torque/sched_priv + schedpriv_DATA = sched_config resource_group holidays dedicated_time + + EXTRA_DIST = $(schedpriv_DATA) diff --git a/sysutils/torque/files/patch-mom_mach.c b/sysutils/torque/files/patch-mom_mach.c new file mode 100644 index 000000000000..ff94b2bdb9c3 --- /dev/null +++ b/sysutils/torque/files/patch-mom_mach.c @@ -0,0 +1,361 @@ +--- src/resmom/freebsd/mom_mach.c.orig Tue Jun 20 02:23:04 2006 ++++ src/resmom/freebsd/mom_mach.c Thu Sep 14 19:09:58 2006 +@@ -370,40 +370,10 @@ + continue; + + nps++; +- cputime += tvk(pp->kp_proc.p_rtime); + +- if (pp->kp_proc.p_ru == NULL) { +- struct pstats ps; +- +- DBPRT(("%s: p_stats 0x%lx\n", id, +- (u_long)pp->kp_proc.p_stats)) +- if (pp->kp_proc.p_stats == NULL) +- continue; +- +- if (kvm_read(kd, (u_long)pp->kp_proc.p_stats, &ps, +- sizeof(ps)) != sizeof(ps)) { +- log_err(errno, id, "kvm_read(pstats)"); +- continue; +- } +- cputime += tv(ps.p_ru.ru_utime) + +- tv(ps.p_ru.ru_stime) + +- tv(ps.p_cru.ru_utime) + +- tv(ps.p_cru.ru_stime); +- } +- else { +- struct rusage ru; +- +- DBPRT(("%s: p_ru 0x%lx\n", id, +- (u_long)pp->kp_proc.p_ru)) +- if (kvm_read(kd, (u_long)pp->kp_proc.p_ru, &ru, +- sizeof(ru)) != sizeof(ru)) { +- log_err(errno, id, "kvm_read(session)"); +- continue; +- } +- cputime += tv(ru.ru_utime) + tv(ru.ru_stime); +- } ++ cputime += pp->ki_runtime / 1000000; + DBPRT(("%s: ses %d pid %d cputime %d\n", id, +- sess_tbl[i], pp->kp_proc.p_pid, cputime)) ++ sess_tbl[i], pp->ki_pid, pp->ki_runtime / 1000000)) + } + + if (nps == 0) +@@ -434,11 +404,9 @@ + if (!injob(pjob, sess_tbl[i])) + continue; + +- memsize += ctob(pp->kp_eproc.e_vm.vm_tsize + +- pp->kp_eproc.e_vm.vm_dsize + +- pp->kp_eproc.e_vm.vm_ssize); ++ memsize += pp->ki_size; + DBPRT(("%s: ses %d pid=%d totmem=%lu\n", id, +- sess_tbl[i], pp->kp_proc.p_pid, memsize)) ++ sess_tbl[i], pp->ki_pid, pp->ki_size)) + } + + return (memsize); +@@ -461,10 +429,10 @@ + if (!injob(pjob, sess_tbl[i])) + continue; + +- memsize += ctob(pp->kp_eproc.e_vm.vm_rssize); ++ memsize += pp->ki_rssize * PAGE_SIZE; + DBPRT(("%s: pid=%d ses=%d mem=%d totmem=%d\n", id, +- pp->kp_proc.p_pid, sess_tbl[i], +- pp->kp_eproc.e_vm.vm_rssize, memsize)) ++ pp->ki_pid, sess_tbl[i], ++ pp->ki_rssize * PAGE_SIZE, memsize)) + } + + return (memsize); +@@ -485,9 +453,7 @@ + if (!injob(pjob, sess_tbl[i])) + continue; + +- if (ctob(pp->kp_eproc.e_vm.vm_tsize + +- pp->kp_eproc.e_vm.vm_dsize + +- pp->kp_eproc.e_vm.vm_ssize) > limit) ++ if (pp->ki_size > limit) + return (TRUE); + } + +@@ -732,7 +698,7 @@ + const void *b) + + { +- return((int)((struct kinfo_proc *)a)->kp_eproc.e_paddr - (int)((struct kinfo_proc *)b)->kp_eproc.e_paddr); ++ return((int)((struct kinfo_proc *)a)->ki_paddr - (int)((struct kinfo_proc *)b)->ki_paddr); + } + + int bs_cmp( +@@ -741,7 +707,7 @@ + const void *member) + + { +- return((int)((struct session *)key)->s_leader - (int)((struct kinfo_proc *)member)->kp_eproc.e_paddr); ++ return((int)((struct session *)key)->s_leader - (int)((struct kinfo_proc *)member)->ki_paddr); + } + + +@@ -786,24 +752,10 @@ + + qsort(proc_tbl, nproc, sizeof(struct kinfo_proc), qs_cmp); + +- for (i=0, kp=proc_tbl; i<nproc; i++, kp++) { +- if (kvm_read(kd, (u_long)kp->kp_eproc.e_sess, &ss, sizeof(ss)) +- != sizeof(ss)) { +- sprintf(log_buffer, +- "kvm_read: %s", kvm_geterr(kd)); +- log_err(errno, id, log_buffer); +- return (PBSE_SYSTEM); +- } +- if (ss.s_leader == kp->kp_eproc.e_paddr || +- ss.s_leader == NULL) { +- sid = kp->kp_proc.p_pid; +- } +- else { +- leader = bsearch(&ss, proc_tbl, nproc, +- sizeof(struct kinfo_proc), bs_cmp); +- sid = leader ? leader->kp_proc.p_pid : 0; +- } +- sess_tbl[i] = sid; ++ for (i=0; i<nproc; i++) { ++ struct kinfo_proc *pp = &proc_tbl[i]; ++ ++ sess_tbl[i] = pp->ki_sid; + } + + return (PBSE_NONE); +@@ -1012,8 +964,8 @@ + continue; + + DBPRT(("%s: send signal %d to pid %d\n", id, +- sig, pp->kp_proc.p_pid)) +- (void)kill(pp->kp_proc.p_pid, sig); ++ sig, pp->ki_pid)) ++ (void)kill(pp->ki_pid, sig); + ++ct; + } + return ct; +@@ -1118,36 +1070,10 @@ + if (jobid != sess_tbl[i]) + continue; + +- cputime += tvk(pp->kp_proc.p_rtime); +- +- if (pp->kp_proc.p_ru == NULL) { +- struct pstats ps; +- +- if (pp->kp_proc.p_stats == NULL) +- continue; +- +- if (kvm_read(kd, (u_long)pp->kp_proc.p_stats, &ps, +- sizeof(ps)) != sizeof(ps)) { +- log_err(errno, id, "kvm_read(pstats)"); +- continue; +- } +- cputime += tv(ps.p_ru.ru_utime) + +- tv(ps.p_ru.ru_stime) + +- tv(ps.p_cru.ru_utime) + +- tv(ps.p_cru.ru_stime); +- } +- else { +- struct rusage ru; ++ cputime += pp->ki_runtime / 1000000; + +- if (kvm_read(kd, (u_long)pp->kp_proc.p_ru, &ru, +- sizeof(ru)) != sizeof(ru)) { +- log_err(errno, id, "kvm_read(session)"); +- continue; +- } +- cputime += tv(ru.ru_utime) + tv(ru.ru_stime); +- } + DBPRT(("%s: ses %d pid %d cputime %d\n", id, +- jobid, pp->kp_proc.p_pid, cputime)) ++ jobid, pp->ki_pid, cputime)) + + } + +@@ -1166,37 +1092,11 @@ + for (i=0; i<nproc; i++) { + struct kinfo_proc *pp = &proc_tbl[i]; + +- if (pid != pp->kp_proc.p_pid) ++ if (pid != pp->ki_pid) + continue; + +- cputime = tvk(pp->kp_proc.p_rtime); +- +- if (pp->kp_proc.p_ru == NULL) { +- struct pstats ps; +- +- if (pp->kp_proc.p_stats == NULL) +- break; +- +- if (kvm_read(kd, (u_long)pp->kp_proc.p_stats, &ps, +- sizeof(ps)) != sizeof(ps)) { +- log_err(errno, id, "kvm_read(pstats)"); +- break; +- } +- cputime += tv(ps.p_ru.ru_utime) + +- tv(ps.p_ru.ru_stime) + +- tv(ps.p_cru.ru_utime) + +- tv(ps.p_cru.ru_stime); +- } +- else { +- struct rusage ru; ++ cputime = pp->ki_runtime / 1000000; + +- if (kvm_read(kd, (u_long)pp->kp_proc.p_ru, &ru, +- sizeof(ru)) != sizeof(ru)) { +- log_err(errno, id, "kvm_read(session)"); +- break; +- } +- cputime += tv(ru.ru_utime) + tv(ru.ru_stime); +- } + DBPRT(("%s: pid %d cputime %d\n", id, pid, cputime)) + + sprintf(ret_string, "%.2f", (double)cputime * cputfactor); +@@ -1261,13 +1161,11 @@ + continue; + + found = 1; +- addmem = pp->kp_eproc.e_vm.vm_tsize + +- pp->kp_eproc.e_vm.vm_dsize + +- pp->kp_eproc.e_vm.vm_ssize; ++ addmem = pp->ki_size; + memsize += addmem; + } + if (found) { +- sprintf(ret_string, "%ukb", ctob(memsize) >> 10); /* KB */ ++ sprintf(ret_string, "%ukb", memsize / 1024); /* KB */ + return ret_string; + } + +@@ -1289,13 +1187,11 @@ + for (i=0; i<nproc; i++) { + struct kinfo_proc *pp = &proc_tbl[i]; + +- if (pid != pp->kp_proc.p_pid) ++ if (pid != pp->ki_pid) + continue; + +- memsize = pp->kp_eproc.e_vm.vm_tsize + +- pp->kp_eproc.e_vm.vm_dsize + +- pp->kp_eproc.e_vm.vm_ssize; +- sprintf(ret_string, "%ukb", ctob(memsize) >> 10); /* KB */ ++ memsize = pp->ki_size; ++ sprintf(ret_string, "%ukb", memsize / 1024); /* KB */ + return ret_string; + } + +@@ -1358,10 +1254,10 @@ + continue; + + found = 1; +- resisize += pp->kp_eproc.e_vm.vm_rssize; ++ resisize += pp->ki_rssize * PAGE_SIZE; + } + if (found) { +- sprintf(ret_string, "%ukb", ctob(resisize) >> 10); /* KB */ ++ sprintf(ret_string, "%ukb", resisize / 1024); /* KB */ + return ret_string; + } + +@@ -1385,11 +1281,11 @@ + for (i=0; i<nproc; i++) { + struct kinfo_proc *pp = &proc_tbl[i]; + +- if (pid != pp->kp_proc.p_pid) ++ if (pid != pp->ki_pid) + continue; + +- resisize = pp->kp_eproc.e_vm.vm_rssize; +- sprintf(ret_string, "%ukb", ctob(resisize) >> 10); /* KB */ ++ resisize = pp->ki_rssize * PAGE_SIZE; ++ sprintf(ret_string, "%ukb", resisize / 1024); /* KB */ + return ret_string; + } + +@@ -1462,12 +1358,12 @@ + for (i=0; i<nproc; i++) { + struct kinfo_proc *pp = &proc_tbl[i]; + +- if (pp->kp_eproc.e_pcred.p_ruid == 0) ++ if (pp->ki_ruid == 0) + continue; + + jobid = sess_tbl[i]; + DBPRT(("%s: pid %d sid %u\n", +- id, (int)pp->kp_proc.p_pid, jobid)) ++ id, (int)pp->ki_pid, jobid)) + for (j=0; j<njids; j++) { + if (jids[j] == jobid) + break; +@@ -1548,12 +1444,12 @@ + struct kinfo_proc *pp = &proc_tbl[i]; + + DBPRT(("%s[%d]: pid %d sid %u\n", +- id, num_pids, pp->kp_proc.p_pid, sess_tbl[i])) ++ id, num_pids, pp->ki_pid, sess_tbl[i])) + if (jobid != sess_tbl[i]) + continue; + + checkret(&fmt, 100); +- sprintf(fmt, " %d", pp->kp_proc.p_pid); ++ sprintf(fmt, " %d", pp->ki_pid); + fmt += strlen(fmt); + num_pids++; + } +@@ -1591,11 +1487,11 @@ + for (i=0; i<nproc; i++) { + struct kinfo_proc *pp = &proc_tbl[i]; + +- if ((uid = pp->kp_eproc.e_pcred.p_ruid) == 0) ++ if ((uid = pp->ki_ruid) == 0) + continue; + + DBPRT(("%s: pid %d uid %u\n", +- id, (int)pp->kp_proc.p_pid, uid)) ++ id, (int)pp->ki_pid, uid)) + for (j=0; j<nuids; j++) { + if (uids[j] == uid) + break; +@@ -1884,23 +1780,12 @@ + continue; + } + else { +- if (value != pp->kp_proc.p_pid) ++ if (value != pp->ki_pid) + continue; + } + +- if (pp->kp_proc.p_stats == NULL) { +- rm_errno = RM_ERR_SYSTEM; +- return NULL; +- } +- +- if (kvm_read(kd, (u_long)pp->kp_proc.p_stats, &ps, +- sizeof(ps)) != sizeof(ps)) { +- log_err(errno, id, "kvm_read(pstats)"); +- rm_errno = RM_ERR_SYSTEM; +- return NULL; +- } + found = 1; +- start = MIN(start, ps.p_start.tv_sec); ++ start = MIN(start, pp->ki_start.tv_sec); + } + if (found) { + sprintf(ret_string, "%ld", (long)((double)(now - start) * wallfactor)); +@@ -2035,7 +1920,7 @@ + dirdev = sb.st_dev; + DBPRT(("dir has devnum %d\n", dirdev)) + +- if (setfsent() == NULL) { ++ if (setfsent() == 0) { + log_err(errno, id, "setfsent"); + rm_errno = RM_ERR_SYSTEM; + return NULL; diff --git a/sysutils/torque/files/patch-pbs_mkdirs.in b/sysutils/torque/files/patch-pbs_mkdirs.in new file mode 100644 index 000000000000..732193534b50 --- /dev/null +++ b/sysutils/torque/files/patch-pbs_mkdirs.in @@ -0,0 +1,19 @@ +--- buildutils/dpbs_mkdirs.in.orig Tue Jun 20 02:22:46 2006 ++++ buildutils/pbs_mkdirs.in Thu Sep 14 15:06:48 2006 +@@ -105,6 +105,7 @@ + # + prefix=@prefix@ + exec_prefix=@exec_prefix@ ++DESTDIR=@prefix@ + CHK_TREE=${DESTDIR}@bindir@/chk_tree + + PBS_DEFAULT_SERVER=@PBS_DEFAULT_SERVER@ +@@ -112,7 +113,7 @@ + # PBS_SERVER_HOME is defined without DESTDIR so that DEFAULT_FILE and EVIRON + # can be based on SERVER_HOME. SERVER_HOME is defined a second time to pick + # up DESTDIR +-test -n "$PBS_SERVER_HOME" || PBS_SERVER_HOME=@PBS_SERVER_HOME@ ++test -n "$PBS_SERVER_HOME" || PBS_SERVER_HOME=/share/examples/torque/var/spool/torque/ + test -n "$PBS_DEFAULT_FILE" || PBS_DEFAULT_FILE=${DESTDIR}@PBS_DEFAULT_FILE@ + test -n "$PBS_ENVIRON" || PBS_ENVIRON=${DESTDIR}@PBS_ENVIRON@ + diff --git a/sysutils/torque/files/pbs_mom.sh.in b/sysutils/torque/files/pbs_mom.sh.in new file mode 100644 index 000000000000..60cde8368343 --- /dev/null +++ b/sysutils/torque/files/pbs_mom.sh.in @@ -0,0 +1,27 @@ +#!/bin/sh + +# PROVIDE: pbs_mom +# REQUIRE: +# +# Add the following lines to /etc/rc.conf.local or /etc/rc.conf +# to enable this service: +# +# pbs_mom_enable (bool): Set to NO by default. +# Set it to YES to enable pbs_mom. +# + +. %%RC_SUBR%% + +name="pbs_mom" +rcvar=${name}_enable + +pidfile=/var/spool/torque/mom_priv/mom.lock +command=%%PREFIX%%/sbin/${name} + +load_rc_config $name + +: ${pbs_mom_enable="NO"} + +command_args="" + +run_rc_command "$1" diff --git a/sysutils/torque/files/pbs_sched.sh.in b/sysutils/torque/files/pbs_sched.sh.in new file mode 100644 index 000000000000..885be18bf945 --- /dev/null +++ b/sysutils/torque/files/pbs_sched.sh.in @@ -0,0 +1,27 @@ +#!/bin/sh + +# PROVIDE: pbs_sched +# REQUIRE: pbs_server +# +# Add the following lines to /etc/rc.conf.local or /etc/rc.conf +# to enable this service: +# +# pbs_sched_enable (bool): Set to NO by default. +# Set it to YES to enable pbs_sched. +# + +. %%RC_SUBR%% + +name="pbs_sched" +rcvar=${name}_enable + +pidfile=/var/spool/torque/sched_priv/sched.lock +command=%%PREFIX%%/sbin/${name} + +load_rc_config $name + +: ${pbs_sched_enable="NO"} + +command_args="" + +run_rc_command "$1" diff --git a/sysutils/torque/files/pbs_server.sh.in b/sysutils/torque/files/pbs_server.sh.in new file mode 100644 index 000000000000..e19696a349fe --- /dev/null +++ b/sysutils/torque/files/pbs_server.sh.in @@ -0,0 +1,27 @@ +#!/bin/sh + +# PROVIDE: pbs_server +# REQUIRE: +# +# Add the following lines to /etc/rc.conf.local or /etc/rc.conf +# to enable this service: +# +# pbs_server_enable (bool): Set to NO by default. +# Set it to YES to enable pbs_server. +# + +. %%RC_SUBR%% + +name="pbs_server" +rcvar=${name}_enable + +pidfile=/var/spool/torque/server_priv/server.lock +command=%%PREFIX%%/sbin/${name} + +load_rc_config $name + +: ${pbs_server_enable="NO"} + +command_args="" + +run_rc_command "$1" diff --git a/sysutils/torque/files/pkg-message.in b/sysutils/torque/files/pkg-message.in new file mode 100644 index 000000000000..426b0058b8d7 --- /dev/null +++ b/sysutils/torque/files/pkg-message.in @@ -0,0 +1,40 @@ +*************************************************************** +You can find example configuration in + + %%PREFIX%%/share/examples/torque/var/spool/torque + +On all machines, both server and computing nodes, copy it's +contents into + + /var/spool/torque/ + +and put hostname of the server into + + /var/spool/torque/server_name + +On computing nodes, put '$pbsserver ip.address.of.server' into + + /var/spool/torque/mom_priv/config + +On server, put hostnames of computing nodes, one per line, into + + /var/spool/torque/server_priv/nodes + +On computing nodes, add the following line to /etc/rc.conf: + + pbs_mom_enable="YES" + +On TORQUE server, add the following lines to /etc/rc.conf: + + pbs_server_enable="YES" + pbs_sched_enable="YES" + +To configure queues on server, execute + + %%PREFIX%%/share/examples/torque/torque.setup <admin> + +For further information, see + + http://www.clusterresources.com/torquedocs21/ + +*************************************************************** diff --git a/sysutils/torque/pkg-descr b/sysutils/torque/pkg-descr new file mode 100644 index 000000000000..57d945433616 --- /dev/null +++ b/sysutils/torque/pkg-descr @@ -0,0 +1,9 @@ +TORQUE is an open source resource manager providing control over +batch jobs and distributed compute nodes. It is a community effort +based on the original *PBS project and, with more than 1,200 patches, +has incorporated significant advances in the areas of scalability, +fault tolerance, and feature extensions contributed by NCSA, OSC, +USC , the U.S. Dept of Energy, Sandia, PNNL, U of Buffalo, TeraGrid, +and many other leading edge HPC organizations. + +WWW: http://www.clusterresources.com/pages/products/torque-resource-manager.php diff --git a/sysutils/torque/pkg-plist b/sysutils/torque/pkg-plist new file mode 100644 index 000000000000..2476cc20571e --- /dev/null +++ b/sysutils/torque/pkg-plist @@ -0,0 +1,73 @@ +include/pbs_error.h +include/pbs_ifl.h +include/tm.h +include/tm_.h +include/rpp.h +include/rm.h +lib/libtorque.so.0 +lib/libtorque.so +lib/libtorque.la +lib/libtorque.a +sbin/pbs_server +sbin/pbs_sched +sbin/pbs_mom +sbin/pbs_iff +bin/qalter +bin/qdel +bin/qhold +bin/qmove +bin/qorder +bin/qmsg +bin/qrerun +bin/qrls +bin/qselect +bin/qsig +bin/qstat +bin/qsub +bin/pbsdsh +bin/qdisable +bin/qenable +bin/qrun +bin/qstart +bin/qstop +bin/qterm +bin/pbsnodes +bin/qmgr +bin/nqs2pbs +sbin/pbs_demux +sbin/momctl +bin/chk_tree +bin/hostn +bin/printjob +bin/printtracking +bin/tracejob +bin/pbs-config +%%EXAMPLESDIR%%/torque.setup +%%EXAMPLESDIR%%/var/spool/torque/pbs_environment +%%EXAMPLESDIR%%/var/spool/torque/server_name +%%EXAMPLESDIR%%/var/spool/torque/sched_priv/sched_config +%%EXAMPLESDIR%%/var/spool/torque/sched_priv/resource_group +%%EXAMPLESDIR%%/var/spool/torque/sched_priv/holidays +%%EXAMPLESDIR%%/var/spool/torque/sched_priv/dedicated_time +@dirrm %%EXAMPLESDIR%%/var/spool/torque/aux +@dirrm %%EXAMPLESDIR%%/var/spool/torque/checkpoint +@dirrm %%EXAMPLESDIR%%/var/spool/torque/mom_logs +@dirrm %%EXAMPLESDIR%%/var/spool/torque/mom_priv/jobs +@dirrm %%EXAMPLESDIR%%/var/spool/torque/mom_priv +@dirrm %%EXAMPLESDIR%%/var/spool/torque/sched_logs +@dirrm %%EXAMPLESDIR%%/var/spool/torque/sched_priv +@dirrm %%EXAMPLESDIR%%/var/spool/torque/server_logs +@dirrm %%EXAMPLESDIR%%/var/spool/torque/server_priv/jobs +@dirrm %%EXAMPLESDIR%%/var/spool/torque/server_priv/queues +@dirrm %%EXAMPLESDIR%%/var/spool/torque/server_priv/acl_svr +@dirrm %%EXAMPLESDIR%%/var/spool/torque/server_priv/acl_hosts +@dirrm %%EXAMPLESDIR%%/var/spool/torque/server_priv/acl_users +@dirrm %%EXAMPLESDIR%%/var/spool/torque/server_priv/acl_groups +@dirrm %%EXAMPLESDIR%%/var/spool/torque/server_priv/accounting +@dirrm %%EXAMPLESDIR%%/var/spool/torque/server_priv +@dirrm %%EXAMPLESDIR%%/var/spool/torque/undelivered +@dirrm %%EXAMPLESDIR%%/var/spool/torque/spool +@dirrm %%EXAMPLESDIR%%/var/spool/torque +@dirrm %%EXAMPLESDIR%%/var/spool +@dirrm %%EXAMPLESDIR%%/var +@dirrm %%EXAMPLESDIR%% |