RAL HTCondor Multicore Jobs Configuration
ARC CE
Make sure the environment variable RUNTIME_ENABLE_MULTICORE_SCRATCH is defined. The simplest way is to define it in the default runtime environment, in our case ENV/GLITE. Our ENV/GLITE can be seen here https://github.com/alahiff/ral-arc-ce-rte/blob/master/GLITE.
Defrag daemon setup
We have the condor_defrag daemon configured to run on one of our central managers. The configuration is as follows:
DAEMON_LIST = $(DAEMON_LIST) DEFRAG DEFRAG_INTERVAL = 600 DEFRAG_DRAINING_MACHINES_PER_HOUR = 30.0 DEFRAG_MAX_CONCURRENT_DRAINING = 60 DEFRAG_MAX_WHOLE_MACHINES = 300 DEFRAG_SCHEDULE = graceful
## Allow some defrag configuration to be settable DEFRAG.SETTABLE_ATTRS_ADMINISTRATOR = DEFRAG_MAX_CONCURRENT_DRAINING,DEFRAG_DRAINING_MACHINES_PER_HOUR,DEFRAG_MAX_WHOLE_MACHINES ENABLE_RUNTIME_CONFIG = TRUE
## Which machines are more desirable to drain DEFRAG_RANK = ifThenElse(Cpus >= 8, -10, (TotalCpus - Cpus)/(8.0 - Cpus))
# Definition of a "whole" machine: # - anything with 8 cores (since multicore jobs only need 8 cores, don't need to drain whole machines with > 8 cores) # - must be configured to actually start new jobs (otherwise machines which are deliberately being drained will be included) DEFRAG_WHOLE_MACHINE_EXPR = ((Cpus == TotalCpus) || (Cpus >= 8)) && StartJobs =?= True
# Decide which machines to drain # - must not be cloud machines # - must be healthy # - must be configured to actually start new jobs DEFRAG_REQUIREMENTS = PartitionableSlot && Offline =!= True && RalCluster =!= "wn-cloud" && StartJobs =?= True && NODE_IS_HEALTHY =?= True
## Logs MAX_DEFRAG_LOG = 104857600 MAX_NUM_DEFRAG_LOG = 10
Adjusting draining based on demand
The following script is run as a cron every 20 minutes on the same central manager where the condor_defrag daemon runs:
#!/bin/bash # Change condor_defrag daemon parameters depending on how many idle and running multicore jobs there are.
function setDefrag () { # Get the address of the defrag daemon defrag_address=$(condor_status -any -autoformat MyAddress -constraint 'MyType =?= "Defrag"')
# Log echo "Setting DEFRAG_MAX_CONCURRENT_DRAINING=$3, DEFRAG_DRAINING_MACHINES_PER_HOUR=$4, DEFRAG_MAX_WHOLE_MACHINES=$5 (idle multicore=$1, running multicore=$2)"
# Set configuration /usr/bin/condor_config_val -address "$defrag_address" -rset "DEFRAG_MAX_CONCURRENT_DRAINING = $3" >& /dev/null /usr/bin/condor_config_val -address "$defrag_address" -rset "DEFRAG_DRAINING_MACHINES_PER_HOUR = $4" >& /dev/null /usr/bin/condor_config_val -address "$defrag_address" -rset "DEFRAG_MAX_WHOLE_MACHINES = $5" >& /dev/null /usr/sbin/condor_reconfig -daemon defrag >& /dev/null }
# Get total number of idle multicore jobs idle_jobs=$(condor_q -global -constraint 'RequestCpus == 8 && JobStatus == 1' -autoformat ClusterId | wc -l)
# Get total numbe of running multicore jobs running_jobs=$(condor_q -global -constraint 'RequestCpus == 8 && JobStatus == 2' -autoformat ClusterId | wc -l)
if [ $idle_jobs -gt 20 ] && [ $running_jobs -lt 190 ] then setDefrag $idle_jobs $running_jobs 60 40 300 elif [ $idle_jobs -gt 20 ] && [ $running_jobs -gt 190 ] then setDefrag $idle_jobs $running_jobs 8 8 300 else setDefrag $idle_jobs $running_jobs 1 1 4 fi
Negotiator
To ensure that multi-core slots are not lost too quickly, we configure the negotiator to consider multi-core groups before the normal single core groups (apart from high priority groups associated with SUM tests) using this configuration:
GROUP_SORT_EXPR = ifThenElse(AccountingGroup=?="<none>", 3.4e+38,                                                                 \
                  ifThenElse(AccountingGroup=?="group_HIGHPRIO", -23,                                                             \
                  ifThenElse(AccountingGroup=?="group_HIGHPRIO.prodlhcb", -22,                                                    \
                  ifThenElse(AccountingGroup=?="group_HIGHPRIO.prodcms", -21,                                                     \
                  ifThenElse(AccountingGroup=?="group_HIGHPRIO.cms_pilot", -20,                                                   \
                  ifThenElse(AccountingGroup=?="group_DTEAM_OPS", -19,                                                            \
                  ifThenElse(regexp("multicore",AccountingGroup),ifThenElse(GroupQuota > 0,-2+GroupResourcesInUse/GroupQuota,-1), \
                  ifThenElse(GroupQuota > 0, GroupResourcesInUse/GroupQuota, 3.3e+38))))))))
Note that all of our multi-core groups contain the word multicore.
