-
Notifications
You must be signed in to change notification settings - Fork 0
/
RELEASENOTES
275 lines (204 loc) · 12.8 KB
/
RELEASENOTES
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
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
Release Notes
Gold Allocation Manager
Version 2.2.0
Copyright (c) 2010 Adaptive Computing
This document provides an overview of the changes made in a minor release
of Gold Allocation Manager. A minor release will generally include new
functionality and features that can break compatibility with previous
versions. See the Migration section for migration procedures.
----------------------------------------------------------------------
Overview
This release of Gold Allocation Manager features enhanced charge rate
types that give more flexibility in the way charges can be calculated.
Other changes were made to allow for better support of incremental
charging and cost determination. Command-line clients were added that aid
in the importing and manipulation of job records.
----------------------------------------------------------------------
New Features
The following is a list of new features added in this release.
* Additional Charge Rate Types - This release added a new Instance field
to the ChargeRate object in support of an expanded set of charge rate
types (See the chapter on Managing Charge Rates in the Gold User's
Guide for details). The following new charge rate types replace the
former types (Resource, Usage, Multiplier, other):
* VBR - Value Based Resource (formerly Resource) [These charge
rates define how much it costs per unit of time to use a
consumable resource like processors, memory or a telescope, etc.]
* NBR - Name Based Resource [These charge rates define how much it
costs per unit of time to use a named resource such as
license=matlab, etc.]
* VBU - Value Based Usage (formerly Usage) [These charge rates
define how much it costs for total resource usage such as
cputime, power consumed, generic resources or licenses that are
charged flat fees per use, and which will be subject to
multiplier charge rates.]
* NBU - Name Based Usage [These charge rates define how much it
costs to use a named attribute having a flat charge such as
feature=black, and which will be subject to multiplier charge
rates.]
* VBM - Value Based Multiplier (formerly Multiplier) [These are
scaled multipliers which apply a multiplicative charge factor
based on a numeric scaling factor (such as Discount=.8).]
* NBM - Name Based Multiplier (formerly other) [These are quality
based multipliers which apply a multiplicative charge factor
based on a named quality of the job such as quality of service,
nodetype, queue, user, etc.]
* VBF - Value Based Fee [These charge rates define how much to
charge for scaled or enumerated fees such as setup fees, shipping
charges, etc. which should be added after the multipliers are
applied.]
* NBF - Name Based Fee [These charge rates define how much it costs
to use a named attribute having a flat charge such as feature,
etc. which should be added after the multipliers are applied.]
* <other> - Multi-dimensional Value Based Resource [These charge
rates apply a consumable resource cost that varies depending on
the value of a separate named job property.]
* New commands to import and manipulate job records - Three new command
line clients have been added to import and manipulate job records:
* gmkjob - Import or create a new job record
* gchjob - Modify a job record
* grmjob - Delete a job record
* Distinction between charge properties and job properties - Prior to
Gold 2.2, WallDuration, StartTime, EndTime and Description options
specified to gcharge, greserve and gquote were taken as both charge
and job properties, making it difficult to support incremental
charging. In Gold 2.2, these properties have now been disambiguated.
The duration, starttime, endtime and description for the charge will
be passed via the standard options (-t, -s, -e, -d) while the same
properties for the job (duration, starttime, endtime and description)
can be passed in separately using the extension option (i.e. -X
WallDuration=1234). See the man pages for gcharge, greserve and gquote
for additional details.
* CostOnly Quote Option - A job quote now supports a new costOnly option
which will return a cost estimate without performing balance checking
or other qualifying validation. This is useful if you would like to
know how much something would cost, but you are not interested in
establishing that a user has an allocation, or belongs to a specified
project, etc.
* Improved Client Performance - The gold server was modified to preload
the utf8 module (instead of doing so after the fork for each
individual client request). This has been shown to give an 10-20%
speedup for common scheduler action command invocations. This
improvement is also available in the gold 2.1.12.2 fix release.
----------------------------------------------------------------------
Migration Procedures
The following recommendations should assist you in migrating from an
existing Gold 2.1 installation to a new Gold 2.2 installation.
Important: It is important that you read this entire section before
proceding with the migration upgrade steps.
----------------------------------------------------------------------
Database Migration
If you have an existing Gold 2.1 installation, you will need to develop a
strategy for redefining/migrating your essential data into the new Gold
2.2 database and object format.
Since all of the database changes are concentrated in the ChargeRate (and
QuotationChargeRate) table, most of the database fields can remain
unchanged and a database migration would be possible in most cases.
For those willing to risk it, we have made a best-effort attempt to create
a database migration script which will attempt to convert an existing Gold
2.1 database into a Gold 2.2 database. It is NOT guaranteed to work
correctly on your database.
Note: SQLite databases cannot yet be migrated in most circumstances
since current versions do not support the ALTER TABLE ADD COLUMN syntax.
+------------------------------------------------------------------------+
| USE AT YOUR OWN RISK!!! |
|------------------------------------------------------------------------|
| You should MAKE A BACKUP of your gold databases before running this |
| script. If you proceed without a backup, a failure in this script |
| could irreveribly corrupt the integrity and data of your gold |
| database. |
| |
| Any part of this script should only be run once. If it fails, you are |
| going to need to carve it up and just run the parts that did not run |
| successfully the first time. I would recommend running this under |
| script so that you can capture and examine the output for progress and |
| errors. |
+------------------------------------------------------------------------+
Run the test/bank_2.1_to_2.2.pl script to migrate your Gold 2.1 database
to the new Gold 2.2 format. It will perform the following steps:
* Add a Job Stage Value of Create and add Job Create as a Scheduler Role
Action
* Create new ChargeRate and QuotationChargeRate Instance Attributes
* Translate Existing ChargeRates to new format (VBR, NBU, etc.)
----------------------------------------------------------------------
Migration Upgrade Steps
Gold Allocation Manager uses the standard configure, make and make install
steps for upgrades. This document assumes that you are updating Gold
Allocation Manager to a new major or minor release from an existing
installation. Instructions for migrating to a new maintenance or fix
release can be found in the Gold Allocation Manager User's Guide. This
document provides a number of sample steps referenced to a particular
installation on a Linux platform using the bash shell. These steps
indicate the userid in brackets performing the step. The exact commands to
be performed and the user that issues them will vary based on the
platform, shell, installation preferences, etc. These steps are very
similar to the steps for performing a maintenance or fix upgrade install
with the exception that the migration script should be run before shutting
down the server for the make install.
To build and update Gold Allocation Manager, you first need to unpack the
tar archive and change directory into the top directory of the
distribution.
[gold]$ cd ~/src
[gold]$ tar -zxvf gold-2.2.0.5.tar.gz
[gold]$ cd gold-2.2.0.5
To configure Gold Allocation Manager, run the "configure" script provided
with the distribution with the desired options.
Note: In Gold 2.2, the default Gold installation location has been
changed to /opt/gold (from /usr/local/gold). Thus, if you were
previously running ./configure without the -prefix option to install
Gold into /usr/local/gold, when upgrading to Gold 2.2 you will need to
explicitly specify your location now with ./configure
-prefix=/usr/local/gold in order to have Gold installed in the same
place.
[gold]$ ./configure
To compile the program, type make:
[gold]$ make
If you would like to install the web gui, type make gui:
[gold]$ make gui
Run the migration script. The prior version of goldd 2.2 must be running
in order for this script to function. See the previous section for more
details on the migration script.
[gold]$ src/bank_2.1_to_2.2.pl --I-understand-the-risks
Stop the server daemon.
[gold]$ goldd -k
Use `make install' to install Gold Allocation Manager. You may need to do
this as root if any of the installation or log directories do not already
have write permission as the gold admin user.
[root]# make install
If you would like to install the web gui, type make install-gui (as root).
[root]# make install-gui
Start the server daemon up.
[gold]$ goldd
----------------------------------------------------------------------
Differences
* Default prefix changed to /opt/gold - In Gold 2.2, the default Gold
installation location has been changed to /opt/gold (from
/usr/local/gold). Thus, if you were previously running ./configure
without the -prefix option to install Gold into /usr/local/gold, when
upgrading to Gold 2.2 you will need to explicitly specify your
location now with ./configure -prefix=/usr/local/gold in order to have
Gold installed in the same place.
* Scheduler action commands now use gold_job_id as default argument -
The optionless argument in gquote, greserve and gcharge has been
changed to Id ([-j] <gold_job_id>) instead of JobId (-J <job_id>)
which now must be use an explicit -J flag. In Gold 2.1 and earlier,
gcharge 123 has been interpreted to mean a charge against the resource
manager job id 123. As of Gold 2.2, gcharge 123 will be interpreted to
mean a charge against the gold job id 123. Any scripts (such as a
prolog or epilog) which make use of these commands should be modified
accordingly.
* Disambiguation of charge and job properties in scheduler action
commands - In Gold 2.2, in order to better support incremental
charging, the duration, starttime, endtime and description for the
charge will be passed via the standard options (-t, -s, -e, -d) while
the same properties for the job (duration, starttime, endtime and
description) may be passed in separately using the extension option
(i.e. -X WallDuration=1234). If you are are using prolog and epilog
scripts to invoke greserve and gcharge, and you are charging for the
entire job (not incremental charging), then if you were using gcharge
-t 1234 -s "2010-07-01 12:00:00" -e "2010-07-01 12:20:34", in Gold 2.2
you would have to use gcharge -t 1234 -X WallDuration=1234 -X
StartTime="2010-07-01 12:00:00" -X EndTime="2010-07-01 12:20:34" to
accomplish similar results (the -t option would be used in the charge
calculation to determine cost, while the -X options would be sent in
as job metadata for the job accounting records).