AWS Cloud9の利点の1つが、同じ環境を複数人で共有できることです。
同じファイルを同時に更新したり、チャットでコミューケーションをとったりできます。
AWS Cloud9で共有環境を用意し、複数人で開発を行えるようにするまでの手順をまとめました。
[1] IAMユーザーを用意する
Cloud9にアクセス出来るユーザーを準備します。
[1-1] ユーザー権限の違い
AWSCloud9Administrator, AWSCloud9User, AWSCloud9EnvironmentMember、3種類のポリシー(権限)が存在します。
3種類の違いは、大雑把にまとめると以下の通りです。
ポリシー | 作成 | 編集(*1) | 削除 | アクセス |
---|---|---|---|---|
AWSCloud9Administrator | OK | OK | OK | OK |
AWSCloud9User | OK | NG(*2) | NG(*2) | OK |
AWSCloud9EnvironmentMember | NG | NG | NG | OK |
*1:環境の編集のことであり、ファイルの編集はAWSCloud9EnvironmentMemberでも可能。
*2:自身で作成した環境の編集・削除は可。
詳しくは下記を参照。
AWS Cloud9 のアクセス権限リファレンス
[1-2] AWSCloud9User権限ユーザー作成
自身で環境の作成も可能なAWSCloud9Userを作成します。
[1-2-1] ユーザー名とアクセスの種類
ユーザー名やパスワードは自分の好きなものにして問題ありません。
今回は、マネジメントコンソールからのみ使用するので、アクセスの種類は「AWS マネジメントコンソールへのアクセス」を選択します。
[1-2-2] アクセス許可の設定
アクセス許可の設定では[既存のポリシーを直接アタッチ]を選択します。
ポリシーのフィルタで検索欄に"cloud9"と入力すると、上述の3つのポリシーが表示されます。
その中から「AWSCloud9User」を選択します。
[1-2-3] その他の設定
以降の項目はデフォルトのままにして作成を進めました。
[1-3] AWSCloud9EnvironmentMember権限ユーザー作成
選択するポリシー以外は、AWSCloud9Userと同様に作成します。
[2] 共有環境を作る
[2-1] ルートユーザーでCloud9環境作成
共有するからと言って特別な手順はなく、1人で開発するときと同様に環境を作成します。
[2-2] 他のユーザーと共有
環境の作成が終わったら、早速ほかのユーザーと共有してみます。
右上の[Share]をクリックします。
[2-3] AWSCloud9User権限ユーザーを招待
[Share]を押すと、以下の画面が表示されます。
ユーザーを招待することで、作成した環境を共有します。
シェアしたいユーザーの名称を入力し、R (Readのみ可), R/W (Read/Write可)のいずれを選択し、[Invite]をクリックします。
以上で、AWSCloud9User権限ユーザーの招待が完了しました。
[3] 共有環境を使用する
[3-1] 2つのユーザーで同時編集
rootユーザーと先ほど招待したユーザーとで、同じファイルを編集してみたところ、ほとんど遅延なくお互いの画面に編集内容が反映されました。
ソースコードの行No.の左側に色が付いていますが、ユーザーごとに異なる色になっています。
どのユーザーがどの行を編集したのかが分かるようになっています。
[3-2] 3つのユーザーで同時編集
もう1人ユーザーを招待し、同じファイルを編集した場合も同様です。
[3-3] チャット機能
チャットは画面右側に表示されます。
絵文字等はなく、最低限のチャットに必要な機能だけが提供されているという印象です。
終わりに
かなり簡単に共有環境を用意することができました。
実際に複数人で開発するにあたっては、色々とルールを決める必要はありでしょう。
しかしながら、数人でさくっと何かを作る、コードレビューを行う、といった場面では便利なこと間違いなしということが分かりました。
参考文献
IAMユーザーのポリシー(権限)に関して、下記記事を参考にさせていただきました。
【AWS】cloud9へのアクセスのみが可能なユーザーを作成してコードを共有してみる