0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

NLBのNW要件を検証してみる

Posted at

やりたいこと

ふとしたきっかけで、AWSのドキュメントで気になる部分があり、CDKの練習を含んで検証してみようと思いました。
その部分とは、NLB(Network LoadBalancer)のホワイトペーパーのこの部分です。

要件

  • インターネット向けロードバランサーの場合、指定するサブネットには最低 8 個の利用可能な IP アドレスが必要です。内部ロードバランサーの場合は、 AWS がサブネットからプライベート IPv4 アドレスを選択する場合にのみ必要です。

  • 制約のあるアベイラビリティーゾーンにあるサブネットを指定することはできません。エラーメッセージは、「'network' タイプを使用したロードバランサーは az_name でサポートされていません」です。制約されていない別のアベイラビリティーゾーンにあるサブネットを指定し、クロスゾーン負荷分散を使用して、制約されているアベイラビリティーゾーンのターゲットにトラフィックを分散することはできます。

  • ローカルゾーンでサブネットを指定することはできません。

普段はIPを固定して設計しているので、最低8個という要件をあまり気にしていませんでしたが、記載があるならそうなのか???

ということで、検証してみようと思います。

結論

結論からいうと、ホワイトペーパーにある通りでした!(当たり前ですね笑)

  • IPを指定する場合は、1つでも空きがあればOK
  • AWSにお任せする場合はNG

前提

Network周りのリソースとSubnetのIPを埋めるためのEC2インスタンスはCDKで定義しようと思います。
基本的なソースはこちら

VPC・3PrivateSubnet・EC2 10台を構築します。
/28のサブネットを作成しているので、5台ずつaz-a,az-cに構築しています。
空いているIPは6つなので、要件としてはNGのはずです。

NLBの構築

NGになる方

IPv4 settingsの部分で、Assigned from CIDR 10.1.0.0/28を選択します。
(ターゲットグループなどは事前に作成しています。)

01_nlb.png
02_nlb.png

Not enough IP space available in subnet-******.ELB requires at least 8 free IP addresses in each subnet.というエラーが出てます。
ホワイトペーパーの通りAWSがIPを定義する場合はダメなようです。

OKになる方

IPv4 settingsの部分で、Enter IP from CIDR 10.1.0.0/28を選択します。
空いているIPを適当に入力してデプロイしてみます。

03_nlb.png
04_nlb.png

Successfully created load balancerと出てデプロイ出来ました。
ホワイトペーパーの通り自身でIPを指定する場合はOKなようです。

最後に

普段よく使うサービスでもしっかりとドキュメントを読むと、意外と理解できてない部分がありますね。
こういう部分を簡単に検証できるのもパブリッククラウドの利点ですね!

CDKのコードを綺麗にかけるようになりたいです。。

以上です、お読みいただきありがとうございます!!

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

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?