0
0

東大のAWSによるクラウド入門やってみた日記 2

Posted at

前回

今回進んだところ

3.6~4.5まで進みました。

AWSの登録

4.1でAWSアカウントの準備が必要なので進めました。
最初にEメールで登録したユーザはルートユーザで、この先の手順に書かれている端末からのアクセスではこのユーザを直接使う事ができないので、別途ユーザを作る必要があります。

AWSではユーザや役割による権限、グループなどを管理する機能はIAMにまとめられています。

私はとりあえずというのと資料を読み勧めるの優先でAdmin権限を持ったユーザを作ってしまいましたが、本来であれば権限周りの理解や最低限のセキュリティ設定をしたうえで使ったほうが良いと思います。

とりあえず最小限のセキュリティだけでも確保したい人向け
https://qiita.com/yanyansk/items/3a989b70d2d3d49eff16

IAMや権限周りのベストプラクティスを知りたい人向け
https://qiita.com/c60evaporator/items/0121399880625cc1de51

あと注意が必要な点ですが、端末からのアクセスに必要な情報のうちシークレットアクセスキーはユーザ作成時に表示されたあとは確認する方法がありません。
ユーザー作成時にメモしておきましょう。

aws-cdk

今回一番ハマった点です。
資料中ではaws-cdkのバージョンは1.30.0が推奨されていますが、手順通り1.30.0で進めるとcdk bootstrapでエラーになります。

そもそも1.30.0のpackeage.jsonにはnodeの必須バージョンが10.3.0と書いてありますが、10.3.0では動きませんでした。
↓こんな感じのエラーになります。

/home/***/.nvm/versions/node/v10.3.0/lib/node_modules/aws-cdk/node_modules/minimatch/dist/commonjs/index.js:192
    options;
           ^

SyntaxError: Unexpected token ;
    at new Script (vm.js:74:7)
    at createScript (vm.js:246:10)
    at Object.runInThisContext (vm.js:298:10)
    at Module._compile (internal/modules/cjs/loader.js:670:28)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:713:10)
    at Module.load (internal/modules/cjs/loader.js:612:32)
    at tryModuleLoad (internal/modules/cjs/loader.js:551:12)
    at Function.Module._load (internal/modules/cjs/loader.js:543:3)
    at Module.require (internal/modules/cjs/loader.js:650:17)
    at require (internal/modules/cjs/helpers.js:20:18)

nodeのバージョンをそれぞれ12.22.12と14.21.3で試したところ14.21.3だと動きましたが、pip install -r requirement.txt後にcdk bootstrapを実行してもエラーになります。(jissのバージョンの問題?)

$ nvm use 14
Now using node v14.21.3 (npm v6.14.18)
$ cdk --version
1.30.0 (build 4f54ff7)
$ source .env/bin/activate
(.env)$ pip install -r requirements.txt
(.env)$ cdk bootstrap
Traceback (most recent call last):
  File "/mnt/***/intro-aws/handson/01-ec2/app.py", line 53, in <module>
    MyFirstEc2(
  File "/mnt/***/intro-aws/handson/01-ec2/.env/lib/python3.10/site-packages/jsii/_runtime.py", line 66, in __call__
    inst = super().__call__(*args, **kwargs)
  File "/mnt/***/intro-aws/handson/01-ec2/app.py", line 13, in __init__
    vpc = ec2.Vpc(
  File "/mnt/***/intro-aws/handson/01-ec2/.env/lib/python3.10/site-packages/jsii/_runtime.py", line 66, in __call__
    inst = super().__call__(*args, **kwargs)
  File "/mnt/***/intro-aws/handson/01-ec2/.env/lib/python3.10/site-packages/aws_cdk/aws_ec2/__init__.py", line 25781, in __init__
    jsii.create(Vpc, self, [scope, id, props])
  File "/mnt/***/intro-aws/handson/01-ec2/.env/lib/python3.10/site-packages/jsii/_kernel/__init__.py", line 224, in create
    response = self.provider.create(
  File "/mnt/***/intro-aws/handson/01-ec2/.env/lib/python3.10/site-packages/jsii/_kernel/providers/process.py", line 333, in create
    return self._process.send(request, CreateResponse)
  File "/mnt/***/intro-aws/handson/01-ec2/.env/lib/python3.10/site-packages/jsii/_kernel/providers/process.py", line 303, in send
    data = json.dumps(req_dict, default=jdefault).encode("utf8")
  File "/usr/lib/python3.10/json/__init__.py", line 238, in dumps
    **kw).encode(obj)
  File "/usr/lib/python3.10/json/encoder.py", line 199, in encode
    chunks = self.iterencode(o, _one_shot=True)
  File "/usr/lib/python3.10/json/encoder.py", line 257, in iterencode
    return _iterencode(o, 0)
  File "/mnt/***/intro-aws/handson/01-ec2/.env/lib/python3.10/site-packages/jsii/_kernel/providers/process.py", line 146, in jdefault
    raise TypeError("Don't know how to convert object to JSON: %r" % obj)
TypeError: Don't know how to convert object to JSON: <SubnetType.PUBLIC: 'PUBLIC'>
Subprocess exited with error 1

色々バージョンを探ってみましたが、わからん+時間がかかるので動きそうなaws-cdkのバージョンに変えました。
nodeの18.20.3をつかって最新のaws-cdkを入れました。

後で書きますが、aws-cdkはnodeのバージョン18をサポートしていないので、最初から17.3をインストールして作業を進めることをおすすめします。

$ nvm use 18
Now using node v18.20.3 (npm v10.7.0)
$ npm install aws-cdk
added 1 package in 4s

cdk initを実行するため、空のディレクトリを作って、そこで作業します。

$ mkdir work
$ cd work
$ cdk init app --language=python
(出力は長いので省略)
$ python3 -m venv .env
$ source .env/bin/activate
$ pip install -r requirements.txt
(出力は長いので省略)
$ cdk bootstrap

動かん……。

Cannot find module '@aws-cdk/cx-api'というエラーが発生しました。
どうやら2.14.0は問題があるらしく2.13.0を使えというissueを見つけました(※後日2.14.9はうまく動きました)。
https://github.com/localstack/aws-cdk-local/issues/59

aws-cdkは開発が活発なようでチョロチョロバグを踏む可能性がありそうです。
aws-cdkのバージョンを2.13.0に変更してcdk bootstrapを実行したところうまく動きました。

Trusted accounts for deployment: (none)
Trusted accounts for lookup: (none)
Using default execution policy of 'arn:aws:iam::aws:policy/AdministratorAccess'. Pass '--cloudformation-execution-policies' to customize.
Bootstrap stack already at version '21'. Not downgrading it to version '10' (use --force if you intend to downgrade)
 ✅  Environment aws://339712945862/ap-northeast-1 bootstrapped (no changes).

ここで起動時のwarningでnodeのバージョン18はサポートしてないよと出るので、バージョンを17.3に切り替えました。

この状態で4.4.1から作業を進めると4.4.4の「デプロイを実行」で引っかかりました。
https://tomomano.gitlab.io/intro-aws/#_%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%A0%E3%82%92%E5%AE%9F%E8%A1%8C%E3%81%99%E3%82%8B

Traceback (most recent call last):
  File "/mnt/c/Users/AtsushiYamazaki/git/intro-aws/handson/01-ec2/app.py", line 1, in <module>
    from aws_cdk import (
ImportError: cannot import name 'core' from 'aws_cdk' (/mnt/c/Users/AtsushiYamazaki/git/intro-aws/work/.venv/lib/python3.10/site-packages/aws_cdk/__init__.py)
Subprocess exited with error 1

上でも書きましたがaws-cdkは開発が活発で、破壊的な更新も少なくないようです。
要は東大が用意してくれたpythonのコードはaws-cdk2.13.0では使えないようです

なので下記の記事を元に書き換えます。
https://qiita.com/t-kigi/items/8115456ebbb43c5c738e

from aws_cdk import (
    core,
    aws_ec2 as ec2,
)
import os
from aws_cdk import (
    aws_ec2 as ec2,
)
import aws_cdk as core
import os

これでうまく動きます。
(※このあとknown_hostsに書き込めないというエラーが出たりもしたのですが、パーミッションを変えればいいだけだったので、問題はないかなと思います。)

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0