はじめに
どうも、こんにちは。今回は、AWSで定期実行処理を行う方法を紹介したいと思います。今回の記事には、超絶初歩的なことしか書いてないです。AWS玄人の方からすれば鼻で笑われても仕方ないような内容になりますが、最後までお付き合いいただけると幸いです。
AWSのアカウントをまだ作っていないよ~、って人は公式のドキュメントを参考に作ってみてください。
lambdaの設定
具体的にどのような処理を実装するのかというと、AWSのlambdaとCloudWatchを使って、一分毎に「hello world」と出力するプログラムを作ってみようと思います。
まずは、lambdaで「hello world」と出力する処理を作ります。AWSのマネジメントコンソールに移動したらlambdaを選択してください。トップページにlambdaが表示されていない方は、検索バーでlambdaと検索すると出てくると思います。
lambdaを選択してこのような画面が表示されたら、関数の作成をクリックしてください。
関数名は適当にhelloWorldとかにして、関数を記述する際に使用する言語を指定しましょう。今回はPythonを使用するのでPythonを選択します。バージョンは別になんでも大丈夫です。設定が完了したら関数の作成をクリックします。
ここまでできたら、コードを以下のように書き換えて、デプロイをクリックします。コードを変更したら、毎回デプロイするのを忘れずに。
本来は使用するファイルをzip形式でアップロードしたり、S3から読み込んだりするのがスタンダードらしいのですが、今回は簡単な処理なので直接プログラムを書き込んでしまいましょう。
それでは一度、テストをしてみましょう。テストをクリックして、イベント名に適当な名前を付けて作成をクリックします。このような画面が表示されればしっかりと実行できています。「hello wolrd」という文字列が出力されていますね。これでlambdaの作成は完了になります。
CloudWatchの設定
次に、CloudWatchの設定をしていきましょう。ページ上部にある検索バーに「CloudWatch」と入力して、CloudWatchにアクセスします。このようなページに移動出来たら大丈夫です。そしたら、ページの左側にあるイベントの「ルール」をクリックします。
そうすると、Amazon EventBridgeへのアクセスページが表示されますので、クリックしてください。
それでは、ルールを作成をクリックして定期実行処理の設定をしましょう。
適当なルール名をつけます。ルールの説明に関しては任意なので、書かなくても大丈夫です。
パターンを定義から、イベントの実行タイミングを設定します。今回は一分毎に「hello world」と出力したいので、スケージュールをチャックして、「固定速度ごと」という項目を1分にします。
ターゲットを選択から、先ほど作成したlambdaのhelloWorld関数を選択したら、ページ下部の作成をクリックします。ここまで出来たらルールの作成は完了です。
作成が完了するとAmazon EventBridgeのトップページに移動すると思います。作成したルールがEnabledになっていたらOKです。それでは、正常に実行されているのか確認していきます。検索バーにCloudWatchと入力して、CloudWatchのトップページに移動します。
ログループを確認できる画面に移ると思うので、そこから先ほど作成したlambda関数のログを確認していきます。先ほど作成したlambdaの関数名のログをクリックします。
ちゃんとログが作成されていますね。正常に動作しているか、ログの中身を確認してみましょう。
「hello world」と一分毎に出力されていますね。これでAWSを用いた簡単な定期実行処理を実装できました。
定期実行処理の停止(超重要)
ここからが超重要です。というか、ここをすっ飛ばすと後から、大量の請求が来るという恐ろしい事態に発展してしまうかもしれません...
今回作成した「1分毎にhello worldと出力する処理」は、あくまでもAWSでの定期実行処理の実装方法を確認するためのものです。そのため、確認が済んだら定期実行処理を停止してしまいましょう。検索バーに「EventBridge」と入力して、Amazon EventBridgeのトップページに移動します。このような画面が表示されると思うので、画面左側の「ルール」をクリックします。
先ほど作成した「test-hello-world」というルールをチェックして、「無効にする」をチェックして、ルールを無効化してください。これでルールを無効化できました。心配な方はもう一度、CloudWatchのログループから定期実行処理が停止されていることを確認してみましょう。
1日に1回とか、1時間に1回ぐらいの定期実行処理なら、わざわざルールを無効化する必要もないかもしれませんが、1分に1回実行は流石に怖いですよね...
最後に
以上がAWSを使った簡単な定期実行処理の実装方法です。どうでしたか?できる限りかみ砕いて説明したつもりなので、少しでもお役に立てたら幸いです。次回は、ニュースデータを一定の間隔で取得して、Amazon S3というストレージに格納していくシステムを実装していきたいと思います。lambdaとS3の接続に関しては、私自身本当に躓きました。私が躓いたポイントも含めてできる限り分かりやすく、説明していきたいと思います。
それではまた。