mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
bug 10804: add default dns provider
This commit is contained in:
parent
8de59166a4
commit
797836723d
@ -24,13 +24,15 @@
|
|||||||
# $ip : the associated ip address
|
# $ip : the associated ip address
|
||||||
# $host : the hostname
|
# $host : the hostname
|
||||||
# $4 : default router
|
# $4 : default router
|
||||||
# $5 : comma separated static routes
|
# $5 : nameserver on default nic
|
||||||
|
# $6 : comma separated static routes
|
||||||
|
|
||||||
mac=$1
|
mac=$1
|
||||||
ip=$2
|
ip=$2
|
||||||
host=$3
|
host=$3
|
||||||
dflt=$4
|
dflt=$4
|
||||||
routes=$5
|
dns=$5
|
||||||
|
routes=$6
|
||||||
|
|
||||||
DHCP_HOSTS=/etc/dhcphosts.txt
|
DHCP_HOSTS=/etc/dhcphosts.txt
|
||||||
DHCP_OPTS=/etc/dhcpopts.txt
|
DHCP_OPTS=/etc/dhcpopts.txt
|
||||||
@ -99,6 +101,7 @@ echo "$ip $host" >> $HOSTS
|
|||||||
|
|
||||||
if [ "$dflt" != "" ]
|
if [ "$dflt" != "" ]
|
||||||
then
|
then
|
||||||
|
logger -t cloud "$0: setting default router to $dflt"
|
||||||
#make sure dnsmasq looks into options file
|
#make sure dnsmasq looks into options file
|
||||||
sed -i /dhcp-optsfile/d /etc/dnsmasq.conf
|
sed -i /dhcp-optsfile/d /etc/dnsmasq.conf
|
||||||
echo "dhcp-optsfile=$DHCP_OPTS" >> /etc/dnsmasq.conf
|
echo "dhcp-optsfile=$DHCP_OPTS" >> /etc/dnsmasq.conf
|
||||||
@ -106,6 +109,11 @@ then
|
|||||||
tag=$(echo $ip | tr '.' '_')
|
tag=$(echo $ip | tr '.' '_')
|
||||||
sed -i /$tag/d $DHCP_OPTS
|
sed -i /$tag/d $DHCP_OPTS
|
||||||
echo "$tag,3,$dflt" >> $DHCP_OPTS
|
echo "$tag,3,$dflt" >> $DHCP_OPTS
|
||||||
|
if [ "$dns" != "" ]
|
||||||
|
then
|
||||||
|
logger -t cloud "$0: setting dns server to $dns"
|
||||||
|
echo "$tag,6,$dns" >> $DHCP_OPTS
|
||||||
|
fi
|
||||||
[ "$routes" != "" ] && echo "$tag,121,$routes" >> $DHCP_OPTS
|
[ "$routes" != "" ] && echo "$tag,121,$routes" >> $DHCP_OPTS
|
||||||
#delete entry we just put in because we need a tag
|
#delete entry we just put in because we need a tag
|
||||||
sed -i /$mac/d $DHCP_HOSTS
|
sed -i /$mac/d $DHCP_HOSTS
|
||||||
|
|||||||
101
patches/systemvm/debian/config/root/edithosts.sh.orig
Executable file
101
patches/systemvm/debian/config/root/edithosts.sh.orig
Executable file
@ -0,0 +1,101 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#
|
||||||
|
# Copyright (C) 2010 Cloud.com, Inc. All rights reserved.
|
||||||
|
#
|
||||||
|
# This software is licensed under the GNU General Public License v3 or later.
|
||||||
|
#
|
||||||
|
# It is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or any later version.
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
#
|
||||||
|
|
||||||
|
# edithosts.sh -- edit the dhcphosts file on the routing domain
|
||||||
|
# $1 : the mac address
|
||||||
|
# $2 : the associated ip address
|
||||||
|
# $3 : the hostname
|
||||||
|
|
||||||
|
source /root/func.sh
|
||||||
|
|
||||||
|
lock="biglock"
|
||||||
|
locked=$(getLockFile $lock)
|
||||||
|
if [ "$locked" != "1" ]
|
||||||
|
then
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
lock_rr="rrouter"
|
||||||
|
locked_rr=$(getLockFile $lock_rr)
|
||||||
|
if [ "$locked_rr" != "1" ]
|
||||||
|
then
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
grep "redundant_router=1" /var/cache/cloud/cmdline > /dev/null
|
||||||
|
no_redundant=$?
|
||||||
|
|
||||||
|
wait_for_dnsmasq () {
|
||||||
|
local _pid=$(pidof dnsmasq)
|
||||||
|
for i in 0 1 2 3 4 5 6 7 8 9 10
|
||||||
|
do
|
||||||
|
sleep 1
|
||||||
|
_pid=$(pidof dnsmasq)
|
||||||
|
[ "$_pid" != "" ] && break;
|
||||||
|
done
|
||||||
|
[ "$_pid" != "" ] && return 0;
|
||||||
|
logger -t cloud "edithosts: timed out waiting for dnsmasq to start"
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
|
||||||
|
logger -t cloud "edithosts: update $1 $2 $3 to hosts"
|
||||||
|
|
||||||
|
[ ! -f /etc/dhcphosts.txt ] && touch /etc/dhcphosts.txt
|
||||||
|
[ ! -f /var/lib/misc/dnsmasq.leases ] && touch /var/lib/misc/dnsmasq.leases
|
||||||
|
|
||||||
|
#delete any previous entries from the dhcp hosts file
|
||||||
|
sed -i /$1/d /etc/dhcphosts.txt
|
||||||
|
sed -i /$2,/d /etc/dhcphosts.txt
|
||||||
|
sed -i /$3,/d /etc/dhcphosts.txt
|
||||||
|
|
||||||
|
#put in the new entry
|
||||||
|
echo "$1,$2,$3,infinite" >>/etc/dhcphosts.txt
|
||||||
|
|
||||||
|
#delete leases to supplied mac and ip addresses
|
||||||
|
sed -i /$1/d /var/lib/misc/dnsmasq.leases
|
||||||
|
sed -i /"$2 "/d /var/lib/misc/dnsmasq.leases
|
||||||
|
sed -i /"$3 "/d /var/lib/misc/dnsmasq.leases
|
||||||
|
|
||||||
|
#put in the new entry
|
||||||
|
echo "0 $1 $2 $3 *" >> /var/lib/misc/dnsmasq.leases
|
||||||
|
|
||||||
|
#edit hosts file as well
|
||||||
|
sed -i /"$2 "/d /etc/hosts
|
||||||
|
sed -i /"$3"/d /etc/hosts
|
||||||
|
echo "$2 $3" >> /etc/hosts
|
||||||
|
|
||||||
|
# make dnsmasq re-read files
|
||||||
|
pid=$(pidof dnsmasq)
|
||||||
|
if [ "$pid" != "" ]
|
||||||
|
then
|
||||||
|
service dnsmasq restart
|
||||||
|
else
|
||||||
|
if [ $no_redundant -eq 1 ]
|
||||||
|
then
|
||||||
|
wait_for_dnsmasq
|
||||||
|
else
|
||||||
|
logger -t cloud "edithosts: skip wait dnsmasq due to redundant virtual router"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
ret=$?
|
||||||
|
releaseLockFile $lock_rr $locked_rr
|
||||||
|
unlock_exit $ret $lock $locked
|
||||||
@ -38,8 +38,9 @@ add_dhcp_entry() {
|
|||||||
local ip=$3
|
local ip=$3
|
||||||
local vm=$4
|
local vm=$4
|
||||||
local dfltrt=$5
|
local dfltrt=$5
|
||||||
local staticrt=$6
|
local ns=$6
|
||||||
ssh -p 3922 -o StrictHostKeyChecking=no -i $cert root@$domr "/root/edithosts.sh $mac $ip $vm $dfltrt $staticrt" >/dev/null
|
local staticrt=$7
|
||||||
|
ssh -p 3922 -o StrictHostKeyChecking=no -i $cert root@$domr "/root/edithosts.sh $mac $ip $vm $dfltrt $ns $staticrt" >/dev/null
|
||||||
return $?
|
return $?
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -49,8 +50,9 @@ vmIp=
|
|||||||
vmName=
|
vmName=
|
||||||
staticrt=
|
staticrt=
|
||||||
dfltrt=
|
dfltrt=
|
||||||
|
dns=
|
||||||
|
|
||||||
while getopts 'r:m:v:n:d:s:' OPTION
|
while getopts 'r:m:v:n:d:s:N:' OPTION
|
||||||
do
|
do
|
||||||
case $OPTION in
|
case $OPTION in
|
||||||
r) domrIp="$OPTARG"
|
r) domrIp="$OPTARG"
|
||||||
@ -65,12 +67,14 @@ do
|
|||||||
;;
|
;;
|
||||||
d) dfltrt="$OPTARG"
|
d) dfltrt="$OPTARG"
|
||||||
;;
|
;;
|
||||||
|
N) dns="$OPTARG"
|
||||||
|
;;
|
||||||
?) usage
|
?) usage
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
add_dhcp_entry $domrIp $vmMac $vmIp $vmName $dfltrt $staticrt
|
add_dhcp_entry $domrIp $vmMac $vmIp $vmName $dfltrt $dns $staticrt
|
||||||
|
|
||||||
exit $?
|
exit $?
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user