Ⅰ. CDN 기술이란?
콘텐츠 전송 네트워크(CDN)는 데이터 사용량이 많은 애플리케이션의 웹 페이지 로드 속도를 높이는 상호 연결된 서버 네트워크입니다. CDN은 콘텐츠 전송 네트워크 또는 콘텐츠 배포 네트워크를 의미할 수 있습니다. 사용자가 웹 사이트를 방문할 때 해당 웹 사이트 서버의 데이터는 사용자의 컴퓨터에 도달하기 위해 인터넷을 통해 이동해야 합니다. 사용자가 해당 서버에서 멀리 떨어져 있는 경우 동영상 또는 웹 사이트 이미지와 같은 대용량 파일을 로드하는 데 시간이 오래 걸립니다. 대신 웹 사이트 콘텐츠는 지리적으로 사용자와 가까운 CDN 서버에 저장되며 컴퓨터에 훨씬 빨리 도달합니다.
Ⅱ. CDN 기술의 목적
콘텐츠 전송 네트워크(CDN)의 주 목적은 대기 시간을 줄이거나 네트워크 설계로 인해 발생하는 통신 지연을 줄이는 것입니다. 인터넷의 글로벌하고 복잡한 특성으로 인해 웹 사이트(서버)와 사용자(클라이언트) 간의 통신 트래픽은 아주 먼 물리적 거리를 이동해야 합니다. 또한 클라이언트에서 서버로 요청을 보내고 응답을 반환하는 양방향 통신입니다.
CDN은 클라이언트와 웹 사이트 서버 간에 중간 서버를 두어 효율성을 높입니다. 이러한 CDN 서버는 클라이언트-서버 통신의 일부를 관리합니다. 웹 서버에 대한 웹 트래픽을 줄이고, 대역폭 소비를 줄이며, 애플리케이션의 사용자 환경을 개선합니다.
Ⅲ. CDN 기술의 특징
콘텐츠 전송 네트워크(CDN)는 웹 사이트 성능을 높이고 핵심 네트워크 인프라를 지원하며 특징은 다음과 같습니다..
ⅰ) 페이지 로드 시간(캐싱) 단축
페이지 로드 시간이 너무 느리면 웹 사이트 트래픽이 감소할 수 있습니다. CDN은 반송률을 줄이고 사용자가 사이트에서 보내는 시간을 늘릴 수 있습니다.
ⅱ) 대역폭 비용 절감(로드 밸런싱)
들어오는 모든 웹 사이트 요청은 네트워크 대역폭을 사용하기 때문에 대역폭 비용이 상당히 높습니다. 캐싱 및 기타 최적화를 통해 CDN은 오리진(Origin Server) 서버가 제공해야 하는 데이터의 양을 줄여 웹 사이트 소유자의 호스팅 비용을 절감할 수 있습니다.
ⅲ) 콘텐츠 가용성 제고
한 번에 너무 많은 방문자가 방문하거나 네트워크 하드웨어 오류가 발생하면 웹 사이트가 중단될 수 있습니다. CDN 서비스는 더 많은 웹 트래픽을 처리하고 웹 서버의 로드를 줄일 수 있습니다. 또한 하나 이상의 CDN 서버가 오프라인으로 전환되면 다른 운영 서버가 해당 서버를 대체하여 서비스가 중단되지 않도록 할 수 있습니다.
ⅳ) 웹 사이트 보안 강화
분산 서비스 거부(DDoS) 공격은 대량의 가짜 트래픽을 웹 사이트로 전송하여 애플리케이션이 작동 중지되도록 만들려고 시도합니다. CDN은 여러 중간 서버 간에 로드를 분산하여 오리진(Origin Server) 서버에 미치는 영향을 줄임으로써 이러한 트래픽 급증을 처리할 수 있습니다.
Ⅳ. CDN 기술의 역사
콘텐츠 전송 네트워크(CDN) 기술은 1990년대 후반에 인터넷을 통한 더 빠른 콘텐츠 전송에 중점을 두고 등장했습니다.
ⅰ) 1세대 CDN: 초기 CDN은 단순히 콘텐츠를 전 세계적으로 복제하고 전달하는 것이 주요 목적이었습니다. 이러한 CDN은 캐시 서버를 이용하여 콘텐츠를 저장하고 사용자의 요청에 따라 해당 캐시 서버에서 콘텐츠를 제공했습니다. 하지만 이러한 CDN은 캐시 미스(cache miss) 문제와 같은 제약이 있었습니다.
ⅱ) 2세대 CDN: 2세대 CDN은 캐싱과 로드 밸런싱을 개선하고 보안 및 성능 최적화를 강화하는 등 여러 가지 기능을 추가하여 진화했습니다. 또한 동적 콘텐츠를 효율적으로 처리하기 위한 기술도 도입되었습니다.
ⅲ) 3세대 CDN: 3세대 CDN은 기존 CDN의 한계를 극복하고 새로운 기술적 도전에 대응하기 위해 발전했습니다.
1) 인텔리전트 콘텐츠 배포(Intelligent Content Delivery): 3세대 CDN은 인공지능과 머신러닝 기술을 활용하여 사용자의 행동 및 네트워크 조건에 따라 최적의 콘텐츠 전달을 제공합니다. 이를 통해 콘텐츠 제공 속도를 높이고 사용자 경험을 개선합니다.
2) 엣지 컴퓨팅(Edge Computing): 3세대 CDN은 엣지 서버를 이용하여 콘텐츠를 가까운 곳에서 처리하고 제공함으로써 지연 시간을 최소화하고 네트워크 트래픽을 줄입니다. 이는 IoT(Internet of Things) 및 현지화된 서비스에 특히 유용합니다.
3) 보안 및 개인정보 보호 강화: 3세대 CDN은 보안 기능을 더욱 강화하여 DDoS 공격 및 기타 네트워크 공격으로부터 콘텐츠를 보호합니다. 또한 개인정보 보호에 중점을 두고 GDPR 및 기타 규정을 준수합니다.
다양한 콘텐츠 형식 지원: 3세대 CDN은 다양한 콘텐츠 형식을 지원하여 비디오, 오디오, 스트리밍 미디어 등을 효율적으로 처리할 수 있습니다.
Ⅴ. CDN을 통해 전송할 수 있는 콘텐츠는?
콘텐츠 전송 네트워크(CDN)는 정적 콘텐츠와 동적 콘텐츠의 두 가지 유형의 콘텐츠를 전송할 수 있습니다.
ⅰ) 정적 콘텐츠
정적 콘텐츠는 사용자 간에 변경되지 않는 웹 사이트 데이터입니다. 웹 사이트 헤더 이미지, 로고 및 글꼴 스타일은 모든 사용자에게 동일하게 유지되며 기업이 자주 변경하지 않습니다. 정적 데이터는 수정, 처리 또는 생성할 필요가 없으며 CDN에 저장하는 데 이상적입니다.
ⅱ) 동적 콘텐츠
소셜 미디어 뉴스 피드, 날씨 보고서, 로그인 상태 및 채팅 메시지와 같은 동적 콘텐츠는 웹 사이트 사용자마다 다릅니다. 이 데이터는 사용자의 위치, 로그인 시간 또는 사용자 기본 설정에 따라 변경되며 웹 사이트는 모든 사용자와 모든 사용자 상호 작용에 대한 데이터를 생성해야 합니다.
Ⅵ. CDN 기술의 동작 방식
콘텐츠 전송 네트워크(CDN)는 여러 지리적 위치에 접속 지점(POP) 또는 CDN 엣지 서버 그룹을 설정하는 방식으로 작동합니다. 지리적으로 분산된 이 네트워크는 캐싱, 동적 가속 및 엣지 로직 계산의 원리를 기반으로 작동합니다.
ⅰ) 캐싱
캐싱은 더 빠른 데이터 액세스를 위해 동일한 데이터의 여러 복사본을 저장하는 프로세스입니다. 컴퓨팅에서 캐싱의 원리는 모든 유형의 메모리 및 스토리지 관리에 적용됩니다. CDN 기술에서 이 용어는 네트워크의 여러 서버에 정적 웹 사이트 콘텐츠를 저장하는 프로세스를 의미합니다.
CDN에서 캐싱은 다음과 같이 작동합니다. 지리적으로 멀리 떨어진 웹 사이트 방문자는 사이트에서 정적 웹 콘텐츠를 처음 요청합니다. 요청이 웹 애플리케이션 서버 또는 오리진(Origin Server) 서버에 도달합니다. 오리진(Origin Server) 서버는 원격 방문자에게 응답을 보냅니다. 또한 해당 방문자와 지리적으로 가장 가까운 CDN POP에 응답 복사본을 보냅니다. CDN POP 서버는 복사본을 캐싱된 파일로 저장합니다. 다음에 해당 방문자 또는 해당 위치에 있는 다른 방문자가 동일한 요청을 하면, 오리진(Origin Server) 서버가 아닌 캐싱 서버가 응답을 보냅니다. |
ⅱ) 동적 가속
동적 가속은 웹 애플리케이션과 클라이언트 사이의 중개 CDN 서버로 인해 발생하는 동적 웹 콘텐츠 요청에 대한 서버 응답 시간을 단축하는 것입니다. 사용자 요청이 있을 때마다 콘텐츠가 변경될 수 있기 때문에 동적 웹 콘텐츠에서는 캐싱이 제대로 작동하지 않습니다. CDN 서버는 모든 동적 요청에 대해 오리진(Origin Server) 서버와 다시 연결해야 하지만 자신과 오리진(Origin Server) 서버 간의 연결을 최적화하여 프로세스를 가속화합니다.
클라이언트가 인터넷을 통해 웹 서버로 직접 동적 요청을 보내는 경우 네트워크 지연 시간으로 인해 요청이 손실되거나 지연될 수 있습니다. 보안 검증을 위해 연결을 열고 닫는 데에도 시간이 걸릴 수 있습니다. 반면, 근처의 CDN 서버가 요청을 오리진(Origin Server) 서버로 전달할 경우, 신뢰할 수 있는 지속적인 연결이 이미 설정되었을 것입니다. 예를 들어 다음과 같은 기능을 통해 이들 간의 연결을 더욱 최적화할 수 있습니다.
1) 지능형 라우팅 알고리즘
2) 오리진(Origin Server)에 대한 지리적 근접성
3) 클라이언트 요청을 처리할 수 있으므로 클라이언트 요청을 줄일 수 있습니다.
엣지 로직 계산 클라이언트와 서버 간의 통신을 단순화하는 논리적 계산을 수행하도록 CDN 에지 서버를 프로그래밍할 수 있습니다. 예를 들어 이 서버는 다음을 수행할 수 있습니다. - 사용자 요청을 검사하고 캐싱 동작을 수정합니다. - 잘못된 사용자 요청을 확인하고 처리합니다. - 응답하기 전에 콘텐츠를 수정하거나 최적화합니다. - 웹 서버와 네트워크 엣지 간에 애플리케이션 로직을 배포하면 개발자가 오리진(Origin Server) 서버의 컴퓨팅 요구 사항을 오프로드하고 웹 사이트 성능을 높이는 데 도움이 됩니다 |
Ⅶ. CDN은 무엇에 사용되나요?
콘텐츠 전송 네트워크(CDN)는 일반적인 웹 사이트 기능을 개선하며, 개선 가능한 항목은 다음과 같습니다.
ⅰ) 고속 콘텐츠 전송 : 정적 및 동적 인터넷 콘텐츠 전송을 결합하여 CDN을 사용하여 고객에게 글로벌 고성능 전체 사이트 환경을 제공할 수 있습니다.
ⅱ) 실시간 스트리밍 : CDN은 고품질의 풍부한 미디어 파일을 안정적이고 비용 효율적으로 제공할 수 있도록 지원합니다. 비디오 및 오디오를 스트리밍하는 기업은 CDN을 사용하여 대역폭 비용 절감, 확장성 향상, 제공 시간 단축이라는 세 가지 과제를 해결합니다.
ⅲ) 다중 사용자 확장 : CDN은 다수의 동시 사용자를 지원하는 데 도움이 됩니다. 웹 사이트 리소스는 한 번에 제한된 수의 클라이언트 연결만 관리할 수 있습니다. CDN은 애플리케이션 서버에서 로드 일부를 가져옴으로써 이 수를 빠르게 확장할 수 있습니다.
'어플리케이션' 카테고리의 다른 글
Windows Server 이 VM Workstation 에서 설치 되지 않을 때 조치 방법 (0) | 2024.05.13 |
---|---|
CDR(Content Disarm&Reconstruction) 에 대해 알아보겠습니다. (0) | 2024.05.09 |
Grafana와 Prometheus 에 대해 알아보겠습니다. (0) | 2024.05.03 |
Zabbix 에 대해 알아보겠습니다. (0) | 2024.05.02 |
openSSL로 생성한 인증서를 Apache 웹 서버에 적용하는 방법 (0) | 2024.04.05 |