本記事の目的
AWSのセキュリティを強化するための主要なサービスであるIAM(Identity and Access Management)には、多くのエンティティと概念が存在します。これらのエンティティの中でも、特に重要な「ロール」と「ポリシー」について、詳細に解説していくことが本記事の目的です。
前回、IAMエンティティの基本についての記事を公開しました。その中でユーザーやグループなどIAMの基本的なエンティティや、それらがどのように連携して機能するのかについて触れました。IAMの奥深い部分をより良く理解するためには、ロールとポリシーの知識がとても役立ちます。今回はこの2つのトピックを詳しく解説していきたいと思います。
前回の記事の振り返り
前回の記事では、IAMの基本的なエンティティ、すなわちユーザー、グループ、ロールについて概要を紹介しました。ユーザーはAWSリソースへのアクセスを持つエンティティ、グループは複数のユーザーをまとめるためのエンティティ、ロールは一時的なアクセス権を付与するためのエンティティとして紹介しました。
前回の内容を未読の方や、再度確認したい方は、こちらのリンクから詳細な記事をご覧いただけます。
https://envader.plus/article/246
IAMロールの深掘り
IAMロールとは?
IAMロールは、特定のAWSサービスやユーザーが一時的にAWSリソースにアクセスするための中継的な役割を果たします。IAMロールはアクセス許可を持ち、それを一時的に他のエンティティに"貸し出す"ことができます。直接アクセスキーを持たないエンティティでも、ロールを介して特定のリソースにアクセスすることが可能となります。
代表的な使用例
EC2インスタンス
EC2インスタンスがS3バケットや他のAWSリソースにアクセスする際、直接アクセスキーを持つことなく、IAMロールをアタッチすることで必要な権限を得ることができます。
Lambda
Lambda関数がRDSやDynamoDBテーブルなどのデータベースにアクセスする必要がある場合、関数にIAMロールを関連付けることで安全にアクセスすることが可能となります。
ロールのメリットとデメリット
メリット
- セキュリティの向上 アクセスキーを直接持たないため、キーの漏洩リスクが低減します。
- 柔軟なアクセス管理 ロールを介して一時的にアクセス権限を付与・変更することができるため、状況に応じた細やかなアクセス制御が可能です。
デメリット
- 設定の複雑さ IAMロールの設定や関連付け、ポリシーの適用など、初めての方には少々複雑に感じられるかもしれません。
- 適切なポリシーの選択が必要 ロールに適切なアクセス権限を持つポリシーを関連付ける必要があり、誤った設定はセキュリティリスクとなる可能性があります。
IAMポリシーの詳細
IAMポリシーは、AWSリソースへのアクセスを制御するためのドキュメントです。このセクションでは、IAMポリシーの種類やその構成、ベストプラクティスについて詳しく解説します。
マネージドポリシーとインラインポリシーの違い
マネージドポリシー
AWSが提供する既存のポリシーであり、複数のIAMエンティティ(ユーザー、グループ、ロール)に再利用可能です。公開されているものや、ユーザーがカスタムで作成したものが含まれます。
インラインポリシー
ユーザーが特定のIAMエンティティに直接関連付けるためのカスタムポリシーです。このポリシーは、関連付けられたエンティティにのみ適用され、再利用はできません。
JSON形式のポリシーの読み方と作成方法
IAMポリシーはJSON形式で記述されます。主要なキーには以下のようなものがあります。
- Effect:ポリシーが許可するか("Allow")、拒否するか("Deny")を指定します。
- Action:許可または拒否するアクションを指定します。例:s3:ListBucketやdynamodb:PutItemなど。
- Resource:アクションが適用されるリソースを指定します。例:特定のS3バケットやDynamoDBテーブルなど。
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"s3:ListBucket"
],
"Resource": "arn:aws:s3:::example-bucket"
},
{
"Effect": "Allow",
"Action": [
"dynamodb:PutItem"
],
"Resource": "arn:aws:dynamodb:us-west-1:123456789012:table/example-table"
}
]
}
上記のサンプルポリシーでは、example-bucketというS3バケットのリストを表示する権限と、example-tableというDynamoDBテーブルにアイテムを追加する権限が許可されています。
ポリシーの書き方のベストプラクティス
最小権限の原則
必要最低限の権限のみを付与すること。これにより、不正なアクセスや誤操作のリスクを最小限に抑えることができます。
明確なリソースの指定
ポリシーでリソースを指定する際は、可能な限り具体的に指定すること。ワイルドカード(*)を使用する場合は注意が必要です。
IAMロールとポリシーのTerraformによるサンプルコード
Terraformは、AWSなどのクラウドプロバイダのリソースをコード化し、安定した環境を効率的にデプロイするためのツールです。以下は、Terraformを使用してIAMロールとポリシーを作成するサンプルコードです。
1. IAMポリシーの作成
resource "aws_iam_policy" "example" {
name = "ExamplePolicy"
description = "My example policy description"
policy = jsonencode({
Version = "2012-10-17",
Statement = [
{
Action = ["s3:ListBucket"],
Effect = "Allow",
Resource = "arn:aws:s3:::example-bucket"
}
]
})
}
上記のコードは、S3のexample-bucketバケットの内容をリストする権限を持つIAMポリシーを作成します。
2. IAMロールの作成
resource "aws_iam_role" "example" {
name = "ExampleRole"
assume_role_policy = jsonencode({
Version = "2012-10-17",
Statement = [
{
Action = "sts:AssumeRole",
Principal = {
Service = "ec2.amazonaws.com"
},
Effect = "Allow",
Sid = ""
}
]
})
}
resource "aws_iam_role_policy_attachment" "example-attach" {
role = aws_iam_role.example.name
policy_arn = aws_iam_policy.example.arn
}
上記のコードは、EC2インスタンスがこのロールを引き受けることができるIAMロールを作成し、先に作成したIAMポリシーをそのロールにアタッチします。
これらのコードを適切な.tfファイル(例えばiam.tfなど)に配置し、terraform init
およびterraform apply
を実行することで、IAMロールとポリシーをAWS上にデプロイできます。
IAMのベストプラクティス
AWSのIAMを効果的に使用するためのベストプラクティスを以下にまとめます。
最小権限の原則
セキュリティの基本的な考え方として、ユーザーやサービスに必要最低限の権限のみを付与する「最小権限の原則」があります。これにより、誤操作や不正アクセスによる損失を最小限に抑えることができます。
実践方法
ポリシーの作成方法
- AWSが提供するマネージドポリシーを活用する
- 必要な権限を個別に定義してカスタムポリシーを作成する
ポリシーの管理方法
- ポリシーのレビューを行う
- ポリシーを定期的に更新する
ルートユーザーの使用を避ける
AWSアカウントのルートユーザーは、AWSリソースに対する全ての権限を持っています。そのため、このユーザーの認証情報が漏洩すると、AWS環境に甚大なダメージが及ぶ可能性があります。
理由
-
セキュリティ上のリスク
- ルートユーザーは制限なく全ての操作ができるため、不正アクセス時のリスクが極大
- 誤操作の可能性
- 意図しない変更や削除が容易
-
ルートユーザーの認証情報を複数人で共有するリスク
- 共有しているうちの1人の認証情報が漏洩すると、AWSアカウントに甚大なダメージが及ぶ可能性
定期的なアクセス権限の見直し
組織の変更やプロジェクトの進行に伴い、IAMユーザーやロールの必要な権限は変わる可能性があります。そのため、定期的にアクセス権限の見直しを行うことが重要です。
重要性
- 不要な権限の削除によるセキュリティリスクの低減
- 過去のプロジェクトや役割で付与された権限が現在も継続している場合、それを削除することでセキュリティリスクを低減
- 新しい権限の追加による作業効率の向上
- 新しいプロジェクトやタスクのために新しい権限が必要になる場合があります。必要な権限を適切に追加することで、作業の効率を向上させることが可能
まとめ
AWSのIAMは、クラウドリソースの管理とセキュリティの強化に不可欠です。この記事では、IAMロール、ポリシー、そしてTerraformを使った適切な設定方法について学びました。IAMの設定は複雑であり、継続的な更新が求められますが、正しく適用することで、AWSの使用経験が向上します。これらの知識を活用し、より安全で効率的なAWS環境を追求しましょう。
【番外編】USBも知らなかった私が独学でプログラミングを勉強してGAFAに入社するまでの話
プログラミング塾に半年通えば、一人前になれると思っているあなた。それ、勘違いですよ。「なぜ間違いなの?」「正しい勉強法とは何なの?」ITを学び始める全ての人に知って欲しい。そう思って書きました。是非読んでみてください。
「フリーランスエンジニア」
近年やっと世間に浸透した言葉だ。ひと昔まえ、終身雇用は当たり前で、大企業に就職することは一種のステータスだった。しかし、そんな時代も終わり「優秀な人材は転職する」ことが当たり前の時代となる。フリーランスエンジニアに高価値が付く現在、ネットを見ると「未経験でも年収400万以上」などと書いてある。これに釣られて、多くの人がフリーランスになろうとITの世界に入ってきている。私もその中の1人だ。数年前、USBも知らない状態からITの世界に没入し、そこから約2年間、毎日勉学を行なった。他人の何十倍も努力した。そして、企業研修やIT塾で数多くの受講生の指導経験も得た。そこで私は、伸びるエンジニアとそうでないエンジニアをたくさん見てきた。そして、稼げるエンジニア、稼げないエンジニアを見てきた。
「成功する人とそうでない人の違いは何か?」
私が出した答えは、「量産型エンジニアか否か」である。今のエンジニア市場には、量産型エンジニアが溢れている!!ここでの量産型エンジニアの定義は以下の通りである。
比較的簡単に学習可能なWebフレームワーク(WordPress, Rails)やPython等の知識はあるが、ITの基本概念を理解していないため、単調な作業しかこなすことができないエンジニアのこと。
多くの人がフリーランスエンジニアを目指す時代に中途半端な知識や技術力でこの世界に飛び込むと返って過酷な労働条件で働くことになる。そこで、エンジニアを目指すあなたがどう学習していくべきかを私の経験を交えて書こうと思った。続きはこちらから、、、、
エンベーダー編集部
エンベーダーは、ITスクールRareTECHのインフラ学習教材として誕生しました。 「遊びながらインフラエンジニアへ」をコンセプトに、インフラへの学習ハードルを下げるツールとして運営されています。
関連記事
2020.02.25
完全未経験からエンジニアを目指す爆速勉強法
USBも知らなかった私が独学でプログラミングを勉強してGAFAに入社するまでの話
- キャリア・学習法
- エンジニア
2023.11.26
gitのコミット履歴を整理するためにsquashを使いこなそう
Squashは、複数のコミットを1つのコミットにまとめる操作です。Squashを使用すると、コミットの履歴を整理したり、コミットのメッセージや変更内容を変更したりすることができます。
- インフラエンジニア
- git
2023.03.01
インフラエンジニア将来のキャリアパス SREや上流工程
インフラエンジニアは、ネットワークやサーバーといったITインフラを支える大切な存在です。今やなくてはならない人材とも言えます。活躍の場が広がっているからこそ、キャリアパスは重要です。
- インフラエンジニア
- キャリア・学習法
2023.09.25
インフラ基盤を支える運用保守エンジニアとは
私たちの生活に欠かせないサーバーやネットワークは、日々稼働しています。そんなサーバーやネットワークといったシステム面を運用保守するのが「運用保守エンジニア」です。
- インフラエンジニア