>[оверквотинг удален]
>>>> Одинарные кавычки. Переменные внутри них не раскрываются.
>>> К сожалению изменение на sed -i "/vpn 0 IN A ${SERV}/d" /tmp/db.local
>>> ничего не изменила, файл db.local на всякий случай
>>> vpn 0 IN A 10.10.12.15
>>> vpn 0 IN A 10.10.12.16
>>> vpn 0 IN A 10.10.12.17
>>> vpn 0 IN A 10.10.12.18
>> BSD ?
>> sed -i "" "/vpn 0 IN A ${SERV}/d" /tmp/db.local
> Да BSD ! Спасибо так сработало.Подскажите пожалуйста, у меня немного изменилась задача. Я пингую сервера по одним IP, а в зону нужно добавить по привязке к другому, т.е. есть текстовой файл в котором есть эти привязки в виде :
172.20.2.1 10.100.100.1
172.20.2.2 10.100.100.2
172.20.2.3 10.100.100.3
Как переменную $i сопоставить с ip в первой колонке, а в зону внести данные из второй колонки ? Подозреваю что нужно использовать awk или grep, но вот саму конструкцию не представляю.
#!/bin/sh
FILE="file_ip.txt"
for i in 172.20.2.1 172.20.2.2 172.20.2.3;
do
if eval "ping -c 2 $i"> /dev/null;
then
file="/tmp/ping/file`echo $i`"
if [ -e $file ];
then
rm "/tmp/ping/file`echo $i`"
echo "vpn 0 IN A $i" >>/etc/bind/db.local # Вот здесь должна быть другая переменная
echo "$(date +%d-%m-%y\ %H:%M:%S) resumption of rotation $i " >>/var/log/bad_ip.log
fi
echo "11" > /dev/null
else
file="/tmp/ping/file`echo $i`"
if [ -e $file ];
then
echo "11" > /dev/null
else
sed -i "/vpn 0 IN A $i/d" /etc/bind/db.local
touch "/tmp/ping/file`echo $i`"
echo "$(date +%d-%m-%y\ %H:%M:%S) detected BAD IP $i, delete of zone " >>/var/log/bad_ip.log
fi
fi
done
rndc reload