Révision 51
trunk/shell/configuration-stop-compute-nodes (revision 51) | ||
---|---|---|
1 |
#! /bin/bash -x |
|
2 |
# |
|
3 |
# ST - 2012-07-03 |
|
4 |
# |
|
5 |
# Start the compute nodes for a configuration. |
|
6 |
# |
|
7 |
# Get the directory of the script. |
|
8 |
SCRIPT_PATH=`dirname $0` |
|
9 |
# Get the script name. |
|
10 |
SCRIPT_NAME=`basename $0` |
|
11 |
# Source the common configuration variables. |
|
12 |
. $SCRIPT_PATH/c-i-a-b.common |
|
13 |
# |
|
14 |
# |
|
15 |
# Get the configurations |
|
16 |
# |
|
17 |
CONFIGURATIONS=`ls $SCRIPT_PATH/$CONST_CONFIGURATIONS_DIR` |
|
18 |
CONFIGURATIONS_STRING="{" |
|
19 |
echo $CONFIGURATIONS |
|
20 |
for i in $CONFIGURATIONS ; do |
|
21 |
CONFIGURATIONS_STRING="$CONFIGURATIONS_STRING$i|" |
|
22 |
done |
|
23 |
# |
|
24 |
# Check command line arguments. |
|
25 |
# |
|
26 |
if [ "x$1" == "x" ] |
|
27 |
then |
|
28 |
echo |
|
29 |
echo "Missing parameter. Aborting!" |
|
30 |
echo |
|
31 |
echo "Usage: $SCRIPT_NAME configuration" |
|
32 |
echo |
|
33 |
echo -e " configuration: one of $CONFIGURATIONS_STRING\b}" |
|
34 |
exit 1 |
|
35 |
fi |
|
36 |
# |
|
37 |
# Does the configuration exist? |
|
38 |
# |
|
39 |
CONFIGURATION_FOUND="" |
|
40 |
CONFIGURATION=`echo $1 | tr [:upper:] [:lower:]` |
|
41 |
for i in $CONFIGURATIONS ; do |
|
42 |
CURRENT_CONFIGURATION=`echo $i | tr [:upper:] [:lower:]` |
|
43 |
if [ $CONFIGURATION == $CURRENT_CONFIGURATION ] ; then |
|
44 |
CONFIGURATION_FOUND=$i |
|
45 |
fi |
|
46 |
done |
|
47 |
if [ -z $CONFIGURATION_FOUND ] ; then |
|
48 |
echo |
|
49 |
echo |
|
50 |
echo "The configuration \"$1\" does not exist". |
|
51 |
echo -e "The configuration must be one of $CONFIGURATIONS_STRING\b}." |
|
52 |
echo "Aborting!" |
|
53 |
echo |
|
54 |
echo |
|
55 |
exit 1 |
|
56 |
else |
|
57 |
CONFIGURATION=$CONFIGURATION_FOUND |
|
58 |
fi |
|
59 |
# |
|
60 |
# Source the specific variables for the configuration. |
|
61 |
# |
|
62 |
. $SCRIPT_PATH/$CONST_CONFIGURATIONS_DIR/$CONFIGURATION/c-i-a-b.config.common |
|
63 |
# |
|
64 |
# Start the compute-nodes. |
|
65 |
# |
|
66 |
COMPUTE_NODE_INDEX=1 |
|
67 |
while [ $COMPUTE_NODE_INDEX -le $COMPUTE_NODE_MAX_INDEX ] ; do |
|
68 |
# |
|
69 |
# Convert the number into a three caracters strings. |
|
70 |
# |
|
71 |
COMPUTE_NODE_INDEX_STRING=$COMPUTE_NODE_INDEX |
|
72 |
while [ ${#COMPUTE_NODE_INDEX_STRING} -lt 3 ] ; do |
|
73 |
COMPUTE_NODE_INDEX_STRING="0$COMPUTE_NODE_INDEX_STRING" |
|
74 |
done |
|
75 |
# |
|
76 |
# Compute the host name. |
|
77 |
# |
|
78 |
CURRENT_HOST_NAME=${COMPUTE_NODE_NAME_PREFIX}${COMPUTE_NODE_INDEX_STRING} |
|
79 |
# |
|
80 |
# Check if the corresponding VM is already running. |
|
81 |
# |
|
82 |
IS_RUNNING=`xm list | grep $CURRENT_HOST_NAME` |
|
83 |
if [ -n "$IS_RUNNING" ] ; then |
|
84 |
echo |
|
85 |
echo The \"$CURRENT_HOST_NAME\" domU already exists. Aborting! |
|
86 |
echo |
|
87 |
fi |
|
88 |
# |
|
89 |
# Get the CPU data. |
|
90 |
# |
|
91 |
COMPUTE_NODE_CPUS=`sed -n ${NODE_NUMBER},${NODE_NUMBER}p $SCRIPT_PATH/$CONST_CONFIGURATIONS_DIR/$CONFIGURATION/$COMPUTE_NODE_CPUS_FILE` |
|
92 |
COMPUTE_NODE_VCPUS_NUM=0 |
|
93 |
COMPUTE_NODE_CPUS_LIST="" |
|
94 |
for i in $COMPUTE_NODE_CPUS ; do |
|
95 |
if [ -z $COMPUTE_NODE_CPUS_LIST ] ; then |
|
96 |
COMPUTE_NODE_CPUS_LIST=$i |
|
97 |
else |
|
98 |
COMPUTE_NODE_CPUS_LIST="$COMPUTE_NODE_CPUS_LIST,$i" |
|
99 |
fi |
|
100 |
COMPUTE_NODE_VCPUS_NUM=$((COMPUTE_NODE_VCPUS_NUM + 1)) |
|
101 |
done |
|
102 |
# |
|
103 |
# Check that the configuration file exists. |
|
104 |
# |
|
105 |
if [ ! -f $CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg ] ; then |
|
106 |
echo |
|
107 |
echo |
|
108 |
echo "No configuration file for \"$CURRENT_HOST_NAME\." |
|
109 |
echo "Aborting!" |
|
110 |
echo |
|
111 |
echo |
|
112 |
xm list |
|
113 |
exit 1 |
|
114 |
fi |
|
115 |
# |
|
116 |
# Start the virtual machine |
|
117 |
# |
|
118 |
xm create $CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
119 |
# |
|
120 |
# Wait until the virtual machine has started |
|
121 |
# |
|
122 |
IS_RUNNING="" |
|
123 |
while [ -z "$IS_RUNNING" ] |
|
124 |
do |
|
125 |
IS_RUNNING=`xm list | grep $CURRENT_HOST_NAME` |
|
126 |
sleep 1 |
|
127 |
done # End while |
|
128 |
# |
|
129 |
# Pin the VCPUs to "real" CPUs. |
|
130 |
# |
|
131 |
VCPU_INDEX=0 |
|
132 |
for i in $COMPUTE_NODE_CPUS_LIST ; do |
|
133 |
xm vcpu-pin $CURRENT_HOST_NAME $VCPU_INDEX $i |
|
134 |
VCPU_INDEX=$((VCPU_INDEX + 1)) |
|
135 |
done # End for i |
|
136 |
COMPUTE_NODE_INDEX=$((COMPUTE_NODE_INDEX + 1)) |
|
137 |
done # End main loop. |
|
138 |
# |
|
139 |
exit 0 |
|
0 | 140 |
trunk/shell/configuration-start-compute-nodes (revision 51) | ||
---|---|---|
1 |
#! /bin/bash -x |
|
2 |
# |
|
3 |
# ST - 2012-07-03 |
|
4 |
# |
|
5 |
# Start the compute nodes for a configuration. |
|
6 |
# |
|
7 |
# Get the directory of the script. |
|
8 |
SCRIPT_PATH=`dirname $0` |
|
9 |
# Get the script name. |
|
10 |
SCRIPT_NAME=`basename $0` |
|
11 |
# Source the common configuration variables. |
|
12 |
. $SCRIPT_PATH/c-i-a-b.common |
|
13 |
# |
|
14 |
# |
|
15 |
# Get the configurations |
|
16 |
# |
|
17 |
CONFIGURATIONS=`ls $SCRIPT_PATH/$CONST_CONFIGURATIONS_DIR` |
|
18 |
CONFIGURATIONS_STRING="{" |
|
19 |
echo $CONFIGURATIONS |
|
20 |
for i in $CONFIGURATIONS ; do |
|
21 |
CONFIGURATIONS_STRING="$CONFIGURATIONS_STRING$i|" |
|
22 |
done |
|
23 |
# |
|
24 |
# Check command line arguments. |
|
25 |
# |
|
26 |
if [ "x$1" == "x" ] |
|
27 |
then |
|
28 |
echo |
|
29 |
echo "Missing parameter. Aborting!" |
|
30 |
echo |
|
31 |
echo "Usage: $SCRIPT_NAME configuration" |
|
32 |
echo |
|
33 |
echo -e " configuration: one of $CONFIGURATIONS_STRING\b}" |
|
34 |
exit 1 |
|
35 |
fi |
|
36 |
# |
|
37 |
# Does the configuration exist? |
|
38 |
# |
|
39 |
CONFIGURATION_FOUND="" |
|
40 |
CONFIGURATION=`echo $1 | tr [:upper:] [:lower:]` |
|
41 |
for i in $CONFIGURATIONS ; do |
|
42 |
CURRENT_CONFIGURATION=`echo $i | tr [:upper:] [:lower:]` |
|
43 |
if [ $CONFIGURATION == $CURRENT_CONFIGURATION ] ; then |
|
44 |
CONFIGURATION_FOUND=$i |
|
45 |
fi |
|
46 |
done |
|
47 |
if [ -z $CONFIGURATION_FOUND ] ; then |
|
48 |
echo |
|
49 |
echo |
|
50 |
echo "The configuration \"$1\" does not exist". |
|
51 |
echo -e "The configuration must be one of $CONFIGURATIONS_STRING\b}." |
|
52 |
echo "Aborting!" |
|
53 |
echo |
|
54 |
echo |
|
55 |
exit 1 |
|
56 |
else |
|
57 |
CONFIGURATION=$CONFIGURATION_FOUND |
|
58 |
fi |
|
59 |
# |
|
60 |
# Source the specific variables for the configuration. |
|
61 |
# |
|
62 |
. $SCRIPT_PATH/$CONST_CONFIGURATIONS_DIR/$CONFIGURATION/c-i-a-b.config.common |
|
63 |
# |
|
64 |
# Start the compute-nodes. |
|
65 |
# |
|
66 |
COMPUTE_NODE_INDEX=1 |
|
67 |
while [ $COMPUTE_NODE_INDEX -le $COMPUTE_NODE_MAX_INDEX ] ; do |
|
68 |
# |
|
69 |
# Convert the number into a three caracters strings. |
|
70 |
# |
|
71 |
COMPUTE_NODE_INDEX_STRING=$COMPUTE_NODE_INDEX |
|
72 |
while [ ${#COMPUTE_NODE_INDEX_STRING} -lt 3 ] ; do |
|
73 |
COMPUTE_NODE_INDEX_STRING="0$COMPUTE_NODE_INDEX_STRING" |
|
74 |
done |
|
75 |
# |
|
76 |
# Compute the host name. |
|
77 |
# |
|
78 |
CURRENT_HOST_NAME=${COMPUTE_NODE_NAME_PREFIX}${COMPUTE_NODE_INDEX_STRING} |
|
79 |
# |
|
80 |
# Check if the corresponding VM is already running. |
|
81 |
# |
|
82 |
IS_RUNNING=`xm list | grep $CURRENT_HOST_NAME` |
|
83 |
if [ -n "$IS_RUNNING" ] ; then |
|
84 |
echo |
|
85 |
echo The \"$CURRENT_HOST_NAME\" domU already exists. |
|
86 |
echo |
|
87 |
fi |
|
88 |
# |
|
89 |
# Get the CPU data. |
|
90 |
# |
|
91 |
COMPUTE_NODE_CPUS=`sed -n ${COMPUTE_NODE_INDEX},${COMPUTE_NODE_INDEX}p $SCRIPT_PATH/$CONST_CONFIGURATIONS_DIR/$CONFIGURATION/$COMPUTE_NODE_CPUS_FILE` |
|
92 |
COMPUTE_NODE_VCPUS_NUM=0 |
|
93 |
COMPUTE_NODE_CPUS_LIST="" |
|
94 |
for i in $COMPUTE_NODE_CPUS ; do |
|
95 |
if [ -z $COMPUTE_NODE_CPUS_LIST ] ; then |
|
96 |
COMPUTE_NODE_CPUS_LIST=$i |
|
97 |
else |
|
98 |
COMPUTE_NODE_CPUS_LIST="$COMPUTE_NODE_CPUS_LIST,$i" |
|
99 |
fi |
|
100 |
COMPUTE_NODE_VCPUS_NUM=$((COMPUTE_NODE_VCPUS_NUM + 1)) |
|
101 |
done |
|
102 |
# |
|
103 |
# Check that the configuration file exists. |
|
104 |
# |
|
105 |
if [ ! -f $CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg ] ; then |
|
106 |
echo |
|
107 |
echo |
|
108 |
echo "No configuration file for \"$CURRENT_HOST_NAME\." |
|
109 |
echo "Aborting!" |
|
110 |
echo |
|
111 |
echo |
|
112 |
xm list |
|
113 |
exit 1 |
|
114 |
fi |
|
115 |
# |
|
116 |
# Start the virtual machine |
|
117 |
# |
|
118 |
xm create $CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
119 |
# |
|
120 |
# Wait until the virtual machine has started |
|
121 |
# |
|
122 |
IS_RUNNING="" |
|
123 |
while [ -z "$IS_RUNNING" ] |
|
124 |
do |
|
125 |
IS_RUNNING=`xm list | grep $CURRENT_HOST_NAME` |
|
126 |
sleep 1 |
|
127 |
done # End while |
|
128 |
# |
|
129 |
# Pin the VCPUs to "real" CPUs. |
|
130 |
# |
|
131 |
VCPU_INDEX=0 |
|
132 |
for i in $COMPUTE_NODE_CPUS_LIST ; do |
|
133 |
xm vcpu-pin $CURRENT_HOST_NAME $VCPU_INDEX $i |
|
134 |
VCPU_INDEX=$((VCPU_INDEX + 1)) |
|
135 |
done # End for i |
|
136 |
COMPUTE_NODE_INDEX=$((COMPUTE_NODE_INDEX + 1)) |
|
137 |
done # End main loop. |
|
138 |
# |
|
139 |
exit 0 |
|
0 | 140 |
trunk/shell/configuration-delete-compute-nodes (revision 51) | ||
---|---|---|
1 |
#! /bin/bash -x |
|
2 |
# |
|
3 |
# ST - 2012-07-04 |
|
4 |
# |
|
5 |
# Delete the compute nodes for a configuration. |
|
6 |
# |
|
7 |
# Get the directory of the script. |
|
8 |
SCRIPT_PATH=`dirname $0` |
|
9 |
# Get the script name. |
|
10 |
SCRIPT_NAME=`basename $0` |
|
11 |
# Source the common configuration variables. |
|
12 |
. $SCRIPT_PATH/c-i-a-b.common |
|
13 |
# |
|
14 |
# Get the configurations |
|
15 |
# |
|
16 |
CONFIGURATIONS=`ls $SCRIPT_PATH/$CONST_CONFIGURATIONS_DIR` |
|
17 |
CONFIGURATIONS_STRING="{" |
|
18 |
echo $CONFIGURATIONS |
|
19 |
for i in $CONFIGURATIONS ; do |
|
20 |
CONFIGURATIONS_STRING="$CONFIGURATIONS_STRING$i|" |
|
21 |
done |
|
22 |
# |
|
23 |
# Check command line arguments. |
|
24 |
# |
|
25 |
if [ "x$1" == "x" ] |
|
26 |
then |
|
27 |
echo |
|
28 |
echo "Missing parameter. Aborting!" |
|
29 |
echo |
|
30 |
echo "Usage: $SCRIPT_NAME configuration" |
|
31 |
echo |
|
32 |
echo -e " configuration: one of $CONFIGURATIONS_STRING\b}" |
|
33 |
exit 1 |
|
34 |
fi |
|
35 |
# |
|
36 |
# Does the configuration exist? |
|
37 |
# |
|
38 |
CONFIGURATION_FOUND="" |
|
39 |
CONFIGURATION=`echo $1 | tr [:upper:] [:lower:]` |
|
40 |
for i in $CONFIGURATIONS ; do |
|
41 |
CURRENT_CONFIGURATION=`echo $i | tr [:upper:] [:lower:]` |
|
42 |
if [ $CONFIGURATION == $CURRENT_CONFIGURATION ] ; then |
|
43 |
CONFIGURATION_FOUND=$i |
|
44 |
fi |
|
45 |
done |
|
46 |
if [ -z $CONFIGURATION_FOUND ] ; then |
|
47 |
echo |
|
48 |
echo |
|
49 |
echo "The configuration \"$1\" does not exist". |
|
50 |
echo -e "The configuration must be one of $CONFIGURATIONS_STRING\b}." |
|
51 |
echo "Aborting!" |
|
52 |
echo |
|
53 |
echo |
|
54 |
exit 1 |
|
55 |
else |
|
56 |
CONFIGURATION=$CONFIGURATION_FOUND |
|
57 |
fi |
|
58 |
# |
|
59 |
# Source the specific variables for the configuration. |
|
60 |
# |
|
61 |
. $SCRIPT_PATH/$CONST_CONFIGURATIONS_DIR/$CONFIGURATION/c-i-a-b.config.common |
|
62 |
# |
|
63 |
# Delete the compute nodes. |
|
64 |
# |
|
65 |
COMPUTE_NODE_INDEX=1 |
|
66 |
while [ $COMPUTE_NODE_INDEX -le $COMPUTE_NODE_MAX_INDEX ] ; do |
|
67 |
# |
|
68 |
# Compute the host name. |
|
69 |
# |
|
70 |
# |
|
71 |
# Convert the number into a three caracters strings. |
|
72 |
# |
|
73 |
COMPUTE_NODE_INDEX_STRING=$COMPUTE_NODE_INDEX |
|
74 |
while [ ${#COMPUTE_NODE_INDEX_STRING} -lt 3 ] ; do |
|
75 |
COMPUTE_NODE_INDEX_STRING="0$COMPUTE_NODE_INDEX_STRING" |
|
76 |
done |
|
77 |
# |
|
78 |
# Compute the host name. |
|
79 |
# |
|
80 |
CURRENT_HOST_NAME=${COMPUTE_NODE_NAME_PREFIX}${COMPUTE_NODE_INDEX_STRING} |
|
81 |
# |
|
82 |
# If the compute node is running, stop it. |
|
83 |
# |
|
84 |
IS_RUNNING=`xm list | grep $CURRENT_HOST_NAME` |
|
85 |
if [ ! -z "$IS_RUNNING" ] ; then |
|
86 |
xm shutdown $CURRENT_HOST_NAME |
|
87 |
# |
|
88 |
# And wait until it has sopped. |
|
89 |
# |
|
90 |
IS_RUNNING="" |
|
91 |
while [ -z "$IS_RUNNING" ] ; do |
|
92 |
IS_RUNNING=`xm list | grep $CURRENT_HOST_NAME` |
|
93 |
sleep 1 |
|
94 |
done # End while |
|
95 |
fi # End compute node is running. |
|
96 |
# |
|
97 |
# If necessary, delete the VM system disk. |
|
98 |
# |
|
99 |
COMPUTE_NODE_SYSTEM_DISK_DEVICE="${COMPUTE_NODE_MODEL_SYSTEM_VOLUME_GROUP_DEVICE}/${CURRENT_HOST_NAME}-${CONST_SYSTEM_DISK_POSTFIX}-clone" |
|
100 |
if [ -e $COMPUTE_NODE_SYSTEM_DISK_DEVICE ] ; then |
|
101 |
lvremove -f $COMPUTE_NODE_SYSTEM_DISK_DEVICE |
|
102 |
if [ $? -ne 0 ] ; then |
|
103 |
ciab_abort_message "Could not remove system disk for $CURRENT_HOST_NAME" 1 |
|
104 |
fi |
|
105 |
fi |
|
106 |
# |
|
107 |
# If necessary, remove the swap volume for the compute node. |
|
108 |
# |
|
109 |
COMPUTE_NODE_SWAP_DISK_DEVICE="COMPUTE_NODE_SWAP_DISK_VOLUME_GROUP_DEVICE/${CURRENT_HOST_NAME}-${CONST_SWAP_DISK_POSTFIX}" |
|
110 |
if [ -e $COMPUTE_NODE_SWAP_DISK_DEVICE ] ; then |
|
111 |
lvremove -f $COMPUTE_NODE_SWAP_DISK_DEVICE |
|
112 |
if [ $? -ne 0 ] ; then |
|
113 |
ciab_abort_message "Could not remove swap disk for $CURRENT_HOST_NAME" 1 |
|
114 |
fi |
|
115 |
fi |
|
116 |
# |
|
117 |
# Remove the Xen configuration file. |
|
118 |
# |
|
119 |
CURRENT_PATH=/etc/xen |
|
120 |
rm -f $CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
121 |
# |
|
122 |
COMPUTE_NODE_INDEX=$((COMPUTE_NODE_INDEX + 1)) |
|
123 |
done |
|
124 |
exit 0 |
|
0 | 125 |
trunk/shell/configuration-create-compute-nodes (revision 51) | ||
---|---|---|
1 |
#! /bin/bash -x |
|
2 |
# |
|
3 |
# ST - 2012-07-04 |
|
4 |
# |
|
5 |
# Create the compute nodes for a configuration. |
|
6 |
# Prerequisite: the compute node model must have been created. |
|
7 |
# |
|
8 |
# Get the directory of the script. |
|
9 |
SCRIPT_PATH=`dirname $0` |
|
10 |
# Get the script name. |
|
11 |
SCRIPT_NAME=`basename $0` |
|
12 |
# Source the common configuration variables. |
|
13 |
. $SCRIPT_PATH/c-i-a-b.common |
|
14 |
# |
|
15 |
# Get the configurations |
|
16 |
# |
|
17 |
CONFIGURATIONS=`ls $SCRIPT_PATH/$CONST_CONFIGURATIONS_DIR` |
|
18 |
CONFIGURATIONS_STRING="{" |
|
19 |
echo $CONFIGURATIONS |
|
20 |
for i in $CONFIGURATIONS ; do |
|
21 |
CONFIGURATIONS_STRING="$CONFIGURATIONS_STRING$i|" |
|
22 |
done |
|
23 |
# |
|
24 |
# Check command line arguments. |
|
25 |
# |
|
26 |
if [ "x$1" == "x" ] |
|
27 |
then |
|
28 |
echo |
|
29 |
echo "Missing parameter. Aborting!" |
|
30 |
echo |
|
31 |
echo "Usage: $SCRIPT_NAME configuration" |
|
32 |
echo |
|
33 |
echo -e " configuration: one of $CONFIGURATIONS_STRING\b}" |
|
34 |
exit 1 |
|
35 |
fi |
|
36 |
# |
|
37 |
# Does the configuration exist? |
|
38 |
# |
|
39 |
CONFIGURATION_FOUND="" |
|
40 |
CONFIGURATION=`echo $1 | tr [:upper:] [:lower:]` |
|
41 |
for i in $CONFIGURATIONS ; do |
|
42 |
CURRENT_CONFIGURATION=`echo $i | tr [:upper:] [:lower:]` |
|
43 |
if [ $CONFIGURATION == $CURRENT_CONFIGURATION ] ; then |
|
44 |
CONFIGURATION_FOUND=$i |
|
45 |
fi |
|
46 |
done |
|
47 |
if [ -z $CONFIGURATION_FOUND ] ; then |
|
48 |
echo |
|
49 |
echo |
|
50 |
echo "The configuration \"$1\" does not exist". |
|
51 |
echo -e "The configuration must be one of $CONFIGURATIONS_STRING\b}." |
|
52 |
echo "Aborting!" |
|
53 |
echo |
|
54 |
echo |
|
55 |
exit 1 |
|
56 |
else |
|
57 |
CONFIGURATION=$CONFIGURATION_FOUND |
|
58 |
fi |
|
59 |
# |
|
60 |
# Source the specific variables for the configuration. |
|
61 |
# |
|
62 |
. $SCRIPT_PATH/$CONST_CONFIGURATIONS_DIR/$CONFIGURATION/c-i-a-b.config.common |
|
63 |
# |
|
64 |
# Create the compute nodes. |
|
65 |
# |
|
66 |
COMPUTE_NODE_INDEX=1 |
|
67 |
while [ $COMPUTE_NODE_INDEX -le $COMPUTE_NODE_MAX_INDEX ] ; do |
|
68 |
# |
|
69 |
# Compute the host name. |
|
70 |
# |
|
71 |
# |
|
72 |
# Convert the number into a three caracters strings. |
|
73 |
# |
|
74 |
COMPUTE_NODE_INDEX_STRING=$COMPUTE_NODE_INDEX |
|
75 |
while [ ${#COMPUTE_NODE_INDEX_STRING} -lt 3 ] ; do |
|
76 |
COMPUTE_NODE_INDEX_STRING="0$COMPUTE_NODE_INDEX_STRING" |
|
77 |
done |
|
78 |
# |
|
79 |
# Compute the host name. |
|
80 |
# |
|
81 |
CURRENT_HOST_NAME=${COMPUTE_NODE_NAME_PREFIX}${COMPUTE_NODE_INDEX_STRING} |
|
82 |
# |
|
83 |
# Get the compute node MAC address on the cluster. |
|
84 |
# |
|
85 |
CURRENT_PATH=/etc |
|
86 |
COMPUTE_NODE_CLUSTER_MAC_ADDRESS=\ |
|
87 |
`awk -F, -v INDEX=$COMPUTE_NODE_INDEX '{if (FNR==INDEX) {print $1}}' $SCRIPT_PATH/${CONST_TEMPLATES_DIR}$CURRENT_PATH/$CONST_DHCP_HOSTS_FILE_BASENAME` |
|
88 |
# |
|
89 |
# Create the VM system disk (a snapshot of the model disk). |
|
90 |
# |
|
91 |
COMPUTE_NODE_SYSTEM_DISK="${CURRENT_HOST_NAME}-${CONST_SYSTEM_DISK_POSTFIX}-clone" |
|
92 |
COMPUTE_NODE_LOGICAL_VOLUME="${COMPUTE_NODE_MODEL_SYSTEM_VOLUME_GROUP_DEVICE}/${COMPUTE_NODE_MODEL_CLUSTER_HOST_NAME}-$CONST_SYSTEM_DISK_POSTFIX" |
|
93 |
lvcreate -L$COMPUTE_NODE_SYSTEM_DISK_CLONE_SIZE -s \ |
|
94 |
-n $COMPUTE_NODE_SYSTEM_DISK \ |
|
95 |
$COMPUTE_NODE_LOGICAL_VOLUME > /dev/null 2>&1 |
|
96 |
if [ $? -ne 0 ] ; then |
|
97 |
ciab_abort_message "Could not create system disk for $CURRENT_HOST_NAME" 1 |
|
98 |
fi |
|
99 |
# |
|
100 |
# DO NOT CREATE A FILE SYSTEM ON THE SNAPSHOT! |
|
101 |
# |
|
102 |
# If necessary, create the swap volume for the compute node. |
|
103 |
if [ $COMPUTE_NODE_SWAP_DISK_SIZE != $CONST_NULL_DISK_SIZE ] ; then |
|
104 |
COMPUTE_NODE_SWAP_DISK="${CURRENT_HOST_NAME}-${CONST_SWAP_DISK_POSTFIX}" |
|
105 |
lvcreate -L $COMPUTE_NODE_SWAP_DISK_SIZE \ |
|
106 |
-n $COMPUTE_NODE_SWAP_DISK \ |
|
107 |
$COMPUTE_NODE_SWAP_DISK_VOLUME_GROUP |
|
108 |
if [ $? -ne 0 ] ; then |
|
109 |
ciab_abort_message "Could not create swap disk for $CURRENT_HOST_NAME" 1 |
|
110 |
fi |
|
111 |
mkswap $COMPUTE_NODE_SWAP_DISK_VOLUME_GROUP_DEVICE/$COMPUTE_NODE_SWAP_DISK |
|
112 |
if [ $? -ne 0 ] ; then |
|
113 |
ciab_abort_message "Could not initialize swap disk for $CURRENT_HOST_NAME" 1 |
|
114 |
fi |
|
115 |
fi |
|
116 |
# |
|
117 |
# Get the CPU data. |
|
118 |
# |
|
119 |
COMPUTE_NODE_CPUS=`sed -n ${COMPUTE_NODE_INDEX},${COMPUTE_NODE_INDEX}p $SCRIPT_PATH/$CONST_CONFIGURATIONS_DIR/$CONFIGURATION/$COMPUTE_NODE_CPUS_FILE` |
|
120 |
COMPUTE_NODE_VCPUS_NUM=0 |
|
121 |
COMPUTE_NODE_CPUS_LIST="" |
|
122 |
for i in $COMPUTE_NODE_CPUS ; do |
|
123 |
if [ -z $COMPUTE_NODE_CPUS_LIST ] ; then |
|
124 |
COMPUTE_NODE_CPUS_LIST=$i |
|
125 |
else |
|
126 |
COMPUTE_NODE_CPUS_LIST="$COMPUTE_NODE_CPUS_LIST,$i" |
|
127 |
fi |
|
128 |
COMPUTE_NODE_VCPUS_NUM=$((COMPUTE_NODE_VCPUS_NUM + 1)) |
|
129 |
done # for i |
|
130 |
# |
|
131 |
# Create the Xen configuration file from a template |
|
132 |
# |
|
133 |
CURRENT_PATH=/etc/xen |
|
134 |
cp ${CONST_TEMPLATES_DIR}$CURRENT_PATH/$CONST_COMPUTE_NODE_XEN_TEMPLATE_NAME \ |
|
135 |
$CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
136 |
rpl -q Template Configuration $CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
137 |
rpl -q __COMPUTE_NODE_KERNEL__ "$COMPUTE_NODE_KERNEL" \ |
|
138 |
$CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
139 |
rpl -q __COMPUTE_NODE_RAMDISK__ "$COMPUTE_NODE_RAMDISK" \ |
|
140 |
$CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
141 |
rpl -q __COMPUTE_NODE_VCPUS_NUM__ "$COMPUTE_NODE_VCPUS_NUM" \ |
|
142 |
$CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
143 |
rpl -q __COMPUTE_NODE_CPUS__ "$COMPUTE_NODE_CPUS_LIST" \ |
|
144 |
$CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
145 |
# Memory |
|
146 |
rpl -q __COMPUTE_NODE_MEMORY__ "$COMPUTE_NODE_MEMORY" \ |
|
147 |
$CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
148 |
# Root device |
|
149 |
rpl -q __XEN_SYSTEM_DISK_ROOT_DEVICE_STANZA__ "$CONST_XEN_SYSTEM_DISK_ROOT_DEVICE_STANZA" \ |
|
150 |
$CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
151 |
# |
|
152 |
# System disk stuff |
|
153 |
# |
|
154 |
COMPUTE_NODE_SYSTEM_DISK_STANZA="'phy:${COMPUTE_NODE_MODEL_SYSTEM_VOLUME_GROUP_DEVICE}/${COMPUTE_NODE_SYSTEM_DISK},$COMPUTE_NODE_SYSTEM_VIRTUAL_VOLUME,w'" |
|
155 |
rpl -q __COMPUTE_NODE_SYSTEM_DISK_STANZA__ "$COMPUTE_NODE_SYSTEM_DISK_STANZA" \ |
|
156 |
$CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
157 |
# |
|
158 |
# No home disk stuff: home is network mounted. |
|
159 |
# |
|
160 |
# Swap disk stuff. |
|
161 |
if [ "x$COMPUTE_NODE_SWAP_DISK_SIZE" != "x$CONST_NULL_DISK_SIZE" ] ; then |
|
162 |
COMPUTE_NODE_SWAP_DISK_STANZA="'phy:${COMPUTE_NODE_SWAP_DISK_VOLUME_GROUP_DEVICE}/${COMPUTE_NODE_SWAP_DISK},$COMPUTE_NODE_SWAP_VIRTUAL_VOLUME,w'" |
|
163 |
rpl -q __COMPUTE_NODE_SWAP_DISK_STANZA__ "$COMPUTE_NODE_SWAP_DISK_STANZA" \ |
|
164 |
$CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
165 |
# Comment out the noswap stanza. |
|
166 |
rpl -q __COMPUTE_NODE_NOSWAP__ "#$CLUSTER_NOSWAP" \ |
|
167 |
$CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
168 |
else # No swap |
|
169 |
rpl -q __COMPUTE_NODE_SWAP_DISK_STANZA__ "" \ |
|
170 |
$CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
171 |
rpl -q __COMPUTE_NODE_NOSWAP__ "$CLUSTER_NOSWAP" \ |
|
172 |
$CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
173 |
fi |
|
174 |
# |
|
175 |
rpl -q __COMPUTE_NODE_HOST_NAME__ "$CURRENT_HOST_NAME" \ |
|
176 |
$CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
177 |
# Vif stuff. |
|
178 |
COMPUTE_NODE_CLUSTER_STATIC_IP=\ |
|
179 |
`awk -F, -v INDEX=$NODE_NUMBER '{if (FNR==INDEX) {print $3}}' $SCRIPT_PATH/${CONST_TEMPLATES_DIR}/etc/$CONST_DHCP_HOSTS_FILE_BASENAME` |
|
180 |
VIF_STANZA=$CONST_XEN_VIF_STANZA_PREFIX |
|
181 |
INTERNAL_MAC="${CONST_XEN_MAC_PREFIX}${COMPUTE_NODE_CLUSTER_MAC_ADDRESS}" |
|
182 |
INTERNAL_BRIDGE="${CONST_XEN_BRIDGE_PREFIX}${CLUSTER_BRIDGE_NAME}" |
|
183 |
INTERNAL_IP="${CONST_XEN_IP_PREFIX}${COMPUTE_NODE_CLUSTER_STATIC_IP}" |
|
184 |
if [ $CLUSTER_INTERNAL_ADDRESSES_BY_DHCP -eq 1 ] ; then |
|
185 |
rpl -q __XEN_DHCP_STANZA__ "$CONST_XEN_DHCP_STANZA" \ |
|
186 |
$CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
187 |
VIF_STANZA=${VIF_STANZA}${INTERNAL_IP}","${INTERNAL_MAC}","${INTERNAL_BRIDGE}${CONST_XEN_VIF_STANZA_POSTFIX} |
|
188 |
else |
|
189 |
# Comment out the DHCP_STANZA. |
|
190 |
rpl -q __XEN_DHCP_STANZA__ "#$CONST_XEN_DHCP_STANZA" \ |
|
191 |
$CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
192 |
VIF_STANZA=${VIF_STANZA}${INTERNAL_IP}","${INTERNAL_MAC},${INTERNAL_BRIDGE}${CONST_XEN_VIF_STANZA_POSTFIX} |
|
193 |
fi |
|
194 |
# In any case, write the VIF_STANZA |
|
195 |
rpl -q __VIF_STANZA__ "$VIF_STANZA" \ |
|
196 |
$CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
197 |
# Console stuff as extra parameter |
|
198 |
rpl -q __EXTRA_STANZA__ "$CONST_XEN_EXTRA_STANZA" \ |
|
199 |
$CONST_XEN_CONFIG_DIR/$CURRENT_HOST_NAME.cfg |
|
200 |
# End creation of Xen configuration file. |
|
201 |
# |
|
202 |
# Complete installation |
|
203 |
# |
|
204 |
# Mount the file system to append/modify configuration files |
|
205 |
# |
|
206 |
if [ ! -d $COMPUTE_NODE_FILE_SYSTEM_MOUNT_POINT ] ; then |
|
207 |
mkdir $COMPUTE_NODE_FILE_SYSTEM_MOUNT_POINT |
|
208 |
fi |
|
209 |
mount $COMPUTE_NODE_MODEL_SYSTEM_VOLUME_GROUP_DEVICE/$COMPUTE_NODE_SYSTEM_DISK \ |
|
210 |
$COMPUTE_NODE_FILE_SYSTEM_MOUNT_POINT |
|
211 |
if [ $? -ne 0 ] ; then |
|
212 |
echo |
|
213 |
echo "Could not mount the compute node file system. Aborting!" |
|
214 |
echo |
|
215 |
exit 1 |
|
216 |
fi |
|
217 |
# |
|
218 |
# Generate or configure the specific files from templates |
|
219 |
# |
|
220 |
# Create the /etc directory, if necessary |
|
221 |
if [ ! -d $COMPUTE_NODE_MODEL_FILE_SYSTEM_MOUNT_POINT/etc ] ; then |
|
222 |
mkdir $COMPUTE_NODE_MODEL_FILE_SYSTEM_MOUNT_POINT/etc |
|
223 |
fi |
|
224 |
# /etc/network/interfaces |
|
225 |
# The first interface is DHCP configured. |
|
226 |
# No '/' between $COMPUTE_NODE_FILE_SYSTEM_MOUNT_POINT and $CURRENT_PATH |
|
227 |
CURRENT_PATH=/etc/network |
|
228 |
if [ ! -d ${COMPUTE_NODE_FILE_SYSTEM_MOUNT_POINT}${CURRENT_PATH} ] ; then |
|
229 |
mkdir ${COMPUTE_NODE_FILE_SYSTEM_MOUNT_POINT}${CURRENT_PATH} |
|
230 |
fi |
|
231 |
cp ${CONST_TEMPLATES_DIR}$CURRENT_PATH/$COMPUTE_NODE_INTERFACES_TEMPLATE \ |
|
232 |
$COMPUTE_NODE_FILE_SYSTEM_MOUNT_POINT$CURRENT_PATH/interfaces |
|
233 |
# Static address on the cluster interface. |
|
234 |
# The DHCP case should be delt with. It involves a template overhaul. |
|
235 |
rpl -q __STATIC_ADDRESS__ "$COMPUTE_NODE_CLUSTER_STATIC_IP" \ |
|
236 |
${COMPUTE_NODE_FILE_SYSTEM_MOUNT_POINT}${CURRENT_PATH}/interfaces |
|
237 |
rpl -q __STATIC_NETMASK__ "$CLUSTER_STATIC_NETMASK" \ |
|
238 |
${COMPUTE_NODE_FILE_SYSTEM_MOUNT_POINT}${CURRENT_PATH}/interfaces |
|
239 |
|
|
240 |
# /etc/hostname |
|
241 |
CURRENT_PATH=/etc |
|
242 |
echo $CURRENT_HOST_NAME > "${COMPUTE_NODE_FILE_SYSTEM_MOUNT_POINT}${CURRENT_PATH}/hostname" |
|
243 |
# |
|
244 |
# /etc/hosts. We use the clone. |
|
245 |
# |
|
246 |
# /etc/resolv.conf. We use the clone. |
|
247 |
# |
|
248 |
# /etc/fstab. We use the clone. |
|
249 |
# |
|
250 |
# /etc/inittab stuff. We use the clone. |
|
251 |
# |
|
252 |
# Umount the compute node model system disk |
|
253 |
# |
|
254 |
umount $COMPUTE_NODE_FILE_SYSTEM_MOUNT_POINT |
|
255 |
# |
|
256 |
COMPUTE_NODE_INDEX=$((COMPUTE_NODE_INDEX + 1)) |
|
257 |
done |
|
258 |
exit 0 |
|
0 | 259 |
Formats disponibles : Unified diff