AWS高すぎ問題
現在円安で1ドル142円前後となっている。1ドル110円台にAWSは安い!とか思ってコスト削減を狙って社内システムをコストをかけて移行した企業は、円安により30%以上値上がりした結果、AWSへの移行を後悔されていると思う。
とはいっても改めてサーバーを社内システムにも戻すわけにはいかない。どのような対策が考えられるだろうか。
想定するアーキテクチャー(こうした構成がたくさんある想定):
①EC2を利用せずフルサーバーレス(SPA/S3/APIGateway/Lamda/Dynamodb)にアーキテクチャーを変更する
JavaやASP.NETなどのWebアプリケーションは高価なインスタンスを必要とするEC2やBeanstalk、RDSなどのインスタンスで動かさざるを得ない。
プログラムを根本的に書き換えることでインスタンスを利用しないフルサーバーレスアプリケーション(SPA/S3/APIGateway/Lamda/Dynamodb)を変更する。
- メリット:大幅なコスト削減、信頼性の向上が可能。サーバーレスでは利用量%3CmxGraphModel%3E%3Croot%3E%3CmxCell%20id%3D%220%22%2F%3E%3CmxCell%20id%3D%221%22%20parent%3D%220%22%2F%3E%3CmxCell%20id%3D%222%22%20style%3D%22edgeStyle%3DorthogonalEdgeStyle%3Brounded%3D0%3BorthogonalLoop%3D1%3BjettySize%3Dauto%3Bhtml%3D1%3B%22%20edge%3D%221%22%20source%3D%223%22%20target%3D%224%22%20parent%3D%221%22%3E%3CmxGeometry%20relative%3D%221%22%20as%3D%22geometry%22%2F%3E%3C%2FmxCell%3E%3CmxCell%20id%3D%223%22%20value%3D%22AWS%20Lambda%22%20style%3D%22outlineConnect%3D0%3BfontColor%3D%23232F3E%3BgradientColor%3D%23F78E04%3BgradientDirection%3Dnorth%3BfillColor%3D%23D05C17%3BstrokeColor%3D%23ffffff%3Bdashed%3D0%3BverticalLabelPosition%3Dbottom%3BverticalAlign%3Dtop%3Balign%3Dcenter%3Bhtml%3D1%3BfontSize%3D12%3BfontStyle%3D0%3Baspect%3Dfixed%3Bshape%3Dmxgraph.aws4.resourceIcon%3BresIcon%3Dmxgraph.aws4.lambda%3BlabelBackgroundColor%3D%23ffffff%3BspacingTop%3D6%3B%22%20vertex%3D%221%22%20parent%3D%221%22%3E%3CmxGeometry%20x%3D%22640%22%20y%3D%22336%22%20width%3D%2278%22%20height%3D%2278%22%20as%3D%22geometry%22%2F%3E%3C%2FmxCell%3E%3CmxCell%20id%3D%224%22%20value%3D%22Amazon%26lt%3Bbr%26gt%3BDynamoDB%22%20style%3D%22outlineConnect%3D0%3BfontColor%3D%23232F3E%3BgradientColor%3D%234D72F3%3BgradientDirection%3Dnorth%3BfillColor%3D%233334B9%3BstrokeColor%3D%23ffffff%3Bdashed%3D0%3BverticalLabelPosition%3Dbottom%3BverticalAlign%3Dtop%3Balign%3Dcenter%3Bhtml%3D1%3BfontSize%3D12%3BfontStyle%3D0%3Baspect%3Dfixed%3Bshape%3Dmxgraph.aws4.resourceIcon%3BresIcon%3Dmxgraph.aws4.dynamodb%3BlabelBackgroundColor%3D%23ffffff%3B%22%20vertex%3D%221%22%20parent%3D%221%22%3E%3CmxGeometry%20x%3D%22830%22%20y%3D%22336%22%20width%3D%2278%22%20height%3D%2278%22%20as%3D%22geometry%22%2F%3E%3C%2FmxCell%3E%3CmxCell%20id%3D%225%22%20style%3D%22edgeStyle%3DorthogonalEdgeStyle%3Brounded%3D0%3BorthogonalLoop%3D1%3BjettySize%3Dauto%3Bhtml%3D1%3B%22%20edge%3D%221%22%20source%3D%226%22%20target%3D%223%22%20parent%3D%221%22%3E%3CmxGeometry%20relative%3D%221%22%20as%3D%22geometry%22%2F%3E%3C%2FmxCell%3E%3CmxCell%20id%3D%226%22%20value%3D%22API%20Gateway%22%20style%3D%22sketch%3D0%3Bpoints%3D%5B%5B0%2C0%2C0%5D%2C%5B0.25%2C0%2C0%5D%2C%5B0.5%2C0%2C0%5D%2C%5B0.75%2C0%2C0%5D%2C%5B1%2C0%2C0%5D%2C%5B0%2C1%2C0%5D%2C%5B0.25%2C1%2C0%5D%2C%5B0.5%2C1%2C0%5D%2C%5B0.75%2C1%2C0%5D%2C%5B1%2C1%2C0%5D%2C%5B0%2C0.25%2C0%5D%2C%5B0%2C0.5%2C0%5D%2C%5B0%2C0.75%2C0%5D%2C%5B1%2C0.25%2C0%5D%2C%5B1%2C0.5%2C0%5D%2C%5B1%2C0.75%2C0%5D%5D%3BoutlineConnect%3D0%3BfontColor%3D%23232F3E%3BgradientColor%3D%23FF4F8B%3BgradientDirection%3Dnorth%3BfillColor%3D%23BC1356%3BstrokeColor%3D%23ffffff%3Bdashed%3D0%3BverticalLabelPosition%3Dbottom%3BverticalAlign%3Dtop%3Balign%3Dcenter%3Bhtml%3D1%3BfontSize%3D12%3BfontStyle%3D0%3Baspect%3Dfixed%3Bshape%3Dmxgraph.aws4.resourceIcon%3BresIcon%3Dmxgraph.aws4.api_gateway%3B%22%20vertex%3D%221%22%20parent%3D%221%22%3E%3CmxGeometry%20x%3D%22450%22%20y%3D%22336%22%20width%3D%2278%22%20height%3D%2278%22%20as%3D%22geometry%22%2F%3E%3C%2FmxCell%3E%3CmxCell%20id%3D%227%22%20value%3D%22S3-SPA%E3%82%A2%E3%83%97%E3%83%AA%22%20style%3D%22outlineConnect%3D0%3Bdashed%3D0%3BverticalLabelPosition%3Dbottom%3BverticalAlign%3Dtop%3Balign%3Dcenter%3Bhtml%3D1%3Bshape%3Dmxgraph.aws3.s3%3BfillColor%3D%23E05243%3BgradientColor%3Dnone%3B%22%20vertex%3D%221%22%20parent%3D%221%22%3E%3CmxGeometry%20x%3D%22450%22%20y%3D%22186%22%20width%3D%2276.5%22%20height%3D%2293%22%20as%3D%22geometry%22%2F%3E%3C%2FmxCell%3E%3CmxCell%20id%3D%228%22%20style%3D%22edgeStyle%3DorthogonalEdgeStyle%3Brounded%3D0%3BorthogonalLoop%3D1%3BjettySize%3Dauto%3Bhtml%3D1%3BentryX%3D0%3BentryY%3D0.5%3BentryDx%3D0%3BentryDy%3D0%3BentryPerimeter%3D0%3B%22%20edge%3D%221%22%20source%3D%2210%22%20target%3D%227%22%20parent%3D%221%22%3E%3CmxGeometry%20relative%3D%221%22%20as%3D%22geometry%22%2F%3E%3C%2FmxCell%3E%3CmxCell%20id%3D%229%22%20style%3D%22edgeStyle%3DorthogonalEdgeStyle%3Brounded%3D0%3BorthogonalLoop%3D1%3BjettySize%3Dauto%3Bhtml%3D1%3BentryX%3D0%3BentryY%3D0.5%3BentryDx%3D0%3BentryDy%3D0%3BentryPerimeter%3D0%3B%22%20edge%3D%221%22%20source%3D%2210%22%20target%3D%226%22%20parent%3D%221%22%3E%3CmxGeometry%20relative%3D%221%22%20as%3D%22geometry%22%2F%3E%3C%2FmxCell%3E%3CmxCell%20id%3D%2210%22%20value%3D%22Web%E3%83%96%E3%83%A9%E3%82%A6%E3%82%B6%22%20style%3D%22aspect%3Dfixed%3Bhtml%3D1%3Bpoints%3D%5B%5D%3Balign%3Dcenter%3Bimage%3BfontSize%3D12%3Bimage%3Dimg%2Flib%2Fazure2%2Fgeneral%2FBrowser.svg%3B%22%20vertex%3D%221%22%20parent%3D%221%22%3E%3CmxGeometry%20x%3D%22140%22%20y%3D%22260%22%20width%3D%22105%22%20height%3D%2284%22%20as%3D%22geometry%22%2F%3E%3C%2FmxCell%3E%3C%2Froot%3E%3C%2FmxGraphModel%3Eに応じた支払いになる。一般的な業務アプリケーションの利用時間(年の1/4程度でリソース利用率30%)からするとサーバーにかかわるコストは1/10程度のコストまで削減可能
- デメリット:アプリケーション再作成への初期投資がかかりすぎる。また、サーバーレスアーキテクチャーに通じたSEの調達も困難。
- 対象:更改タイミングなどが来ているアプリケーションの場合などにオススメ
②Autoscalingアーキテクチャーに変更して、サーバーをできる限り落とす。また、思い切ってSPOTインスタンスにしてしまう
EC2の契約は通常の契約から大幅に割り引いた(90-80%値引き)SPOTインスタンスというものが存在する。SPOTインスタンスでサーバーを起動することでコストを大幅に削減することができる。ただし、SPOTインスタンスはAWSの要求によりサーバーが停止されるという大きなデメリットが存在する。これに対応するためサーバー停止時に再度起動するなどのAutoscalingアーキテクチャーの導入、停止をユーザーに検知させないためのALBを導入する。
- メリット:EC2インスタンス利用量のコスト削減が可能。
- デメリット:停止をユーザーに検知させないためALB利用のためのサーバー構成変更が必要。インスタンス停止イベントを受け取り、ALBへドレインする処理の追加の必要。
- 対象:複数サーバーでの分散が可能なWEBシステムにオススメ。一般的なWEBシステムではロードバランス可能な構成になっていることが多いので、こうした対策を導入するのは非常に容易なハズ
③DBサーバーのキャパシティをAutoscalingで可変にする。
AWSのRDSサービスは利用量に応じた拡張を行う機能(Autoscaling)が存在している。これを利用してDBのキャパシティを固定せず、利用量がひくときはDBのキャパシティを開放することでコストを削減する。
- メリット:RDS利用量のコスト削減が可能。
- デメリット:特になし。あえて言うのであればDB構成変更のための試験が必要なくらい。
- 対象:全システムで導入すべき構成。
結論
他にも様々なサーバー要件に従いコスト削減が可能なパターンがあると思うが、AWSでは工夫次第で様々な方法でコスト削減が可能な構成をとることができる。こうしたタイミングだけでなく、初期設計の段階でもコスト削減を考慮した構成を検討することで、様々なシステムのAWS化を推進することができるだろう。
例)全パターンを混ぜたサーバーコストが1/3程度になる想定の構成



.png)

