mirror of
https://github.com/xcat2/xcat-core.git
synced 2025-10-24 07:55:27 +00:00
git-svn-id: https://svn.code.sf.net/p/xcat/code/xcat-core/trunk@10946 8638fb3e-16cb-4fca-ae20-7b5d299a9bcd
241 lines
7.0 KiB
Bash
Executable File
241 lines
7.0 KiB
Bash
Executable File
#!/bin/bash
|
|
#written in bash for fewest prerequisites
|
|
function get_def_interface {
|
|
#gethostbyname on `hostname` would be helpful, but since we
|
|
#are in bash, the best alternative is to use ping to get at it
|
|
#don't want to grep in /etc/hosts or presume DNS
|
|
#we are, however, presuming ipv4 for the moment
|
|
retval=$(ping -c 1 `hostname`|head -n 1|cut -d\( -f 2|cut -d\) -f 1)
|
|
if [ -z "$retval" -o "127.0.0.1" = "$retval" ]; then #ok, that didn't pan out, now we grab the first address that looks sane
|
|
retval=`ifconfig|grep inet" " |grep -v addr:127.0.0.1|grep -v 'addr:169.254'|head -n 1|cut -d: -f 2|cut -d' ' -f 1`
|
|
fi
|
|
if [ -z "$retval" ]; then
|
|
echo "ERROR: Unable to reasonably guess the 'default' interface" >&2
|
|
exit 1
|
|
fi
|
|
iface=`ifconfig|grep -v inet6|egrep '(Link|inet)'|grep -B1 'addr:'$retval |head -n 1|awk '{print $1}'`
|
|
if [ -z "$iface" ]; then
|
|
echo "ERROR: Unable to reasonably guess the default interface" >&2
|
|
exit 1
|
|
fi
|
|
if brctl show | grep ^$iface >& /dev/null; then #
|
|
OIFS=$IFS
|
|
IFS=$'\n'
|
|
INMATCH=0
|
|
for brline in $(brctl show); do
|
|
IFS=$OIFS
|
|
if [ $(expr match "$brline" $iface) == $(expr length $iface) ]; then
|
|
INMATCH=1
|
|
elif [ $(expr match "$brline" " ") != 1 ]; then
|
|
INMATCH=0
|
|
fi
|
|
if [ "$INMATCH" == 1 ]; then
|
|
if ! ethtool -i `echo $brline|awk '{print $NF}'`|grep "driver: tun" >& /dev/null; then
|
|
iface=`echo $brline|awk '{print $NF}'`
|
|
echo "$iface"
|
|
IFS=$OFIS
|
|
return
|
|
fi
|
|
fi
|
|
done
|
|
IFS=$OFIS
|
|
else
|
|
echo "$iface"
|
|
fi
|
|
}
|
|
if [ "storageprereq" = "$1" ]; then
|
|
MOUNTURI="$2"
|
|
DIRNAME=`echo $MOUNTURI|sed -e 's!nfs://!nfs_!'`
|
|
MOUNTPATH=`echo $DIRNAME|sed -e 's!nfs_!!'|sed -e 's!/!:/!'`
|
|
if mount|grep $MOUNTPATH > /dev/null; then
|
|
exit 0;
|
|
fi
|
|
mkdir -p /var/lib/xcat/vmnt/$DIRNAME
|
|
mount $MOUNTPATH /var/lib/xcat/vmnt/$DIRNAME
|
|
elif [ "bridgeprereq" = "$1" ]; then
|
|
NETDESC="$2"
|
|
# get the port for installation
|
|
if [ -n "$INSTALLNIC" ]; then
|
|
if [[ "$INSTALLNIC" = mac ]] || [[ "$INSTALLNIC" = MAC ]]; then
|
|
INSPORT=`ifconfig -a|grep -v inet6| grep -i 'HWaddr '$MACADDRESS|head -n 1|awk '{print $1}'`
|
|
else
|
|
INSPORT=$INSTALLNIC
|
|
fi
|
|
fi
|
|
|
|
if [ -z "$NETDESC" ]; then
|
|
if [ -n "$INSTALLNIC" ]; then
|
|
NETDESC=$INSPORT:default
|
|
else
|
|
echo "Incorrect usage"
|
|
exit 1
|
|
fi
|
|
fi
|
|
if echo "$NETDESC"|grep ':'> /dev/null; then
|
|
PORTS=`echo "$NETDESC"|cut -d: -f 1`
|
|
BNAME=`echo "$NETDESC"|cut -d: -f 2`
|
|
else
|
|
if [ -n "$INSTALLNIC" ]; then
|
|
PORTS=$INSPORT
|
|
fi
|
|
BNAME=$NETDESC
|
|
fi
|
|
if brctl showstp "$BNAME" > /dev/null; then
|
|
echo "$BNAME"
|
|
exit 0
|
|
fi
|
|
#Still here, that means we must build a bridge
|
|
if [ -z "$PORTS" ]; then #No ports specified, default to whatever looks up
|
|
PORTS=$(get_def_interface)
|
|
fi
|
|
if [ -z "$PORTS" ]; then #This has been checked many times before in theory, check again just in case
|
|
exit 1
|
|
fi
|
|
#For now, we only support bridge name==network name. This precludes
|
|
#the config of the same vlan number on multiple fabrics, but
|
|
#will cover that flexibility later if demanded (with 4k vlan ids,
|
|
#I think it would be unwise to reuse them as it could confuse anyway)
|
|
if echo "$PORTS"|grep '&'; then #we have bonding... fun to be had
|
|
#To be slack, going to just support one bond for now..
|
|
modprobe bonding miimon=100 mode=4
|
|
PORTS=`echo $PORTS |sed -e 's/&/ /'`
|
|
ip link set bond0 up
|
|
for p in $PORTS; do
|
|
#TODO: we are only going to manage the default
|
|
#route for now
|
|
saveroutes=`ip route | grep default| grep "dev $p"|grep via|sed -e 's/dev .*//'`
|
|
OIFS=$IFS
|
|
IFS=$'\n'
|
|
saveip=`ip addr show dev $p scope global|grep inet|grep -v dynamic|sed -e 's/inet.//'|sed -e 's/[^ ]*$//'`
|
|
if [ ! -z "$saveip" ]; then
|
|
for line in $saveip; do
|
|
ip addr add dev bond0 $line
|
|
done
|
|
fi
|
|
IFS=$OIFS
|
|
ifenslave bond0 $p
|
|
if [ ! -z "$saveroutes" ]; then
|
|
ip route add $saveroutes
|
|
fi
|
|
done
|
|
PORTS=bond0
|
|
fi
|
|
if echo "$BNAME"|egrep '^vl(an)?[0123456789]' > /dev/null; then
|
|
vlan="yes"
|
|
TNAME=${BNAME##vl}
|
|
TNAME=${TNAME##an}
|
|
#We have a vlan... more fun
|
|
modprobe 8021q
|
|
vconfig add $PORTS $TNAME
|
|
vconfig set_flag $PORTS.$TNAME 2 1 #Turn on GVRP where supported
|
|
ip link set $PORTS.$TNAME up
|
|
PORTS=$PORTS.$TNAME
|
|
fi
|
|
#Now, $PORTS is 'the' physical device to participate in a bridge
|
|
#TODO: we are only going to manage the default
|
|
#route for now
|
|
brctl addbr $BNAME
|
|
brctl setfd $BNAME 0 #fast forwarding
|
|
ip link set $BNAME up
|
|
saveroutes=`ip route | grep default| grep "dev $PORTS"|grep via|sed -e 's/dev .*//'`
|
|
OIFS=$IFS
|
|
IFS=$'\n'
|
|
saveip=`ip addr show dev $PORTS scope global|grep inet|grep -v dynamic|sed -e 's/inet.//'|sed -e 's/[^ ]*$//'`
|
|
#saveip=`ip addr show dev $PORTS scope global|grep inet|sed -e 's/inet.//'|sed -e 's/[^ ]*$//'`
|
|
if [ ! -z "$saveip" ]; then
|
|
for line in $saveip; do
|
|
IFS=$OIFS
|
|
ip addr add dev $BNAME $line
|
|
done
|
|
else
|
|
if [ ! -z "$3" ]; then
|
|
ip addr add dev $BNAME $3
|
|
fi
|
|
fi
|
|
brctl addif $BNAME $PORTS
|
|
if [ ! -z "$saveip" ]; then
|
|
OIFS=$IFS
|
|
IFS=$'\n'
|
|
for line in $saveip; do
|
|
IFS=$OIFS
|
|
ip addr del dev $PORTS $line
|
|
done
|
|
IFS=$OIFS
|
|
fi
|
|
IFS=$OIFS
|
|
if [ ! -z "$saveroutes" ]; then
|
|
ip route add $saveroutes
|
|
fi
|
|
|
|
#now save the settings into the config files so that they will be persistent among reboots
|
|
if [[ $OSVER = sles* ]] || [[ $OSVER = suse* ]] || [[ -f /etc/SuSE-release ]]; then
|
|
nwdir="/etc/sysconfig/network"
|
|
isSLES=1
|
|
else
|
|
nwdir="/etc/sysconfig/network-scripts"
|
|
fi
|
|
|
|
#write into the network configuration file
|
|
if [[ $isSLES -eq 1 ]]; then
|
|
cat >$nwdir/ifcfg-$PORTS <<EOF
|
|
DEVICE='$PORTS'
|
|
ONBOOT='yes'
|
|
BRIDGE='$BNAME'
|
|
EOF
|
|
mac=`ip addr show dev $PORTS scope global|grep link|sed -e 's/link\/ether//'|sed -e 's/brd.*$//'|sed -e 's/[ ]*//'`
|
|
if [ ! -z "$mac" ]; then
|
|
echo "HWADDR='$mac'" >> $nwdir/ifcfg-$PORTS
|
|
fi
|
|
if [ ! -z "$vlan" ]; then
|
|
echo "VLAN='yes'" >> $nwdir/ifcfg-$PORTS
|
|
fi
|
|
cat >$nwdir/ifcfg-$BNAME <<EOF
|
|
DEVICE='$BNAME'
|
|
TYPE='Bridge'
|
|
ONBOOT='yes'
|
|
PEERDNS='yes'
|
|
DELAY='0'
|
|
EOF
|
|
if [ ! -z "$3" ]; then
|
|
echo "IPADDR='$3'" >> $nwdir/ifcfg-$BNAME
|
|
if [ ! -z "$4" ]; then
|
|
echo "NETMASK='$4'" >> $nwdir/ifcfg-$BNAME
|
|
fi
|
|
else
|
|
echo "BOOTPROTO=dhcp" >> $nwdir/ifcfg-$BNAME
|
|
fi
|
|
else
|
|
cat >$nwdir/ifcfg-$PORTS <<EOF
|
|
DEVICE=$PORTS
|
|
ONBOOT=yes
|
|
BRIDGE=$BNAME
|
|
EOF
|
|
mac=`ip addr show dev $PORTS scope global|grep link|sed -e 's/link\/ether//'|sed -e 's/brd.*$//'|sed -e 's/[ ]*//'`
|
|
if [ ! -z "$mac" ]; then
|
|
echo "HWADDR=$mac" >> $nwdir/ifcfg-$PORTS
|
|
fi
|
|
if [ ! -z "$vlan" ]; then
|
|
echo "VLAN=yes" >> $nwdir/ifcfg-$PORTS
|
|
fi
|
|
cat >$nwdir/ifcfg-$BNAME <<EOF
|
|
DEVICE=$BNAME
|
|
TYPE=Bridge
|
|
ONBOOT=yes
|
|
PEERDNS=yes
|
|
DELAY=0
|
|
EOF
|
|
if [ ! -z "$3" ]; then
|
|
echo "IPADDR=$3" >> $nwdir/ifcfg-$BNAME
|
|
if [ ! -z "$4" ]; then
|
|
echo "NETMASK=$4" >> $nwdir/ifcfg-$BNAME
|
|
fi
|
|
else
|
|
echo "BOOTPROTO=dhcp" >> $nwdir/ifcfg-$BNAME
|
|
fi
|
|
fi
|
|
|
|
ifup $BNAME
|
|
fi #END bridge config.
|
|
|
|
|