-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathjsv_core_binding.sh
155 lines (122 loc) · 5.17 KB
/
jsv_core_binding.sh
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
#!/bin/sh
# Copyright (c) 2001, 2010, Oracle and/or its affiliates. All rights reserved.
###########################################################################
#
# Example of a JSV script that verifies if a special PE (here: mytestpe),
# which is configured with the $pe_slots strategy for requesting slots
# on only one host, is used together with a core binding strategy to
# ensure that all requests are using the core binding facility.
#
# "mytestpe" should always be requested in case of a parallel job which should
# make use of more than one core
#
# This script ensures that:
#
# - all non-parallel requests are allocating exactly one core (linear:1)
# - all parallel requests to the parallel environment "mytestpe"
# are allocating not more cores than (max-) slots.
# - in case if max-slots is lesser than requested cores, the
# max-slots is modified
# - non-parallel jobs with binding request of more than one core are
# rejected
# - requests to other parallel environments are rejected (they have
# to be configured here depending on they are using one host or more)
#
#
# Be careful: Job verification scripts are started with sgeadmin
# permissions if they are executed within the master process
#
# Since this is a bash script (which could be slow) use this script
# on client side.
PATH=/bin:/usr/bin
jsv_on_start()
{
return
}
jsv_on_verify()
{
if [ "`jsv_get_param binding_strategy`" != "" ]; then
# ---------------------------------------------
# a binding strategy was requested
# -> check if amount of cores is amount of slots
# ---------------------------------------------
# get amount of cores requested for binding
if [ "`jsv_get_param binding_strategy`" != "explicit" ]; then
# for linear and striding "binding_amount" denotes the # of cores
amount=`jsv_get_param binding_amount`
else
# for the explicit request the numer of requestet cores are here
amount=`jsv_get_param binding_exp_n`
fi
if [ "`jsv_get_param pe_name`" = "mytestpe" ]; then
# ------------------------------------------------
# verify if requested slots equals requested cores
# if not correct the parallel environment request
# ------------------------------------------------
max_slots=`jsv_get_param pe_max`
min_slots=`jsv_get_param pe_min`
# min and max slots must be equal in order to ensure
# that cores are matching slots
if [ $max_slots != $min_slots ]; then
jsv_set_param pe_min $max_slots
fi
# correct the pe request more cores than slots are requested
if [ $amount > $max_slots ]; then
jsv_set_param pe_max $amount
jsv_set_param pe_min $amount
jsv_correct "Max slots was set to the amount of requested cores"
return
fi
else
# -------------------------------------------------------------
# No parallel environment was requested -> ensure that not more
# than 1 core is requested
# -------------------------------------------------------------
if [ x$amount != "x1" ]; then
jsv_reject "Amount of requested cores != 1: Please request PE!"
return
fi
jsv_correct "linear now"
fi
else
# ------------------------------
# core binding was not requested
# ------------------------------
if [ "`jsv_get_param pe_name`" = "" ]; then
# -------------------------------------------
# in case no parallel environment was chosen
# add a default request of one processor core
# -------------------------------------------
# set the binding strategy to linear (without given start point: linear_automatic)
jsv_set_param binding_type "set"
jsv_set_param binding_amount "1"
jsv_set_param binding_strategy "linear_automatic"
jsv_correct "Job was modified by JSV"
return
elif [ "`jsv_get_param pe_name`" = "mytestpe" ]; then
# --------------------------------------------
# "mytestpe" was requested but no core binding
# -> set linear allocation with pe max slots
# --------------------------------------------
# max amount of requested slots (mytestpe)
# max_slots=`jsv_get_param pe_max`
# if allocation rule is $pe_slots --> use max_slots for amount
jsv_set_param binding_amount "1"
jsv_set_param binding_type "set"
jsv_set_param binding_strategy "linear_automatic"
jsv_correct "Job was modified by JSV"
return
else
# ---------------------------------------------
# some other parallel environment was requested
# -> the binding request is valid for each host
# ---------------------------------------------
jsv_reject "Other PE..."
return
fi
fi
jsv_accept "Job is accepted"
}
. ${SGE_ROOT}/util/resources/jsv/jsv_include.sh
# main routine handling the protocol between client/master and JSV script
jsv_main