IAM Roleの設定
/etc/awslogs/awscli.conf
に秘密情報を保持して連携する方法もあるのですが、アンチパターンなので、ロールを設定してEC2に割り当てます。
IAMからロールを作成
ロールの作成ボタンをクリックします。
data:image/s3,"s3://crabby-images/57d1c/57d1c470d4af5c7cb3ccc090544048f0529f2d52" alt="1.png"
EC2にロールを割り当てたいのでEC2を選択します。
data:image/s3,"s3://crabby-images/d49b4/d49b4008c27a5a145e8f898658c34f9ba59dfa09" alt="2.png"
ここでは、ポリシーとしてCloudWatchLogFullAccess
をロールに設定します。
data:image/s3,"s3://crabby-images/318e2/318e2b784c98dbcd022626ec242ed3bebd66d966" alt="3.png"
適当なロール名を設定してロールを作成します。
data:image/s3,"s3://crabby-images/e6ade/e6ade99e24bbb21bcfef3ca1f03b2ee1d91cdd6a" alt="4.png"
EC2作成時にロールを割り当てる
上記でEC2に作成したロールを割り当てます。
data:image/s3,"s3://crabby-images/11984/1198470bf294f0fbcc5130ce85f27e461fc1eb79" alt="5.png"
エージェントのインストール
先ほど作成したEC2インスタンスでエージェントをインストールします。
sudo yum install -y awslogs
設定ファイルの編集
設定ファイルを編集します。
/etc/awslogs/awscli.conf
[plugins]
cwlogs = cwlogs
[default]
region = ap-northeast-1
/etc/awslogs/awslogs.conf
参考) CloudWatch Logs エージェントのリファレンス
[general]
state_file = /var/lib/awslogs/agent-state
[/var/log/messages]
datetime_format = %b %d %H:%M:%S
file = /var/log/messages
buffer_duration = 5000
log_stream_name = {instance_id}
initial_position = start_of_file
log_group_name = /var/log/messages
# 追加したセクション
[/logs/MyProject]
datetime_format = %Y-%m-%d %H:%M:%S # ログの日時フォーマット
file = /logs/MyProject/app.log # ログファイルパス
buffer_duration = 5000
encoding = utf_8
log_stream_name = {instance_id}
initial_position = start_of_file # 初期ポジション
log_group_name = /logs/MyProject
[項目の説明]
- datetime_format: ログの日時フォーマット
- file: ログファイルのパス
- buffer_duration: ログの送信間隔
- log_group_name: CloudWatch Logのロググループ名
- log_stream_name: ロググループのストリーム名
- encoding: エンコーディング
エージェントの起動
エージェントを起動します。
sudo systemctl start awslogsd
sudo systemctl enable awslogsd
ログの連携確認
手頃なログがなかったので、CLIでログを出力してみます。
# CloudWatchにログを連携できるか確認する
date '+%Y-%m-%d %H:%M:%S Message from EC2' >> /logs/MyProject/app.log
date '+%Y-%m-%d %H:%M:%S Message from EC2' >> /logs/MyProject/app.log
date '+%Y-%m-%d %H:%M:%S Message from EC2' >> /logs/MyProject/app.log
date '+%Y-%m-%d %H:%M:%S Message from EC2' >> /logs/MyProject/app.log
date '+%Y-%m-%d %H:%M:%S Message from EC2' >> /logs/MyProject/app.log
CloudWatchコンソールからログが確認できればOKです。
data:image/s3,"s3://crabby-images/0d0db/0d0dbe86dd14f1c9082ae2dc56b77650d8b13351" alt="6.png"
data:image/s3,"s3://crabby-images/225b9/225b98640996172e95f6dec4d734a89c84177006" alt="7.png"
data:image/s3,"s3://crabby-images/2d8c9/2d8c9d1dd45bce86451b0ded92bb10df28e9d858" alt="8.png"