blob: cc4c12607f106673df55def338f49e978669f7c0 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
|
# Copyright 1999-2008 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/sys-cluster/torque/torque-2.2.1-r2.ebuild,v 1.9 2008/04/12 18:56:06 dertobi123 Exp $
inherit autotools flag-o-matic eutils
DESCRIPTION="Resource manager and queuing system based on OpenPBS"
HOMEPAGE="http://www.clusterresources.com/products/torque/"
SRC_URI="http://www.clusterresources.com/downloads/${PN}/${P}.tar.gz"
LICENSE="openpbs"
SLOT="0"
KEYWORDS="amd64 hppa ia64 ppc ppc64 ~sparc x86"
IUSE="tk crypt server syslog doc"
PROVIDE="virtual/pbs"
# ed is used by makedepend-sh
DEPEND_COMMON="virtual/libc
sys-libs/ncurses
sys-libs/readline
tk? ( dev-lang/tk )
syslog? ( virtual/logger )
!virtual/pbs
!sys-cluster/openpbs-common
!games-util/qstat"
DEPEND="${DEPEND_COMMON}
sys-apps/ed"
RDEPEND="${DEPEND_COMMON}
crypt? ( net-misc/openssh )
!crypt? ( net-misc/netkit-rsh )"
[ -n "${PBS_SERVER_HOME}" ] || PBS_SERVER_HOME="/var/spool/torque"
src_unpack() {
unpack ${A}
cd "${S}"
epatch "${FILESDIR}"/${PN}-setuid-safety-am.patch
# Otherwise we'll fail due to strings over ISO C89 defined length 509
sed -i 's:gcc_warning_flags="\(.*\)-Werror":gcc_warning_flags="\1":' configure.ac
eautoreconf || die "eautoreconf failed"
}
src_compile() {
local myconf
if use crypt; then
myconf="--with-rcp=scp"
else
myconf="--with-rcp=mom_rcp"
fi
[ -n "${PBS_SERVER_NAME}" ] || PBS_SERVER_NAME=$(hostname -f)
# TODO: Allow cpusets
econf \
$(use_enable tk gui) \
$(use_enable syslog) \
$(use_enable server) \
--with-server-home=${PBS_SERVER_HOME} \
--with-environ=/etc/pbs_environment \
--with-default-server=${PBS_SERVER_NAME} \
${myconf} \
|| die "econf failed"
emake || die "emake failed"
}
# WARNING
# OpenPBS is extremely stubborn about directory permissions. Sometimes it will
# just fall over with the error message, but in some spots it will just ignore
# you and fail strangely. Likewise it also barfs on our .keep files!
pbs_createspool() {
local root="$1"
local s="$(dirname "${PBS_SERVER_HOME}")"
local h="${PBS_SERVER_HOME}"
local sp="${h}/server_priv"
einfo "Building spool directory under ${D}${h}"
local a d m
local dir_spec="
0755:${h}/aux 0700:${h}/checkpoint
0755:${h}/mom_logs 0751:${h}/mom_priv 0751:${h}/mom_priv/jobs
1777:${h}/spool 1777:${h}/undelivered"
if use server; then
dir_spec="${dir_spec} 0755:${h}/sched_logs
0755:${h}/sched_priv/accounting 0755:${h}/server_logs
0750:${h}/server_priv 0755:${h}/server_priv/accounting
0750:${h}/server_priv/acl_groups 0750:${h}/server_priv/acl_hosts
0750:${h}/server_priv/acl_svr 0750:${h}/server_priv/acl_users
0750:${h}/server_priv/jobs 0750:${h}/server_priv/queues"
fi
for a in ${dir_spec}; do
d="${a/*:}"
m="${a/:*}"
if [[ ! -d "${root}${d}" ]]; then
install -d -m${m} "${root}${d}"
else
chmod ${m} "${root}${d}"
fi
# (#149226) If we're running in src_*, then keepdir
if [[ "${root}" = "${D}" ]]; then
keepdir ${d}
fi
done
}
src_install() {
# Make directories first
pbs_createspool "${D}"
make DESTDIR="${D}" install || die "make install failed"
dodoc CHANGELOG DEVELOPMENT README.* Release_Notes || die "dodoc failed"
if use doc; then
dodoc doc/admin_guide.ps doc/*.pdf || die "dodoc failed"
fi
# this file MUST exist for PBS/Torque to work
# but try to preserve any customatizations that the user has made
dodir /etc
mv "${D}"${PBS_SERVER_HOME}/pbs_environment "${D}"/etc/
# The build script isn't alternative install location friendly,
# So we have to fix some hard-coded paths in tclIndex for xpbs* to work
for file in `find "${D}" -iname tclIndex`; do
sed -e "s/${D//\// }/ /" "${file}" > "${file}.new"
mv "${file}.new" "${file}"
done
if use server; then
newinitd "${FILESDIR}"/pbs_server-init.d-2.2.1-r1 pbs_server
newinitd "${FILESDIR}"/pbs_sched-init.d-2.2.1-r1 pbs_sched
fi
newinitd "${FILESDIR}"/pbs_mom-init.d-2.2.1-r1 pbs_mom
newconfd "${FILESDIR}"/torque-conf.d-2.2.1-r1 torque
newenvd "${FILESDIR}"/torque-env.d-2.2.1-r1 25torque
}
pkg_preinst() {
if [[ -f "${ROOT}etc/pbs_environment" ]]; then
cp "${ROOT}etc/pbs_environment" "${D}"/etc/pbs_environment
fi
if [ -n "${PBS_SERVER_NAME}" ]; then
echo "${PBS_SERVER_NAME}" > "${D}${PBS_SERVER_HOME}/server_name"
elif [[ -f "${ROOT}${PBS_SERVER_HOME}/server_name" ]]; then
cp "${ROOT}${PBS_SERVER_HOME}/server_name" "${D}${PBS_SERVER_HOME}/server_name"
fi
# Fix up the env.d file to use our set server home.
sed -i "s:/var/spool/torque:${PBS_SERVER_HOME}:g" "${D}"/etc/env.d/25torque
}
pkg_postinst() {
pbs_createspool "${ROOT}"
elog "If this is the first time torque has been installed, then you are not"
elog "ready to start the server. Please refer to the documentation located at:"
elog "http://www.clusterresources.com/wiki/doku.php?id=torque:torque_wiki"
elog "For a basic setup, you may use emerge --config ${PN}"
elog "There are a couple of changes in this ebuild."
elog "1.) The pbs-server-home has been moved from /var/spool/PBS to /var/spool/torque."
elog "2.) pbs_server, pbs_mom and pbs_sched now have separate init scripts"
elog "Be sure to run env-update if this is your first install or you"
elog "changed PBS_SERVER_HOME!"
}
# Either the correct PBS_SERVER_HOME and PBS_SERVER_NAME are set
# or we use the default HOME and the localhost as the server.
# root will be setup as the primary operator/manager, the local machine
# will be added as a node and we'll create a simple queue, batch.
pkg_config() {
local h="${ROOT}/${PBS_SERVER_HOME}"
local rc=0
ebegin "Configuring Torque"
[ -n "${PBS_SERVER_NAME}" ] || PBS_SERVER_NAME=$(hostname -f)
einfo "Using ${PBS_SERVER_HOME} as the pbs homedir"
einfo "Using ${PBS_SERVER_NAME} as the pbs_server"
# Check for previous configuration and bail if found.
if [ -e "${h}/server_priv/acl_svr/operators" ] \
|| [ -e "${h}/server_priv/nodes" ] \
|| [ -e "${h}/mom_priv/config" ]; then
ewarn "Previous Torque configuration detected. Press any key to"
ewarn "continue or press Control-C to abort now"
read
fi
# pbs_mom configuration.
echo "\$pbsserver ${PBS_SERVER_NAME}" > "${h}/mom_priv/config"
echo "\$logevent 255" >> "${h}/mom_priv/config"
if use server; then
local qmgr="${ROOT}/usr/bin/qmgr -c"
if ! echo "y" | "${ROOT}"/usr/sbin/pbs_server \
-d "${ROOT}${PBS_SERVER_HOME}" -t create &>/dev/null; then
eerror "Failed to start pbs_server"
rc=1
else
${qmgr} "set server operators = root@$(hostname -f)" ${PBS_SERVER_NAME}
${qmgr} "create queue batch" ${PBS_SERVER_NAME}
${qmgr} "set queue batch queue_type = Execution" ${PBS_SERVER_NAME}
${qmgr} "set queue batch started = True" ${PBS_SERVER_NAME}
${qmgr} "set queue batch enabled = True" ${PBS_SERVER_NAME}
${qmgr} "set server default_queue = batch" ${PBS_SERVER_NAME}
${qmgr} "set server resources_default.nodes = 1" ${PBS_SERVER_NAME}
${qmgr} "set server scheduling = True" ${PBS_SERVER_NAME}
"${ROOT}"/usr/bin/qterm -t quick ${PBS_SERVER_NAME} || rc=1
# Add the local machine as a node.
echo "$(hostname -f) np=1" > "${h}/server_priv/nodes"
fi
fi
eend ${rc}
}
|