Hubot を使って CloudFront の Distribution 一覧・Invalidation 作成を行う hubot-cloudfront
Hubot を使って Amazon CloudFront の Distribution (配信) 一覧取得 と、Invalidation (無効化) 作成 を行うスクリプトを公開しました。
npm install --save hubot-cloudfront
Distribution (配信) 一覧取得
Distribution の ID、ドメイン、ステータス、コメント、進行中の Invalidation バッチの件数 (あれば) が取得できます。
me > hubot cloudfront list distributions
hubot > - 0: E2SO336F6AMQ08 --------------------
domain: d1ood20dgya2ll.cloudfront.net
status: InProgress
comment: Distribution for static.liap.us
- 1: E29XRZTZN1VOAV --------------------
domain: d290rn73xc4vfg.cloudfront.net
status: Deployed
invalidation batches in progress: 10
ショートカットにも対応しています
me > hubot cf ls dist
Invalidation (無効化) 作成
me > hubot cloudfront invalidate E2SO336F6AMQ08 /index.html /atom.xml /javascripts/*.js
hubot > Invalidation I14NJQR76VVQAT on distribution E29XRZTZN1VOAV created.
It might take 10 to 15 minutes until all files are invalidated.
Distribution の指定は ID のほか、Distribution 一覧の連番インデックス (ID の前の 0 起点の整数) でも指定できます。
me > hubot cloudfront invalidate 0 /index.html /atom.xml /javascripts/*.js
ショートカット
me > hubot cf inv 0 /index.html /atom.xml /javascripts/*.js
Invalidation の進捗を1分ごとに確認して、完了していたら教えてくれます。
hubot > @ngs Invalidation I14NJQR76VVQAT on distribution E29XRZTZN1VOAV completed.
Invalidation (無効化) 一覧
Distribution ID またはインデックスを指定して Invalidation の一覧を取得します。
me > hubot cloudfront list invalidates E2SO336F6AMQ08
hubot > I14NJQR76VVQAT - InProgress
I3MAZE9OBGZ05X - Completed
ショートカット
me > hubot cf ls inv 0
なぜ作ろうと思ったのか
我ながら、普通に便利なスクリプトなのですが、もともとは CI プロセスの中から行おうとして、ライブラリが期待通りに動かなかったので、このスクリプトを作成しました。
KAIZEN platform で開発している GUI エディターは、以前発表したとおり、Middleman で開発しています。
資材は Amazon S3 にホスティングされており、一部のファイルは Amazon CloudFront で CDN 配信されています。
Origin となる Amazon S3 バケットへのアップロードは middleman-sync を使用しており、その次に middleman-cloudfront を使って Invalidation を作成しようとしました。
# config.rb
activate :cloudfront do |cf|
cf.access_key_id = ENV['AWS_ACCESS_KEY_ID']
cf.secret_access_key = ENV['AWS_SECRET_ACCESS_KEY']
cf.distribution_id = ENV['CLOUDFRONT_DISTRIBUTION_ID']
cf.filter = %r{editor\-inner\.js$}i
cf.after_build = false
end
この設定で、普通に filter
にマッチする /javascripts/editor-inner.js
の Invalidation を作成してほしいのですが、なぜか /editor-inner.js
の Invalidation を作成します。
また、Invalidation の進捗は、AWS のダッシュボードに入って、都度確認 & 配信ファイルの中に含まれる Git のコミットハッシュをリロードして確認しており、とても面倒でした。
そこで HipChat にメッセージを飛ばす、簡単なシェルスクリプト を作成し、以下の様に circle.yml
に設定しました。
deployment:
default:
branch: /deployment\/.*/
commands:
- bundle exec middleman sync
- >
./script/hipchat-notify.sh \
$HIPCHAT_DEPLOYEMNT_ROOM_ID \
"hubot cloudfront invalidate $CLOUDFRONT_DISTRIBUTION_ID /javascripts/editor-inner.js"
この設定で、シェルスクリプトにより発言された命令をハンドリングし、Hubot が Invalidation を作成する様になりました。