Upgrade to Pro — share decks privately, control downloads, hide ads and more …

Docker/ECSで IAMロールを利用する

takipone
January 17, 2015

Docker/ECSで IAMロールを利用する

Docker Meetup Tokyo #4 LT

takipone

January 17, 2015
Tweet

More Decks by takipone

Other Decks in Technology

Transcript

  1. classmethod.jp 2 ⾃自⼰己紹介 •  ⽒氏名  :  ⼤大瀧隆太      

                 @takipone •  会社  :  クラスメソッド •  ポジション  :      AWSコンサル部    エンジニア  /  研修講師 classmethod.jp 2
  2. Dockerコンテナのクレデンシャル管理理 1.  DockerfileのADDなどで設定ファイルを Dockerイメージに埋め込む – クレデンシャル更更新によるイメージの作り直し – Docker  HubへのPushは漏漏洩につながってしまう 2.  環境変数をdocker  run

     -‐‑‒-‐‑‒envで渡す – GKE/ECSだと環境変数を定義ファイルに記述す るので、そのファイルの管理理が必要 3.  クラウドサービスを利利⽤用することで、 クレデンシャルが外出しできる – AWS  :  IAMロール – GCE  :  Service  Account classmethod.jp 4
  3. classmethod.jp 5 AWS  IAMロールの仕組み EC2 AWS  IAM メタデータ サーバー 169.254.169.254

    S3 ⼀一時キー ⼀一時キー GET  /latest/meta-‐‑‒data/iam/ security-‐‑‒credentials/role-‐‑‒name ⼀一時キーでS3にアクセス
  4. classmethod.jp 6 DockerコンテナからのIAMロール EC2 AWS  IAM メタデータ サーバー 169.254.169.254 S3

    ⼀一時キー インスタンスと同じ⼀一時キー が取得できる/できちゃう
  5. classmethod.jp 9 こうする。 AWS  IAM メタデータ サーバー 169.254.169.254 S3 ⼀一時キー

    sts:AssumeRole メタデータサーバーへ のトラフィックを⾃自前 サーバーにフック ⾃自前メタデータ サーバー
  6. classmethod.jp 10 こうする。(⾃自前サーバーの実⾏行行) $ ruby ec2-role.rb arn:aws:iam::XXXXXXXXXXXX:role/exc_web [2015-01-16 15:04:44] INFO

    WEBrick 1.3.1 [2015-01-16 15:04:44] INFO ruby 2.1.5 (2014-11-13) [x86_64-linux-gnu] == Sinatra/1.4.5 has taken the stage on 4567 for development with backup from WEBrick [2015-01-16 15:04:44] INFO WEBrick::HTTPServer#start: pid=2425 port=4567 { "Code" : "Success", "AccessKeyId" : "ASIAJUGBBWGPOE5LB2DA", "SecretAccessKey" : "F1UCLL1xus3i/HX5UjmJRoPzothnnAza9WRCRbSn", "Token" : "AQoDYXdzEPD////////// wEakAJ5SVuBEVHPmjjCMmaAJ7zX6MJsRy09k62S92wCO5rGImeVeKx +IB4AVZJ4eE8E0kRGpI7RDpW1l3UEqfeWon6AKwuNJQxgrcKOuB91zKSi3BeH8nT/ d2JUoY2deUVyBMLg3LoebPIlAzl1l83mbQ1Dds1vsj6pSn+nhU0w +hFJxypQcEGDSUrGyJMw15xDD/DQ+9G001ocbp0yBD4otjInNxWgB/ kME1KBPVANSLcJKSTubvNqjwyVgQpPGdu5p/eutns/sSvvRfYgKU9eSEdZzJ5y3djSEoo +J4Rmwrtol4p0fS1VhzsQOxPpH5nCaJwJiW3LnUfPbaDGoCwk2kq6z8sH8sx1t0Du +VT9Xp0qYSCM0eSlBQ==", "Expiration" : "2015-01-16T16:04:44Z" }
  7. classmethod.jp 11 こうする。(トラフィックのフック) $ sudo iptables -t nat \ -A

    PREROUTING -j DNAT \ -i docker0 \ -p tcp \ ! --src 172.17.0.2 \ --dst 169.254.169.254 --dport 80 \ --to 172.17.42.1:4567
  8. classmethod.jp 12 できた。 $ docker exec 2de1f31fcb3d curl -s 169.254.169.254/latest/meta-data/iam/

    security-credentials/temp { "Code" : "Success", "AccessKeyId" : "ASIAJUGBBWGPOE5LB2DA", "SecretAccessKey" : "F1UCLL1xus3i/HX5UjmJRoPzothnnAza9WRCRbSn", "Token" : "AQoDYXdzEPD////////// : $ ruby ec2-role.rb arn:aws:iam::XXXXXXXXXXXX:role/exc_web : 172.17.0.3 - - [17/Jan/2015:04:58:54 +0000] "GET /latest/meta-data/iam/ security-credentials/temp HTTP/1.1" 200 590 0.0003 ip-172-17-0-3.ec2.internal - - [17/Jan/2015:04:58:54 UTC] "GET /latest/ meta-data/iam/security-credentials/temp HTTP/1.1" 200 590 - -> /latest/meta-data/iam/security-credentials/temp •  コンテナからメタデータサーバーにリクエスト •  ⾃自前メタデータサーバーにアクセスログが表⽰示