데이터 센터에서 서버의 자원과 공간, 및 네트워크 환경을 제공한다.
현대의 클라우드 컴퓨팅은 앞서 설명한 데이터 센터와 비슷한 역할을 하지만,
물리적인 컴퓨터가 아닌, 가상 컴퓨터를 대여한다는 점이 다릅니다. 이는 가상화(Virtualization) 기술의 발전으로부터 비롯되었다.
클라우드는 모든 것을 서비스화하는 것을 목표로 한다.
클라우드는 모든 것을 서비스화하는 것을 목표로 한다.
SaaS (Software as a Service)
클라우드 제공자가 당장 사용 가능한 소프트웨어를 제공하는 경우 대부분 SaaS에 해당
PaaS (Platform as a Service)
클라우드 제공자가 데이터베이스, 개발 플랫폼까지 제공하는 경우 대부분 PaaS에 해당
IaaS (Infrastructure as a Service)
클라우드 제공자가 가상 컴퓨터까지 제공하는 경우 대부분 IaaS에 해당.
(우리가 사용할 AWS는 IaaS에 가깝다.)
EC2란 아마존 웹 서비스에서 제공하는 클라우드 컴퓨팅 서비스
클라우드 컴퓨팅은 인터넷(클라우드)을 통해 서버, 스토리지, 데이터베이스 등의 컴퓨팅 서비스를 제공하는 서비스다.
- 사용한 만큼비용을 지불한다.
- EC2 서비스는 AWS에서 비용, 성능, 용량 면에서 탄력적인 클라우드 컴퓨터를 제공하는 서비스이다.
EC2는 컴퓨터를 한 대 빌리는 것이므로 컴퓨터로 할 수 있는 모든 일을 할 수 있다.
아마존 EC2를 통해서 할 수 있는 가장 기본적인 일은
웹서버를 설치하고 웹 서버를 통해서 사용자가 웹 브라우저를 통해 요청하는 서비스를 제공하는 것이다.
AMI는 인스턴스를 생성하는데 필요한 소프트웨어 구성이 기재된 템플릿이다.
즉,
AWS EC2 인스턴스를 생성한다는 것은
AMI를 토대로 운영체제, CPU, RAM 혹은 런타임 등이 구성된 컴퓨터를 빌리는 것이다.
AWS에서 제공하는 관계형 데이터베이스 서비스
RDS를 이용하면 데이터베이스 유지 보수와 관련된 일들을 RDS에서 전적으로 자동 관리한다.
사용자가 해야 할 일은 초기 설정을 제외하고 데이터베이스에 저장된 데이터를 관리하는 일 밖에 없기에 큰 편의성을 느낄 수 있다.
다양한 데이터베이스 엔진 선택지를 제공한다.
AWS에서 제공하는 클라우드 스토리지 서비스
클라우드 스토리지란 쉽게 말해 인터넷 공간에 데이터를 저장하는 저장소이다.
클라우드 스토리지 서비스는 뛰어난 접근성을 가지고 있다.
클라우드 스토리지를 이용하면 웹 환경이라면 언제 어디서나 저장된 파일에 접근할 수 있다.
컴퓨터뿐만 아니라 웹에 접속이 가능한 다른 전자기기를 활용하여 클라우드 스토리지에 저장된 데이터에 접속할 수 있다.
높은 확장성
확장성이 높으면 많은 시간과 수고를 들이지 않고 스토리지 규모를 확장/축소할 수 있다.
또한 S3에서는 스토리지의 용량을 무한히 확장할 수 있다.
그리고 사용한 만큼만 비용을 지불하면 되기 때문에 비용적인 측면에서 매우 효율적이다.
강한 내구성을 가졌다.
가용성이 높다.
리전(Region):AWS에서 클라우드 서비스를 제공하기 위해서 운영하는 물리적인 서버의 위치
가용 영역(Availability Zone): 각 리전 안에 존재하는 데이터 센터(IDC)
가용 영역은 각각 개별적인 위치에 떨어져서 존재
그래서 한 곳의 가용 영역이 재난이나 사고로 인해 가동이 불가능해지더라도 다른 가용 영역에 백업을 해놓은 데이터를 활용하여 문제없이 서버가 가동되게 하므로 이런 가동 방식 덕분에 AWS에서 제공하는 서비스들은 높은 가용성과 내구성을 보장한다.
다양한 스토리지 클래스를 제공
저장소를 어떤 목적으로 활용할지에 따라 효율적으로 선택할 수 있는 스토리지 클래스가 달라진다.
대표적인 스토리지 클래스
정적 웹 사이트 호스팅이 가능하다.
정적 파일: 서버의 개입 없이 클라이언트에 제공될 수 있는 파일
웹 호스팅: 서버의 한 공간을 빌려주어 웹 사이트의 배포, 운영이 가능하게 만들어 주는 서비스
S3 에서는 버킷을 통해 정적 웹사이트 호스팅이 가능.
버킷
S3에 저장되는 파일들이 담기는 바구니이며 파일을 저장하는 최상위 디렉터리라고도 할 수 있다.
S3에서 저장되는 모든 파일은 버킷 안에 저장되어야 하고, 버킷에는 무한한 양의 파일(객체)을 저장할 수 있다.
각각의 버킷은 이름을 가지고 있는데, 버킷의 이름은 버킷이 속해 있는 리전(버킷이 생성된 지역)에서 유일해야 있다.
또한 버킷 정책을 생성하여 해당 버킷에 대한 다른 유저의 접근 권한을 수정할 수 있다.
객체
S3에서 버킷에 담기는 파일을 객체라고 한다.
S3에 저장되는 객체는 파일과 메타데이터로 구성된다.
모든 객체는 고유한 키를 가진다.
URL 주소를 통해 객체에 접근이 가능하다.
URL 주소형식 http://[버킷의 이름].S3.amazonaws.com/[객체의 키]
AWS에서 제공하는 서비스인 S3라는 서비스를 통해 사용자들에게 Client를 제공할 수 있다.
클라이언트 앱을 정적 파일로 빌드하여 제공하는 것이다.
클라이언트를 위해서 EC2 인스턴스를 사용하지 않아도 된다.
AWS EC2 서비스를 통해 서버를 구성하고 서비스를 제공할 수 있다.
RDS 서비스를 이용하여 EC2를 통해 배포된 Server Application의 데이터를 저장, 제공하는 데이터베이스를 배포할 수 있다.
AWS에서 제공하는 Route 53 서비스를 이용하면
직관적인 도메인 주소를 통해서 서비스에 접근하도록 할 수 있다
기본적으로 4단계를 거쳐서 개발한 서비스를 배포
배포에서는, 환경의 차이를 이해하고 환경 설정을 코드와 분리하는 것이 중요
.env
등을 이용해 환경 변수를 설정하자