インフラ環境試験の自動化を考える
お疲れ様です。伊藤です。
本日は少々趣向を変えてインフラ試験について書きたいと思います。ただ、こちらの内容は私自身も現在調査中で、あいまいな内容が多いので間違いや勘違いがあるかもしれませんのでご了承ください。
という前置きをして、タイトルの件です。
インフラ試験の自動化と言ってもあまり大層なことはできないですね。基本的には
- 設定値確認
- OSの設定
- 機能のインストール
- 機能の設定
- 動作確認
- 正常系動作
- 異常系動作
と大まかにこんな感じだと思います。まあそのほかに総合試験的なものもあるかと思います。
その中で自動化できるのは設定値確認、特に設定した値を確認する箇所ぐらいかなと。
まあその中でもどこを自動化するか、というのは重要なところかと思います。結局単発の試験や試行錯誤が必要な試験は手動でやった方が早いです。動作確認などでサーバをフェールオーバさせて待機系が正常終了するか、なんてのは自動化がとても難しいと思うので準備しているうちに期間が過ぎてしまいます。
効率化のために自動化をしようとしているので、自動化して手間が増えた、というのではちょっと本末転倒ですね。
というわけで自動化に向いているのは設定した値が正しくなっているかを確認する項目ぐらいになるかな、というところです。特に一度構築した後に何度も手を入れるような設定をやっていると、毎回設計書通りに値が設定されているかを確認する必要があるので、そこを自動化しておくとよろしいかと。
で、テスト系のツールです。私も今どのツールにしようか検討しているところですので、その情報を記載しておきます。
- Serverspec
王道だと思います。rubyベースのテストツールです。ほとんどのテスト系ツールはserverspecを基にしたり、参考にしているように感じます(主観
ただし、rubyを導入するのに敷居が高い場合がありますので、すべての場合に適用できるわけではありません。ansibleに合わせてpythonベースのものがあればいいのですが。。基本的には設定値の確認など中からのテストが得意。
- Infrataster
インフラテスターではありません。インフラテイスター。クックパッドの人が作ったからそうなったっぽい。こちらもRubyベースですが、動作確認系が得意です。Httpで外からアクセスしたり、外部からDBにアクセスしたり、ping飛ばしたり。今回はちょっと用途が違うので外します。
- TestInfta
ちょっと名前がダサいですが、こちらはServerspecのpython版の位置づけのツールのようです。そう!こういうのを探してた!でも、、、日本語のドキュメントがすごく少ないです。とりあえずこちらを導入して使えるものかどうか調べていきます。
というわけで当ブログではTestInfraを採用して動作検証していきます。どこまでできるかわかりませんが期待せずにお待ちください。
以上です、お疲れ様でした。