Amazon Web Services-기본 아키텍처
이것이 기본 구조입니다. AWS EC2, 어디 EC2Elastic Compute Cloud의 약자입니다. EC2를 통해 사용자는 요구 사항에 따라 다양한 구성의 가상 머신을 사용할 수 있습니다. 다양한 구성 옵션, 개별 서버 매핑, 다양한 요금 옵션 등이 가능합니다. 이에 대해서는 AWS 제품 섹션에서 자세히 설명합니다. 다음은 아키텍처의 다이어그램 표현입니다.
Note − 위의 다이어그램에서 S3Simple Storage Service의 약자입니다. 이를 통해 사용자는 API 호출을 사용하여 다양한 유형의 데이터를 저장하고 검색 할 수 있습니다. 컴퓨팅 요소가 포함되어 있지 않습니다. 이 주제는 AWS 제품 섹션에서 자세히 설명합니다.
부하 분산
Load balancing단순히 웹 서버를 통한 하드웨어 또는 소프트웨어로드를 의미하며, 이는 서버와 애플리케이션의 효율성을 향상시킵니다. 다음은로드 밸런싱을 사용하는 AWS 아키텍처의 다이어그램 표현입니다.
하드웨어로드 밸런서는 기존 웹 애플리케이션 아키텍처에서 사용되는 매우 일반적인 네트워크 어플라이언스입니다.
AWS는 Elastic Load Balancing 서비스를 제공하고, 트래픽을 사용 가능한 여러 소스에 걸쳐 EC2 인스턴스로 분산하고,로드 밸런싱 순환에서 Amazon EC2 호스트를 동적으로 추가 및 제거합니다.
Elastic Load Balancing 로드 밸런싱 용량을 동적으로 확장 및 축소하여 트래픽 요구에 맞게 조정할 수 있으며 고정 세션을 지원하여 고급 라우팅 요구를 해결할 수도 있습니다.
아마존 클라우드 프런트
콘텐츠 전달, 즉 웹 사이트 전달에 사용됩니다. 엣지 로케이션의 글로벌 네트워크를 사용하는 동적, 정적 및 스트리밍 콘텐츠가 포함될 수 있습니다. 사용자 측의 콘텐츠 요청은 가장 가까운 엣지 로케이션으로 자동 라우팅되어 성능이 향상됩니다.
Amazon Cloud-front는 Amazon S3 및 Amazon EC2와 같은 다른 Amazon Web Services와 함께 작동하도록 최적화되어 있습니다. 또한 비 AWS 오리진 서버에서도 잘 작동하며 유사한 방식으로 원본 파일을 저장합니다.
Amazon Web Services에는 계약이나 월간 약정이 없습니다. 우리는 서비스를 통해 제공하는만큼의 콘텐츠에 대해서만 비용을 지불합니다.
Elastic Load Balancer
트래픽을 웹 서버로 분산하여 성능을 향상시키는 데 사용됩니다. AWS는 트래픽이 사용 가능한 여러 영역에 걸쳐 EC2 인스턴스로 분산되고로드 밸런싱 순환에서 Amazon EC2 호스트를 동적으로 추가 및 제거하는 Elastic Load Balancing 서비스를 제공합니다.
Elastic Load Balancing은 트래픽 조건에 따라로드 밸런싱 용량을 동적으로 늘리거나 줄일 수 있습니다.
보안 관리
Amazon의 Elastic Compute Cloud (EC2)는 인바운드 네트워크 방화벽과 유사한 보안 그룹이라는 기능을 제공합니다.이 기능은 EC2 인스턴스에 도달 할 수있는 프로토콜, 포트 및 소스 IP 범위를 지정해야합니다.
각 EC2 인스턴스에는 하나 이상의 보안 그룹이 할당 될 수 있으며, 각 그룹은 적절한 트래픽을 각 인스턴스로 라우팅합니다. 보안 그룹은 EC2 인스턴스에 대한 액세스를 제한하는 특정 서브넷 또는 IP 주소를 사용하여 구성 할 수 있습니다.
탄력적 캐시
Amazon Elastic Cache는 클라우드에서 메모리 캐시를 관리하는 웹 서비스입니다. 메모리 관리에서 캐시는 매우 중요한 역할을하며 서비스에 대한 부하를 줄이는 데 도움이되며 자주 사용되는 정보를 캐싱하여 데이터베이스 계층의 성능과 확장 성을 향상시킵니다.
아마존 RDS
Amazon RDS (관계형 데이터베이스 서비스)는 MySQL, Oracle 또는 Microsoft SQL Server 데이터베이스 엔진과 유사한 액세스를 제공합니다. Amazon RDS에서 동일한 쿼리, 애플리케이션 및 도구를 사용할 수 있습니다.
데이터베이스 소프트웨어를 자동으로 패치하고 사용자의 지시에 따라 백업을 관리합니다. 또한 특정 시점 복구를 지원합니다. 사전 투자가 필요하지 않으며 사용하는 리소스에 대해서만 비용을 지불합니다.
EC2 인스턴스에서 RDMS 호스팅
Amazon RDS를 사용하면 사용자가 MySQL, Oracle, SQL Server, DB2 등과 같이 선택한 RDBMS (Relational Database Management System)를 EC2 인스턴스에 설치할 수 있으며 필요에 따라 관리 할 수 있습니다.
Amazon EC2는 네트워크 연결 스토리지와 유사한 Amazon EBS (Elastic Block Storage)를 사용합니다. EC2 인스턴스에서 실행되는 모든 데이터와 로그는 Amazon EBS 볼륨에 배치되어야하며 데이터베이스 호스트가 실패하더라도 사용할 수 있습니다.
Amazon EBS 볼륨은 가용 영역 내에서 자동으로 중복성을 제공하여 단순 디스크의 가용성을 높입니다. 또한 볼륨이 데이터베이스 요구 사항에 충분하지 않은 경우 볼륨을 추가하여 데이터베이스 성능을 높일 수 있습니다.
Amazon RDS를 사용하여 서비스 제공 업체는 스토리지를 관리하고 데이터 관리에만 집중합니다.
저장 및 백업
AWS 클라우드는 웹 애플리케이션 데이터 및 자산을 저장, 액세스 및 백업하기위한 다양한 옵션을 제공합니다. Amazon S3 (Simple Storage Service)는 웹 어디에서든 언제든지 원하는 양의 데이터를 저장하고 검색하는 데 사용할 수있는 간단한 웹 서비스 인터페이스를 제공합니다.
Amazon S3는 데이터를 buckets. 사용자는 버킷 내에 요구 사항에 따라 많은 객체를 저장할 수 있으며 버킷에서 객체를 읽고, 쓰고, 삭제할 수 있습니다.
Amazon EBS는 블록 스토리지로 액세스해야하는 데이터에 효과적이며 데이터베이스 파티션 및 애플리케이션 로그와 같이 실행중인 인스턴스의 수명을 초과하는 지속성이 필요합니다.
Amazon EBS 볼륨은 최대 1TB까지 최대화 할 수 있으며 이러한 볼륨은 더 큰 볼륨과 성능 향상을 위해 스트라이핑 될 수 있습니다. 프로비저닝 된 IOPS 볼륨은 스토리지 성능 및 일관성에 민감한 데이터베이스 워크로드의 요구 사항을 충족하도록 설계되었습니다.
Amazon EBS는 현재 볼륨 당 최대 1,000 IOPS를 지원합니다. 여러 볼륨을 함께 스트라이프하여 애플리케이션에 인스턴스 당 수천 IOPS를 제공 할 수 있습니다.
Auto Scaling
AWS 클라우드 아키텍처와 기존 호스팅 모델의 차이점은 AWS가 트래픽 변화를 처리하기 위해 필요에 따라 웹 애플리케이션 집합을 동적으로 확장 할 수 있다는 것입니다.
기존 호스팅 모델에서 트래픽 예측 모델은 일반적으로 예상 트래픽보다 먼저 호스트를 프로비저닝하는 데 사용됩니다. AWS에서 인스턴스는 집합을 확장 및 축소하기위한 일련의 트리거에 따라 즉시 프로비저닝 될 수 있습니다. Amazon Auto Scaling은 필요에 따라 확장 또는 축소 할 수있는 서버의 용량 그룹을 생성 할 수 있습니다.
AWS의 웹 호스팅에 대한 주요 고려 사항
다음은 웹 호스팅에 대한 몇 가지 주요 고려 사항입니다.
물리적 네트워크 장치가 필요하지 않습니다.
AWS에서 방화벽, 라우터 및 AWS 애플리케이션 용로드 밸런서와 같은 네트워크 장치는 더 이상 물리적 장치에 상주하지 않으며 소프트웨어 솔루션으로 대체됩니다.
고품질 소프트웨어 솔루션을 보장하기 위해 여러 옵션을 사용할 수 있습니다. 부하 분산을 위해 Zeus, HAProxy, Nginx, Pound 등을 선택합니다. VPN 연결을 설정하려면 OpenVPN, OpenSwan, Vyatta 등을 선택합니다.
보안 문제 없음
AWS는 모든 호스트가 잠겨있는보다 안전한 모델을 제공합니다. Amazon EC2에서 보안 그룹은 아키텍처의 각 호스트 유형에 대해 설계되었으며, 요구 사항에 따라 아키텍처 내의 호스트간에 최소 액세스를 가능하게하기 위해 다양한 단순 및 계층 형 보안 모델을 생성 할 수 있습니다.
데이터 센터의 가용성
EC2 인스턴스는 AWS 리전의 대부분의 가용 영역에서 쉽게 사용할 수 있으며 고 가용성 및 안정성을 위해 데이터 센터에 애플리케이션을 배포하기위한 모델을 제공합니다.