プログラミングマガジン

プログラミングを中心にIT技術をできるだけわかりやすくまとめます。

  • ホーム
  • 設計
  • 【インフラ】Dockerを本番環境でどう動かすか?(EC2、ECSなど)
 
 
     
  • サーバー言語  
    • Python
    • Ruby
    • PHP
    • SQL
  •  
  • インフラ  
       
    • AWS
    •  
    • 基本
    • Git
  • Web
       
    • Web開発
    • JavaScript
    • Vue.js
    • React
  •  
  • 設計  
       
    • 実装設計
    • DB設計
  • 問い合わせ
  

【インフラ】Dockerを本番環境でどう動かすか?(EC2、ECSなど)

12.02

  • miyabisan2
  • コメントを書く

この記事は2分で読めます

以前は、コンテナは開発環境だけ導入するのが主流だったのですが、ECSにより本番環境でも導入する事例が増えてきています。

コンテナがない場合

ローカル環境

開発環境の構成のメンテナンスが大変

開発環境、ステージング環境

テストの需要がバラバラで管理が大変

本番環境

オートスケールや、ノード障害対応が大変

全体

ローカル、開発、ステージング、本番全ての環境に差異がある。

Dockerをローカル以外の環境に導入するメリット

開発環境で作ったdocker imageを本番環境でも使えるので品質向上及び、構築時間短縮になる。

VMなどに比べて起動が100倍以上早く冗長性が高くなる。

オンプレ+クラスタという構成のクラスタも作りやすいためコストダウンになる。

kubenetesを使えば、冗長性を高める仕組みを自動化できる。

Dockerをローカル以外の環境に導入するデメリット

DBなどの永続化ができないのでバックアップなどの工夫が必要

VMよりも管理の単位が広くなる(VMならインスタンス単位だが、コンテナの場合Pod単位になる。)

新しい技術のため熟知したエンジニアが少なく、事例も少ない。

Dockerをローカル以外の環境に導入する上での課題

どうやってフェイルオーバーする?(待機系と稼働系を切り替える?)、スケールする?

クラスタ管理を導入する必要がある。

具体的には以下のようなことを意識する。ただ、これを自前でやろうとするとかなり大変になる。

  • インスタンス群の状態を管理
  • どこでどのコンテナを動かすか決めて実行
  • コンテナ群の状態を管理

ECSの導入

EC2インスタンス群を簡単にDocker実行環境に変身させられる。

ECS Agentをインストールするだけで済み、管理インスタンスは不要

1コンテナから数万コンテナ以上を管理

開発環境から本番環境までこれ一つで管理

AWSの他のサービスとの連携が簡単
  • CloudFormationでデプロイが可能
  • ALB連携ができる。

DockerデーモンをEC2で使う。

本格的なアプリならECSやEKSなどを検討した方が良いでしょうが、アクセスがそんな見込めない簡易的なアプリケーションであればEC2上で運用しても問題ないでしょう。その手順をまとめておきます。

dockerデーモンをインストールする。

yumアップデートをしてパッケージを最新化します。

1
sudo yum update -y

Dockerデーモンをインストールします。(amazon linux2のみ)

1
sudo amazon-linux-extras install docker

Dockerサービスをスタートさせます。

1
sudo service docker start

ec2-userをDockerグループに所属するように変更します。

1
sudo usermod -a -G docker ec2-user

一旦ログアウトします。

1
exit

dockerデーモンがちゃんとインストールされたか下記コマンドで確認します。

1
docker info

docker hubにログインする。

下記コマンドを実行してユーザー名とパスワードを入力します。

1
docker login

スポンサーリンク
  • 2021 12.02
  • miyabisan2
  • コメントを書く
  • インフラ, 設計
  • Tweets Twitter
  • このエントリーをはてなブックマークに追加
  • LINEで送る

関連記事

  1. 2021 10.03

    【設計】RDBの基本思想(ソートが苦手)、大きなデータをソートしたい場合

  2. 2021 08.01

    【データベース設計】テーブル設計の指針、アンチパターン

  3. 2021 12.05

    【設計】「キューイング」とは?

  4. 2018 07.19

    【Auth0】認証プラットフォーム「Auth0」とは?

  5. 2021 12.02

    【インフラ】「GitLab」と「GitHub」、「Code Commit」の違い

  6. 2018 05.19

    【クラス設計】クラスの独立性を高めるコツ

  • コメント ( 0 )
  • トラックバック ( 0 )
  1. この記事へのコメントはありません。

  1. この記事へのトラックバックはありません。

返信をキャンセルする。

【AWS】「Code Commit」、「Code Bu…

【AWS】「ECS/Fargate構成」におけるメトリ…

RETURN TOP

著者プロフィール

エンジニア歴10年で過去に業務系、Webデザイン、インフラ系なども経験あります。現在はWeb系でフロントエンド開発中心です。

詳細なプロフィールはこちら

スポンサーリンク

カテゴリー

  • Android
  • AngularJS
  • API
  • AWS
  • C++
  • CSS
  • cursor
  • C言語
  • DDD
  • DevOps
  • Django
  • Docker
  • Figma
  • Git
  • GitLab
  • GraphQL
  • gRPC
  • Hasura
  • Java
  • JavaScript
  • Kubernetes
  • Laravel
  • linux
  • MySQL
  • Next.js
  • nginx
  • Node.js
  • NoSQL
  • Nuxt.js
  • Oracle
  • PHP
  • Python
  • React
  • Redux
  • Rspec
  • Ruby
  • Ruby on Rails
  • Sass
  • Spring Framework
  • SQL
  • TypeScript
  • Unity
  • Vue.js
  • Webサービス開発
  • Webデザイン
  • Web技術
  • インフラ
  • オブジェクト指向
  • システム開発
  • セキュリティ
  • その他
  • データベース
  • デザインパターン
  • テスト
  • ネットワーク
  • プログラミング全般
  • マイクロサービス
  • マイクロソフト系技術
  • マルチメディア
  • リファクタリング
  • 副業
  • 未分類
  • 業務知識
  • 生成AI
  • 設計
  • 関数型言語
RETURN TOP

Copyright ©  プログラミングマガジン | プライバシーポリシー