はじめに
SSHなどでログインすることなく、AWSマネジメントコンソールから
直接OS内の情報を参照・操作できるようなサービスが多くなってきました。
今回はそれらのサービスをサクッと体験してみる内容になります。
やってみよう
環境構築
CloudFormationで環境を構築します。手順は下記の通りです。
data:image/s3,"s3://crabby-images/560ed/560ed54731dd1f426f28273edbd96fa088374a71" alt=""
data:image/s3,"s3://crabby-images/4d4c4/4d4c415de37b0603e24573fd64685695407ed1a8" alt=""
data:image/s3,"s3://crabby-images/2d16d/2d16d84cd22a01d196e38010fcd4b47062707784" alt=""
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 |
# 貼り付け用YAML AWSTemplateFormatVersion: 2010-09-09 Parameters: VpcId: Type: AWS::EC2::VPC::Id Description: Enter VPC ID for Tutorial. AmiId: Type: AWS::EC2::Image::Id Description: Enter AMI ID for EC2 Instance. Default: ami-00d101850e971728d InstanceType: Type: String Description: Enter InstanceType for EC2 Instance. Default: t2.micro InstanceName: Type: String Description: Enter Value for Name Tag of EC2 Instance. Default: Amazon Linux 2 DBClusterName: Type: String Description: Enter Name for Aurora DB Cluster. Default: aurora-serverless DBUserName: Type: String Description: Enter DB User Name for Aurora DB Cluster. Default: root DBUserPassword: Type: String Description: Enter DB User Password for Aurora DB Cluster. Default: mypassword Resources: SecurityGroup: Type: AWS::EC2::SecurityGroup Properties: GroupDescription: SecurityGroup for EC2 Instances. SecurityGroupEgress: - IpProtocol: "-1" CidrIp: "0.0.0.0/0" VpcId: !Ref VpcId IAMRole: Type: AWS::IAM::Role Properties: AssumeRolePolicyDocument: Statement: - Effect: "Allow" Principal: Service: - "ec2.amazonaws.com" Action: - "sts:AssumeRole" ManagedPolicyArns: - arn:aws:iam::aws:policy/service-role/AmazonEC2RoleforSSM IAMInstanceProfile: Type: "AWS::IAM::InstanceProfile" Properties: Roles: - !Ref IAMRole DependsOn: [ IAMRole ] EC2Instance: Type: AWS::EC2::Instance Properties: IamInstanceProfile: !Ref IAMInstanceProfile ImageId: !Ref AmiId InstanceType: !Ref InstanceType SecurityGroupIds: - !Ref SecurityGroup Tags: - Key: "Name" Value: !Ref InstanceName DependsOn: [ SecurityGroup, IAMInstanceProfile ] Aurora: Type: "AWS::RDS::DBCluster" Properties: DBClusterIdentifier: !Ref DBClusterName DeletionProtection: false Engine: aurora EngineMode: serverless MasterUsername: !Ref DBUserName MasterUserPassword: !Ref DBUserPassword ScalingConfiguration: AutoPause: false MaxCapacity: 1 MinCapacity: 1 VpcSecurityGroupIds: - !Ref SecurityGroup DependsOn: [ SecurityGroup ] |
YAMLがS3に保存されるので[次へ]。
data:image/s3,"s3://crabby-images/8f167/8f167685f29a5b036637107bc411af922403f67a" alt=""
[パラメータ]のうち入力が必須なのはVpcIdです。それ以外は必要に応じて変更ください。
AMI IDは執筆時点で最新のAmazon Linux 2がデフォルト値として設定されています。
当AMIが利用不可になった場合は新しいAMIのIDを入力してください。
data:image/s3,"s3://crabby-images/734ed/734edddb790b8c1ce4fc152e31e36c662821c444" alt=""
パラメータを入力し終えたら[次へ]。
data:image/s3,"s3://crabby-images/fc84f/fc84f03ae6ef159906ac63d277fc51efbdfcd163" alt=""
data:image/s3,"s3://crabby-images/14c5d/14c5d8f354f25589eec31de06ba3cece79d6e31d" alt=""
最後に全体的な確認を求められるので、IAMリソースの承認にチェックを入れてスタックを作成します。
data:image/s3,"s3://crabby-images/6ff33/6ff33e16751424a44f9f2518f9b713fd897d6b3f" alt=""
しばらくするとリソース(EC2インスタンス、Auroraクラスター)が作成されます。
コンソールからLinuxを触ってみる
まずはコンソールからOSの画面を見てみましょう。
以下のように操作すると、その時点でのスクリーンショットが表示されます。(操作不可)
data:image/s3,"s3://crabby-images/ae986/ae9866dca6046de476b7fe00485a13c3cb5204e0" alt=""
表示されるのは以下のような画面です。
今回はLinuxですが、WindowsであればWindows Updateの進行状況を見たい時に役立ちます。
data:image/s3,"s3://crabby-images/73bce/73bce0b910182d46f7f9ef6474c59e6fdb6a925a" alt=""
次はコンソールからLinuxのコマンドを打ってみましょう。
Systems Managerの操作画面に移り[セッションマネージャー]を操作します。
data:image/s3,"s3://crabby-images/e48e5/e48e54fc1ca0c6c825d0c9109923c3d8858f8a1f" alt=""
操作したいインスタンスを選択し、セッションを開始します。
data:image/s3,"s3://crabby-images/358eb/358eb28d3420196dd6a658fe451ca232ee28829a" alt=""
新しいタブが開き、ブラウザ上からLinuxのコマンドを打つことが出来ます。
data:image/s3,"s3://crabby-images/59ab8/59ab89a8e20b82de61160f7a4d45e05f3ccdac6b" alt=""
コンソールからMySQL(Amazon Aurora MySQL互換)を触ってみる
作成されたDBクラスターの設定を変更します。
data:image/s3,"s3://crabby-images/aba49/aba499721e399504b9976a16d4a968c17b40ac3a" alt=""
Data APIを有効化します。
※執筆時点でベータ版の機能の為か、CloudFormationで本設定を有効化することは出来ませんでした。
data:image/s3,"s3://crabby-images/2b29d/2b29dcde15f4b0d7bb76da4a1fb1459d3137ef19" alt=""
後は画面に従い設定変更を完了させます。
data:image/s3,"s3://crabby-images/b06b2/b06b2a5f30a9d2f90470b1e1987f05e778a9b4fe" alt=""
data:image/s3,"s3://crabby-images/5b909/5b9090e07b38842037a31b703f40006bb23b00d0" alt=""
設定変更が完了したら、RDSの操作画面からQuery Editorを開きます。
data:image/s3,"s3://crabby-images/cb553/cb553f088b016551dc16d6907f34ad696918ab54" alt=""
MySQLへ接続する為の情報を求められるので、入力します。
data:image/s3,"s3://crabby-images/34015/340158bb51d60d251df3474c4714965351b1e029" alt=""
データベースへの接続が完了すると、マネジメントコンソールからクエリを発行できるようになります。
実際にクエリを入力してお試しください。
data:image/s3,"s3://crabby-images/84a0b/84a0b1f354a2fb6d2545b79facec44d55f2ab8c2" alt=""
後片付け
以上で検証は終わりです。
CloudFormationのスタックを削除し、EC2/Aurora等のリソースをクリーンアップしておきましょう。
data:image/s3,"s3://crabby-images/b5c60/b5c60a3b1e374ee5b64a09d575b7fb8d0d46a967" alt=""
投稿者プロフィール
- 2015年8月入社。弊社はインフラ屋ですが、アプリも作ってみたいです。