EC2でWordPressをホストするときにやっておくと便利な設定: バックアップ編
この記事は、AWS Community Builders Advent Calendar 2023の13日目の記事です。WordPressのサーバーをEC2で運用している場合、壊れてもすぐに復旧できるようにバックアップを自動で作成する仕組みが重要です。Amazon Data Lifecycle Managerを使用すると、ノーコードでEC2のバックアップ管理が可能です。Data Lifecycle Managerでは、バックアップのスケジュールやモニタリングも設定できます。また、Amazon EventBridgeと連携させることで、バックアップ作成状況を通知できます。EC2を使いながらも、サーバーレス的な運用保守が可能です。
目次
この記事は、「AWS Community Builders Advent Calendar 2023」13日目の記事です。
Community Buildersとしては、[Serverless]のカテゴリで現在活動しています。しかしそれはそれとして、個人のAWSアカウントでは、長年WordPressを動かすためのEC2が1台稼働しています。記事を移行させる手間や、新しいエディタや管理画面を覚えることを考えると、なんだかんだ多少手間がかかってもWordPressを使い続けるのが性に合っているなぁ・・・ということで、たまにはサーバーフルな話もしたいと思います。
WordPressを気軽に壊せるようにしておきたい
もともとインフラレイヤの人間ではないため、サーバーの設定どころかPHPやMySQLなどのデバッグもなかなか苦手意識を持っていたりします。そんな人間がEC2上にホストするアプリを一人で管理するためには、「壊れてもどうにかなる」と思える環境づくりが重要です。
ということでこのWordPressを動かしているサーバーでは、「壊してもすぐ復旧できるように、バックアップを自動で作成する仕組み」を用意しています。これはEBSのストレージ丸ごとバックアップを作成し、壊れたらそれごと復旧させることですぐにリカバリーできることをめざしています。また、同時にバックアップが貯まることでコストが増えることも避けたいため、数日でバックアップを消すようにもしています。
・・・このような仕組みを組むのはなかなか大変そうに聞こえませんか?実はとあるサービスを利用することで、ノーコードでバックアップの管理が可能です。
Amazon Data Lifecycle Manager
ノーコードでEC2(厳密にはEBS)のバックアップを管理するには、[Amazon Data Lifecycle Manager] を使います。
![](https://wp-kyoto.cdn.rabify.me/wp-content/uploads/2023/12/7baf09b23b75f575c34ff330c3e9d9ce-20231209223145.png?&d=1140)
EC2の管理画面で、Data Lifecycle Managerまたはライフサイクルなどのメニューを探して開きましょう。
![](https://wp-kyoto.cdn.rabify.me/wp-content/uploads/2023/12/66ec0a4aeab01661edd780fdbbc583a1-20231209223326.png?&d=1140)
ライフサイクルポリシーを作ることで、バックアップ管理を設定できます。ポシリータイプはインスタンス・ボリュームごとにカスタマイズしたサイクルを指定できる「カスタムポリシー」と、リージョン内の全てのボリューム・インスタンスのバックアップが作れる「デフォルトポシリー」の2つがあります。
![](https://wp-kyoto.cdn.rabify.me/wp-content/uploads/2023/12/bf3b1bfcfcaa8b3b6088e929d4a1972c-20231209223331.png?&d=1140)
カスタムポリシーの場合、対象にするボリュームやインスタンスをタグやインスタンスIDなどの値で指定できます。
![](https://wp-kyoto.cdn.rabify.me/wp-content/uploads/2023/12/c7134e8e759ee347753f34831daa82a6-20231209223340.png?&d=1140)
除外するボリュームの設定なども行えます。また、ポリシーのステータスを[有効化されていません]にすることもできますので、作成だけしてみることなどもできそうです。
![](https://wp-kyoto.cdn.rabify.me/wp-content/uploads/2023/12/f1f248727330ce39d5ccb61678e69245-20231209223344.png?&d=1140)
バックアップする対象を決めた後は、どのようなスケジュールでバックアップを処理するかを決めます。「毎日X時から、2つまで保持する」みたいな細かい設定までできる様子です。
![](https://wp-kyoto.cdn.rabify.me/wp-content/uploads/2023/12/af6fab451128dbc544a204160e3e7c78-20231209223349.png?&d=1140)
他にもクロスリージョン・クロスアカウントの共有や、バックアップ作成前後に動かすスクリプトなども指定できます。
![](https://wp-kyoto.cdn.rabify.me/wp-content/uploads/2023/12/857324add28817b4c57dba51238169fb-20231209223419.png?&d=1140)
クロスアカウントなどは、EC2を利用してサービスを提供している場合などにも使えるのではないかと思います。
現在利用しているライフサイクル設定は、「毎日実行・3件保持」
このサイトのバックアップ設定は、こんな感じです。
![](https://wp-kyoto.cdn.rabify.me/wp-content/uploads/2023/12/e50a70ed63ada0bcabfe6abe16eedc3e-20231209223530.png?&d=1140)
Headlessに利用しているため、2・3日前までロールバックできればなんとかなるだろうとの判断で、保持数を絞った運用にしています。
チームで運用している場合などでは、もう少し長めに持った方がいいケースもあるかもしれません。
バックアップ作成状況のモニタリングもできる
Data Lifecycle Managerにはモニタリング機能もついています。「どれくらいのリソースが対象」で、「スナップショット作成に成功しているか」がみることができます。
![](https://wp-kyoto.cdn.rabify.me/wp-content/uploads/2023/12/224034c1859c55db89a63bbb9025bdde-20231209223511.png?&d=1140)
Amazon EventBridgeで通知もノーコード
Data Lifecycle ManagerはAmazon EventBridgeとも連携できます。
![](https://wp-kyoto.cdn.rabify.me/wp-content/uploads/2023/12/2b53687f68dc9bd935c86ba2f6e8e278-20231209223632.png?&d=1140)
aws.dlm
から始まるイベントパターンを指定することで、スナップショット作成などに関するイベントを受け取れます。
![](https://wp-kyoto.cdn.rabify.me/wp-content/uploads/2023/12/545e7a820c1dffc830ef417a508cf068-20231209223641.png?&d=1140)
Amazon SNSに連携させて、AWS Chatbot経由でSlackに投げると、バックアップ作成状況をSlackでみれます。
![](https://wp-kyoto.cdn.rabify.me/wp-content/uploads/2023/12/4e2cb17ad795fdadd487c9384b78083f-20231209223748.png?&d=1140)
おわりに
サーバーレスの対極にあるEC2ですが、ノーコードな仕組みを組み合わせることで、運用保守をサーバーレス的に行うことは可能です。
Systems Managerなども組み合わせて、より管理レスなサーバー運用を目指したいと思っていますので、また新しい試みをした際にはご紹介します。