プライマリ DNS サーバーとセカンダリ DNS サーバーの間でゾーンを転送するための bash スクリプトを作成しました。プライマリからゾーン リストをダウンロードし、新しいゾーンをチェックしてから、それらのゾーン ファイルをダウンロードして、ゾーン ディレクトリとバインド用の .local ファイルに挿入します。
私が抱えている問題は、ゾーン ファイルが存在しない場合、この構成が既に存在するかどうかに関係なく、スクリプトが詳細を .local に入力することです。
誰かが既に存在するゾーンを区別し、単にゾーン ファイルをダウンロードするのを手伝ってくれますか? 以下にスクリプトを貼り付けました。スクリプトの動作について質問がある場合は、お気軽にお問い合わせください。(誰かがコードをラップしてください。私が試したどのブラウザでも正しく動作しません!)
#!/bin/sh
NAMED="/etc/bind/named.conf.local"
TMPNAMED="/tmp/zns-441245.temp"
TMPZONEFILE="/tmp/zones.txt"
TMP="/tmp/zns-732.temp"
ZONELOCATION="/var/cache/bind"
IGNORE=`cat ignore.txt`
logger DNS Update script running...
echo -n "Checking for new named.conf... "
wget -q http://91.121.75.205:10801/named/named.conf -O $TMPNAMED
if [ -e $TMPNAMED ]
then
echo "done."
else
echo "no new data!"
exit
fi
echo -n "Generating zone names... "
grep "^zone" $TMPNAMED | cut -d " " -f "2" | cut -d "\"" -f 2 > $TMPZONEFILE
sed '1,5d' $TMPZONEFILE > $TMP
mv $TMP $TMPZONEFILE
echo "done. ("$TMPZONEFILE")"
echo "Generating zone info... "
grep -vf ignore.txt $TMPZONEFILE | while read ZONE; do
echo -n "Checking for $ZONELOCATION/$ZONE.db "
if [ -e $ZONELOCATION/$ZONE.db ]
then
echo "[ exists ]"
else
export updates="yes"
echo "[ doesn't exist ]"
echo "New zone available ($ZONE)... "
echo "zone \"$ZONE\" {
type slave;
file \"$ZONELOCATION/$ZONE.db\";
masters { 91.121.75.205; };
allow-notify { 91.121.75.205; };
};" >> $NAMED
fi
done
echo "Updating Bind configuration... "
/etc/init.d/bind9 restart
rm $TMPZONEFILE
rm $TMPNAMED