私はまだbashでのスクリプト作成は非常に新しいので、基本的なことだと思ったことをいくつか試してみました。Ubuntu 14.04を実行しているサーバーから更新するDDNSを実行したい。
dnsimpleからいくつかのコードを借りて、これは私がこれまで持っているものです:
#!/bin/bash
LOGIN="email"
TOKEN="token"
DOMAIN_ID="domain"
RECORD_ID="record"
IP=`curl -s http://icanhazip.com/`
OUTPUT=`
curl -H "Accept: application/json" \
-H "Content-Type: application/json" \
-H "X-DNSimple-Domain-Token: $TOKEN" \
-X "PUT" \
-i "https://api.dnsimple.com/v1/domains/$DOMAIN_ID/records/$RECORD_ID" \
-d "{\"record\":{\"content\":\"$IP\"}}"`
if ! echo "$OUTPUT" | grep -q "(Status:\s200)"; then
echo "match"
$(echo "$OUTPUT" | grep -oP '(?<="message":")(.[^"]*)' >> /home/ddns/ddns.log)
$(echo "$OUTPUT"| grep -P '(Status:\s[0-9]{3}\s)' >> /home/ddns/ddns.log)
fi
これは5分ごとに実行されるという考え方で、cronjobを使用して作業しています。次に、カールの出力をチェックして、ステータスが「200」またはその他であるかどうかを確認します。それが他の何かである場合、出力をファイルに保存したいと思います。
私が働けないのはif
声明です。私の理解では、コマンドの-q
on grep
はif
ステートメントの終了コードを提供します。しかし、私はそれを機能させることができないようです。どこがおかしいの?
少し修正しました。私は変数を
—
CircularRecursion
DNSimple-Domain-Token
必要としないを使用していLOGIN
ます。
私があなただったら、cronから5分ごとではなく、インターネットネットワークインターフェイスが起動したときにのみ実行します。または、少なくともどこか(おそらく
—
cas
/var/tmp/icanhazip
)のファイルに「$ IP」をキャッシュし、最後の実行以降に変更されていない場合は、exit 0
他の操作を行う前に。IPアドレスが変更された場合にのみ、5分ごとにDDNSエントリを更新する必要はありません。
良いアイデア-私はそれを追加する作業をします。
—
CircularRecursion
if
チェックを削除し、常にログファイルにエコーする場合、スクリプトは機能しますか? dnssimpleのショー$LOGIN
の前に$TOKEN
、しかし、あなたはそれを逃しています。たぶんそれは物事を失敗させているのでしょうか?