KR101574074B1 - 클라우드 cdn 시스템 및 이를 이용한 컨텐츠 제공방법 - Google Patents
클라우드 cdn 시스템 및 이를 이용한 컨텐츠 제공방법 Download PDFInfo
- Publication number
- KR101574074B1 KR101574074B1 KR1020140080524A KR20140080524A KR101574074B1 KR 101574074 B1 KR101574074 B1 KR 101574074B1 KR 1020140080524 A KR1020140080524 A KR 1020140080524A KR 20140080524 A KR20140080524 A KR 20140080524A KR 101574074 B1 KR101574074 B1 KR 101574074B1
- Authority
- KR
- South Korea
- Prior art keywords
- server
- cdn
- edge server
- group
- edge
- Prior art date
Links
- 238000000034 method Methods 0.000 title claims abstract description 22
- 238000005259 measurement Methods 0.000 claims abstract description 15
- 230000008878 coupling Effects 0.000 claims 3
- 238000010168 coupling process Methods 0.000 claims 3
- 238000005859 coupling reaction Methods 0.000 claims 3
- 230000006870 function Effects 0.000 description 8
- 238000010586 diagram Methods 0.000 description 2
- 230000000295 complement effect Effects 0.000 description 1
- 229960005486 vaccine Drugs 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q50/00—Information and communication technology [ICT] specially adapted for implementation of business processes of specific business sectors, e.g. utilities or tourism
- G06Q50/10—Services
Landscapes
- Business, Economics & Management (AREA)
- Tourism & Hospitality (AREA)
- Health & Medical Sciences (AREA)
- Economics (AREA)
- General Health & Medical Sciences (AREA)
- Human Resources & Organizations (AREA)
- Marketing (AREA)
- Primary Health Care (AREA)
- Strategic Management (AREA)
- Physics & Mathematics (AREA)
- General Business, Economics & Management (AREA)
- General Physics & Mathematics (AREA)
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Information Transfer Between Computers (AREA)
Abstract
본 발명은 클라우드 CDN 시스템 및 이를 이용한 컨텐츠 제공방법에 관한 것이다. 본 발명에 따른 클라우드 CDN 시스템은 복수의 CDN 서버에 저장된 컨텐츠의 복사본 또는 상기 CDN 서버에서 내부 CDN 서버에 업로드된 컨텐츠의 복사본을 상기 CDN 서버의 도메인을 통하여 접속된 복수의 엔드 유저에게 제공하는 복수의 에지 서버 그룹 및 상기 복수의 에지 서버 그룹으로부터 헬스 정보를 수집하고, 상기 헬스 정보에 포함되는 측정 값 중에서 하나 이상이 기준 값을 초과하는 제1 에지 서버 그룹이 검출되면, 상기 헬스 정보에 포함되는 측정 값이 가장 작은 제2 에지 서버을 선택하여 상기 제1 에지 서버 그룹에 연결된 CDN 서버 또는 내부 CDN 서버를 상기 제2 에지 서버 그룹에 포함되는 적어도 하나의 에지 서버와 추가적으로 연결하는 제어 모듈을 포함한다.
이와 같이 본 발명에 따르면, 다수의 엔드 유저의 접속으로 컨텐츠 데이터 트래픽이 하나의 노드에 집중되는 트래픽 부하를 줄일 수 있다. 또한, 에지 서버 그룹의 헬스 정보를 이용하여 CDN 서비스의 종류에 따른 최적화된 에지 서버 그룹을 선택할 수 있다.
이와 같이 본 발명에 따르면, 다수의 엔드 유저의 접속으로 컨텐츠 데이터 트래픽이 하나의 노드에 집중되는 트래픽 부하를 줄일 수 있다. 또한, 에지 서버 그룹의 헬스 정보를 이용하여 CDN 서비스의 종류에 따른 최적화된 에지 서버 그룹을 선택할 수 있다.
Description
본 발명은 클라우드 CDN 시스템 및 이를 이용한 컨텐츠 제공방법에 관한 것으로서, 더욱 상세하게는 클라우드 CDN 환경에서 에지 서버를 이용하여 엔드 유저에게 컨텐츠를 제공하는 시스템 및 그 방법에 관한 것이다.
클라우드는 확장성이 뛰어난 인터넷 아키텍처를 구축하고자 하는 기존 개념을 보완 강화하는 한편, 애플리케이션들의 구축 및 배치 방법을 전혀 새롭게 바꾸고자 하는 새로운 개념을 도입한다. 따라서 클라우드의 특징인 확장 가능한 인프라의 혜택을 누리기 위해서는 확장 가능한 아키텍처의 구축이 중요하다.
인터넷에서 컨텐츠를 이용하는 엔드 유저들이 늘어날수록 웹 다운로드와 비디오 및 오디오 다운로드의 속도 저하 문제 등 서비스 품질이 이슈가 되고 있다. 이러한 문제를 해결하기 위해 도입된 방법 중 하나가 CDN(Content Delivery Network) 기술이다. CDN은 그래픽 이미지, 플래시 파일 등 웹 컨텐츠의 빠른 전송에 유용하다는 장점에 따라 온라인 동영상이나 음악 스트리밍, 파일 다운로드 등 대용량 파일 전송과 이미지가 많은 쇼핑몰이나 포털, 게임, 검색 사이트에서 안정적인 이미지를 보여주게 하기 위해 이용되고 있으며, 그 시장 또한 확대되는 추세이다.
그런데 CDN 기술에 있어서도 네트워크의 최종 말단에서 엔드 유저에게 컨테츠를 제공하는 에지(Edge) 서버의 아키텍처 구축에 있어서, 엔드 유저의 접속 회선의 증감에 따른 아키텍처의 확장성이 문제가 될 수 있다. 이를 해결하기 위해 최근의 클라우드 기술을 접목한 클라우드 CDN 시스템에 관한 기술의 도입이 절실하다.
본 발명의 배경이 되는 기술은 대한민국 공개특허공보 제2012-0078764호(2012.07.11 공개)에 기재되어 있다.
본 발명이 해결하고자 하는 과제는, 클라우드 CDN 환경에서 에지 서버를 이용하여 엔드 유저에게 컨텐츠를 제공하는 시스템 및 그 컨텐츠 제공방법을 제공하는 것이다.
상기한 바와 같은 목적을 달성하기 위한 본 발명의 하나의 실시예에 따르면, 클라우드 CDN 시스템은 복수의 CDN 서버에 저장된 컨텐츠의 복사본 또는 상기 CDN 서버에서 내부 CDN 서버에 업로드된 컨텐츠의 복사본을 상기 CDN 서버의 도메인을 통하여 접속된 복수의 엔드 유저에게 제공하는 복수의 에지 서버 그룹 및 상기 복수의 에지 서버 그룹으로부터 헬스 정보를 수집하고, 상기 헬스 정보에 포함되는 측정 값 중에서 하나 이상이 기준 값을 초과하는 제1 에지 서버 그룹이 검출되면, 상기 헬스 정보에 포함되는 측정 값이 가장 작은 제2 에지 서버 그룹을 선택하여 상기 제1 에지 서버 그룹에 연결된 CDN 서버 또는 내부 CDN 서버를 상기 제2 에지 서버 그룹에 포함되는 적어도 하나의 에지 서버와 추가적으로 연결하는 제어 모듈을 포함한다.
또한, 상기 제어 모듈은, 상기 제1 에지 서버 그룹에 연결된 CDN 서버 또는 내부 CDN 서버를 상기 제2 에지 서버 그룹에 포함되는 적어도 하나의 에지 서버와 연결하여 상기 제1 에지 서버 그룹이 엔드 유저에게 제공하는 컨텐츠를 상기 제2 에지 서버 그룹에 포함되는 적어도 하나의 에지 서버가 상기 엔드 유저에게 제공하도록 할 수 있다.
또한, 상기 헬스 정보는, 상기 에지 서버 그룹의 CPU 사용량, 메모리 사용량, 상기 에지 서버 그룹에 연결된 세션의 수 및 상기 에지 서버 그룹의 트래픽 양 중에서 적어도 하나를 포함할 수 있다.
또한, 상기 복수의 CDN 서버는, 컨텐츠 제공 서비스의 유형에 따라 캐쉬 서버, 다운로드 서버, VOD 서버 및 LIVE 서버로 그룹핑될 수 있다.
또한, 상기 제어 모듈은, 상기 제1 에지 서버 그룹에게 할당된 상기 CDN 서버의 도메인을 통하여 상기 CDN 서버의 형태를 판단하고, 상기 CDN 서버와 동일한 그룹에 속하는 다른 CDN 서버와 연결된 에지 서버 그룹 중에서 상기 헬스 정보에 해당하는 측정 값이 가장 작은 상기 제2 에지 서버 그룹을 선택할 수 있다.
또한, 상기 제어 모듈은, 상기 CDN 서버가 캐쉬 서버 형태인 경우, 상기 헬스 정보 중에서 세션의 수를 기준 값과 비교하여 상기 제1 에지 서버 그룹을 검출하고, 상기 CDN 서버가 다운로드 서버, VOD 서버 및 LIVE 서버 중에서 어느 하나의 형태인 경우, 상기 헬스 정보 중에서 트래픽 양을 기준 값과 비교하여 상기 제1 에지 서버 그룹을 검출할 수 있다.
본 발명의 하나의 실시예에 따르면, 복수의 에지 서버 그룹과 제어 모듈을 포함하는 클라우드 CDN 시스템을 이용한 컨텐츠 제공방법은, 복수의 에지 서버 그룹이 복수의 CDN 서버에 저장된 컨텐츠의 복사본 또는 상기 CDN 서버에서 내부 CDN 서버에 업로드된 컨텐츠의 복사본을 상기 CDN 서버의 도메인을 통하여 접속된 복수의 엔드 유저에게 제공하는 단계 및 제어 모듈이 상기 복수의 에지 서버 그룹으로부터 헬스 정보를 수집하고, 상기 헬스 정보에 포함되는 측정 값 중에서 하나 이상이 기준 값을 초과하는 제1 에지 서버 그룹이 검출되면, 상기 헬스 정보에 포함되는 측정 값이 가장 작은 제2 에지 서버 그룹을 선택하여 상기 제1 에지 서버 그룹에 연결된 CDN 서버 또는 내부 CDN 서버를 상기 제2 에지 서버 그룹과 연결하는 단계를 포함한다.
본 발명인 클라우드 CDN 시스템 및 이를 이용한 컨텐츠 제공방법에 따르면, 다수의 엔드 유저의 접속으로 컨텐츠 데이터 트래픽이 하나의 노드에 집중되는 트래픽 부하를 줄일 수 있다. 또한, 에지 서버 그룹의 헬스 정보를 이용하여 CDN 서비스의 종류에 따른 최적화된 에지 서버 그룹을 선택할 수 있다.
도 1은 본 발명의 하나의 실시예에 따른 클라우드 CDN 시스템을 포함하는 전체 네트워크 구성도이다.
도 2는 본 발명의 하나의 실시예에 따른 클라우드 CDN 시스템을 이용한 컨텐츠 제공방법의 순서도이다.
도 3은 도 2에서 설명한 컨텐츠를 제공하는 에지 서버를 추가하는 제어 모듈과 관련된 상세 순서도이다.
도 2는 본 발명의 하나의 실시예에 따른 클라우드 CDN 시스템을 이용한 컨텐츠 제공방법의 순서도이다.
도 3은 도 2에서 설명한 컨텐츠를 제공하는 에지 서버를 추가하는 제어 모듈과 관련된 상세 순서도이다.
이하에서는 첨부한 도면을 참조하여 본 발명이 속하는 기술 분야에서 통상의 지식을 가진 자가 용이하게 실시할 수 있도록 본 발명의 실시예를 상세히 설명한다. 그러나 본 발명은 여러 가지 상이한 형태로 구현될 수 있으며 여기에서 설명하는 실시예에 한정되지 않는다. 그리고 도면에서 본 발명을 명확하게 설명하기 위해서 설명과 관계없는 부분은 생략하였으며, 명세서 전체를 통하여 유사한 부분에 대해서는 유사한 도면 부호를 붙였다.
명세서 전체에서, 어떤 부분이 다른 부분과 "연결"되어 있다고 할 때, 이는 "직접적으로 연결"되어 있는 경우뿐 아니라, 그 중간에 다른 소자를 사이에 두고 "전기적으로 연결"되어 있는 경우도 포함한다. 또한 어떤 부분이 어떤 구성요소를 "포함"한다고 할 때, 이는 특별히 반대되는 기재가 없는 한 다른 구성요소를 제외하는 것이 아니라 다른 구성요소를 더 포함할 수 있는 것을 의미하며, 하나 또는 그 이상의 다른 특징이나 숫자, 단계, 동작, 구성요소, 부분품 또는 이들을 조합한 것들의 존재 또는 부가 가능성을 미리 배제하지 않는 것으로 이해되어야 한다.
이하 첨부된 도면을 참고하여 본 발명을 상세히 설명하기로 한다.
도 1은 본 발명의 하나의 실시예에 따른 클라우드 CDN 시스템을 포함하는 전체 네트워크 구성도이다.
도 1에 나타낸 것처럼, 본 발명의 실시예에 따른 전체 네트워크는 클라우드 CDN 시스템(100), 복수의 CDN 서버(200) 및 엔드 유저(End User)(300)를 포함한다.
먼저 본 발명의 하나의 실시예에 따른 클라우드 CDN 시스템(100)은 복수의 에지 서버 그룹(110) 및 제어 모듈(120)을 포함하며, 경우에 따라서 내부 CDN(130) 서버를 포함할 수 있다. 여기서, 하나의 에지 서버 그룹(110)은 GLB(Global Load Balancer)라는 기능에 의해 트래픽을 분산하여 컨텐츠 서비스를 제공하는 복수의 에지 서버를 포함한다.
도 1에서, 복수의 CDN 서버(200)는 그 컨텐츠 서비스의 종류에 따라서 캐쉬(Cache) 서버, 다운로드(Download) 서버, VOD(Video on Demand) 서버 및 Live 서버로 분류될 수 있다. 여기서 CDN 서버(200)는 오리진(Origin) 서버로 불리기도 하며 기업체의 클라우드 CDN 시스템의 구축자 입장에서 오리진 서버는 고객측 서버에 해당한다. 이를 도 1에서 "고객 Origin"으로 표시하였다.
구체적으로 복수의 에지 서버 그룹(110)은 복수의 CDN 서버(200)에 저장된 컨텐츠의 복사본 또는 CDN 서버(200)에서 내부 CDN 서버(130)에 업로드된 컨텐츠의 복사본을 CDN 서버(200)의 도메인을 통하여 접속된 복수의 엔드 유저(300)에게 제공한다.
그리고 제어 모듈(120)은 복수의 에지 서버 그룹(110)으로부터 헬스 정보를 수집하고, 헬스 정보에 포함되는 측정 값 중에서 하나 이상이 기준 값을 초과하는 에지 서버 그룹(이하에서는 편의상 제1 에지 서버 그룹으로 지칭함)가 검출되면, 헬스 정보에 포함되는 측정 값이 가장 작은 에지 서버 그룹(이하에서는 편의상 제2 에지 서버 그룹으로 지칭함)를 선택하여 제1 에지 서버 그룹에 연결된 CDN 서버(200) 또는 내부 CDN 서버(130)를 상기 제2 에지 서버 그룹에 포함되는 적어도 하나의 에지 서버와 연결한다. 여기서, 제어 모듈(120)은 특정 에지 서버 그룹의 헬스 정보 판단에 있어서 에지 서버 그룹을 이루는 각각의 에지 서버의 트래픽을 종합하여 특정 에지 서버 그룹의 헬스 정보를 판단한다. 에지 서버 또는 에지 서버 그룹의 트래픽 판단의 기준이 되는 헬스 정보에 대해서는 후술하기로 한다.
내부 CDN 서버(130)는 CDN 서버(200)로부터 컨텐츠를 전달받고, 컨텐츠의 복사본을 에지 서버 그룹(110)에 제공한다.
그리고 엔드 유저(300)는 CDN 서버(200)에 서비스를 요청하는 사용자의 사용자 단말기에 해당한다. 도 1에 나타낸 것처럼, 엔드 유저(300)는 PC에서 실행되는 브라우져(PC Browser), Download Manager, 전용 Player 및 아이폰(iphone)이나 안드로이드(android) OS를 사용하는 단말기를 포함한다.
이하에서는 도 2를 통하여 본 발명의 실시예에 따른 클라우드 CDN 시스템(100)을 이용한 컨텐츠 제공방법에 대하여 설명한다.
도 2는 본 발명의 하나의 실시예에 따른 클라우드 CDN 시스템을 이용한 컨텐츠 제공방법의 순서도이다.
먼저 복수의 CDN 서버(200) 또는 내부 CDN 서버(130)의 컨텐츠의 복사본을 복수의 에지 서버 그룹(110)에 저장한다(S210).
클라우드 CDN 시스템(100)은 하나의 서버에서 컨텐츠를 관리하던 시스템에서 벗어나서 서비스의 종류 별로 복수의 CDN 서버(200)의 컨테츠와는 별도로 이와 연결된 복수의 에지 서버 그룹(110)에 복사본을 구비하여 복수의 엔드 유저(300)의 접속으로 발생되는 트래픽을 분산하기 위한 시스템이다. 이 경우, 복수의 에지 서버 그룹(110)은 서로 다른 ISP 측에 구축될 수 있다.
여기서 복수의 CDN 서버(200)는 컨텐츠 제공 서비스의 유형에 따라 캐쉬 서버, 다운로드 서버, VOD 서버 및 LIVE 서버로 그룹핑될 수 있다. 그리고 엔드 유저(300)에게 제공되는 서비스의 유형은 다음과 같다.
캐쉬(Cache) 서비스는 쇼핑몰, 포털, 언론사, 블로그/카페 고객에 특화된 서비스이다. 캐쉬 서비스에서의 접속 빈도가 높은 이미지, 웹페이지 등은 엔드 유저(300)의 PC, 모바일 기기에 다운로드 되지 않는다. 따라서 캐쉬 서비스는 단지 엔드 유저(300)가 PC, 모바일 기기에서 컨텐츠를 빠른 속도로 볼 수만 있도록 하는 서비스이다.
다운로드 서비스는 게임 파일, 패키지 소프트웨어, 백신 등의 대용량 컨텐츠 전송에 최적화된 서비스이다.
VOD 서비스는 파일 형태의 동영상 컨텐츠를 다수의 엔드 유저(300)에게 스트리밍 해주는 서비스이고, LIVE 서비스는 Live 컨텐츠를 다수의 엔드 유저(300)에게 실시간으로 스트리밍 해주는 서비스이다.
저장된 컨텐츠를 이용하기 위해서 엔드 유저(300)는 PC에 설치된 브라우져 또는 모바일 기기를 통해서 해당 사이트에 접속하는데, 이 경우 엔드 유저(300)는 해당 URL을 직접 입력하거나 해당 URL을 클릭하여 해당 사이트에 접속할 수 있다.
다음으로 에지 서버 그룹(110)은 컨텐츠의 복사본을 CDN 서버(200)의 도메인을 통하여 접속한 복수의 엔드 유저(300)에게 제공한다(S220). CDN 시스템(100)에서는 컨텐츠가 그 서비스의 종류에 따라 에지 서버 그룹(110)에 분산되어 저장되어 있기 때문에 엔드 유저(300)가 CDN 서버(200)의 도메인을 통하여 CDN 서버(200)에 컨텐츠를 요청하더라도, 실질적으로 컨텐츠를 제공하는 서버는 CDN 서버(200)에 저장된 컨텐츠의 복사본을 가지고 있는 에지 서버 그룹(110)이다.
기존의 시스템에서는 하나의 웹서버를 통해서 웹페이지의 브라우징에 필요한 각종 이미지, 텍스트를 제공하였다. 그러나, 각종 포털 사이트가 수행할 수 있는 서비스의 범위가 광범위하게 넓어지고, 서비스를 위한 데이터의 범위가 이미지, 텍스트에 그치지 않고 각종 다운로드 파일, 이메일 서비스에서의 대 용량의 파일 첨부 및 게임, VOD 또는 각종 중개방송 서비스에 따른 스트리밍 데이터에까지 이르게 되면서 다수의 엔드 유저(300)의 접속에 따른 컨텐츠 트래픽이 증가하게 되었다.
본 발명의 실시예에 따른 클라우드 CDN 시스템(100)은 접속 세션이 많아서 과부하로 인해 에지 서버 시스템의 아키텍처를 확장할 필요가 있는 경우에 에지 서버 그룹(110)의 아키텍처를 손쉽게 확장할 수 있는 솔루션을 제공한다. 이를 위하여, 현재 서비스의 종류에 따라 컨텐츠를 제공하고 있는 에지 서버 그룹(110)의 헬스 정보를 수집할 필요가 있다. 따라서 제어 모듈(120)은 에지 서버 그룹(110)의 헬스 정보를 수집한다.
즉, 제어 모듈(120)은 복수의 에지 서버 그룹(110)로부터 해당 에지 서버 그룹(110)의 현재의 접속 세션과 관련된 헬스 정보와, 추가적인 컨텐츠 제공 서비스가 가능한 에지 서버 그룹(110)의 헬스 정보를 수집한다(S230).
여기서 헬스 정보는 에지 서버 그룹(110)의 한계 능력 내에서 현재 접속 세션에 따른 서버의 CPU 사용량, 메모리 사용량, 에지 서버 그룹(110)에 연결된 세션의 수 및 에지 서버의 트래픽 양 중에서 적어도 하나를 포함할 수 있다.
또한, 에지 서버 그룹은(110) 크게 웹 서버, 캐쉬 서버 및 스트리밍 서버로 구분되며, 이 중에서 가장 많이 사용되는 것은 캐쉬 서버와 스트리밍 서버이다.
캐쉬 서버는 자주 요청되는 파일, 이미지, 플래시, 웹페이지 등의 컨텐츠를 캐슁하고, 예상하지 못한 트래픽 증가나 Hot Contents에 대한 분산 처리를 하며, 컨텐츠 변경시 기존 컨텐츠에 대한 자동화된 삭제 처리(Purge)기능을 수행한다. 에지 서버 그룹(110)이 캐쉬 서버인 경우에는 캐쉬 서비스, 다운로드 서비스 또는 VOD 서비스 컨테츠 제공을 위한 CDN 서버(200)에 연결될 수 있다.
스트리밍 서버는 VOD, LIVE Streaming을 위해 구축되며, 부가기능으로서 Security 기능과 Seek Control 기능을 수행하고, N-Screen 서비스를 위한 실시간 Transcoder 기능을 수행한다. 에지 서버 그룹이(110) 스트리밍 서버인 경우에는 VOD 서비스 또는 LIVE 서비스 컨텐츠 제공을 위한 CDN 서버(200)에 연결될 수 있다.
다음으로 제어 모듈(120)은 헬스 정보에 포함되는 측정 값 중에서 기준 값을 초과하는 제1 에지 서버 그룹을 검출한다(S240). 여기서, 제1 에지 서버 그룹은 총 컨텐츠 트래픽이 기준 값보다 높은 에지 서버 그룹을 나타낸다. 컨텐츠의 종류에 따른 서비스를 수행하는 각각의 에지 서버 그룹은(110) 규격에 따라 헬스 정보에 포함되는 각종 측정 값에 관한 기준 값을 갖는다. 이러한 기준 값은 에지 서버 그룹을(110) 구성하는 에지 서버의 하드웨어 규격에 따라 결정될 수 있다. 즉, 에지 서버 그룹을(110) 구성하고 있는 에지 서버의 CPU의 처리능력 및 클럭 속도, 메모리 용량, 하드디스크의 저장 용량 및 처리 속도에 따라 에지 서버 그룹(110)의 헬스 정보에 포함되는 각종 측정 값의 기준 값이 결정된다.
제어 모듈(120)은 헬스 정보에 포함되는 측정 값이 가장 작은 제2 에지 서버 그룹을 선택하다(S250). 여기서, 제2 에지 서버 그룹은 컨텐츠 트래픽의 여유 공간이 가장 많은 에지 서버 그룹을 나타낸다.
그리고, 측정되는 헬스 정보는 상설한 CPU 사용량, 메모리 사용량, 연결된 세션의 수 및 트래픽 양을 포함하며, 에지 서버 그룹(110)이 수행하는 컨텐츠 제공 서비스의 종류에 따라 세부 헬스 정보의 측정 값에 특징이 있다.
즉, 에지 서버 그룹이(110) 캐쉬 서비스를 수행하는 경우, 캐쉬 서비스와 관련된 자료의 수는 상대적으로 많은 대신 각각의 자료가 차지하는 용량이 적기 때문에, 해당 에지 서버 그룹(110)의 헬스 정보는 트래픽 양보다는 연결된 세션의 영향을 많이 받는다. 반대로, 에지 서버 그룹(110)이 다운로드 서비스, VOD 서비스 또는 LIVE 서비스를 수행하는 경우에는, 해당 서비스와 관련된 자료의 수는 상대적으로 적으나 각각의 자료가 차지하는 용량이 많기 때문에, 해당 에지 서버 그룹(110)의 헬스 정보는 연결된 세션 보다는 트래픽의 영향을 많이 받는 것이 특징이다.
여기서, 제어 모듈(120)은 해당 에지 서버 그룹(110)의 컨텐츠 제공과 관련하여 제1 에지 서버 그룹에게 할당된 CDN 서버(200)의 도메인을 통하여 CDN 서버(200)의 형태를 판단할 수 있다.
그리고, 제어 모듈은(120) 제1 에지 서버 그룹과 연결된 CDN 서버와 동일한 그룹에 속하는 다른 CDN 서버(200)와 연결된 복수의 에지 서버 그룹들 중에서 헬스 정보에 해당하는 측정 값이 가장 작은 제2 에지 서버를 선택한다.
여기서, 동일한 그룹에 속하는 CDN 서버(200)들은 동일한 컨텐츠 제공 서비스를 수행하므로, 동일 그룹에 속하는 다른 CDN 서버(200)에 연결된 에지 서버 그룹이 제2 에지 서버 그룹이 되면, 제1 에지 서버 그룹과 제2 에지 서버 그룹은 서로 동일한 서비스를 수행하게 되어 제2 에지 서버에 대한 서비스 패턴 설정이 용이하다는 장점이 있다.
다음으로 제어 모듈(120)은 제1 에지 서버 그룹에 연결된 CDN 서버(200) 또는 내부 CDN 서버(130)를 제2 에지 서버 그룹에 포함되는 적어도 하나의 에지 서버와 추가적으로 연결한다(S260). 여기서, CDN 서버(200) 또는 내부 CDN 서버(130)를 제2 에지 서버 그룹에 연결함에 있어서 GLB(Global Load Balancer) 기능이 이용될 수 있다. GLB는 CDN 기술을 위한 중요한 구성 중의 하나로서, 엔드 유저(300) 접속시 IP 주소를 체크하여 제1 에지 서버 그룹의 상태를 체크하여 사용자에게 가장 최적 상태의 제2 에지 서버 그룹으로 밸런싱하는 기능을 수행한다. 제1 에지 서버 그룹 이외에 제2 에지 서버 그룹에 포함되는 적어도 하나의 에지 서버가 추가적으로 CDN 서버 또는 내부 CDN 서버와 연결되는 경우에는, 제어 모듈(120)은 GLB를 이용하여 제1 에지서버 그룹의 에지 서버의 부하를 추가되는 제2 에지 서버 그룹에 포함되는 적어도 하나의 에지 서버에 분산시킨다.
또한, 제어 모듈(120)은 제1 에지 서버 그룹에 연결된 CDN 서버(200) 또는 내부 CDN 서버(130)를 제2 에지 서버 그룹에 포함되는 적어도 하나의 에지 서버와 연결하여 제1 에지 서버 그룹이 엔드 유저(300)에게 제공하는 컨텐츠를 제2 에지 서버 그룹에 포함되는 적어도 하나의 에지 서버가 엔드 유저(300)에게 제공하도록 할 수 있다.
즉, 엔드 유저(300)의 입장에서 해당 서비스가 수행되는 CDN 서버(200)에 직접 접속하는 경우에도 제어 모듈(120)의 헬스 값 정보를 이용한 에지 서버 그룹을(110) 차등하여 접속하는 기능에 따라 실제적으로 엔드 유저(300)는 최적의 에지 서버 그룹(110)에 저장된 컨텐츠의 복사본을 이용하게 된다. 따라서, 제어 모듈(120)의 제어에 따라 한정된 에지 서버 그룹(110)의 아키텍처가 확장되는 결과가 발생할 수 있다.
도 3은 도 2에서 설명한 컨텐츠를 제공하는 에지 서버를 추가하는 제어 모듈과 관련된 상세 순서도이다.
특히, 도 3은 본 발명의 하나의 실시예에 따른 클라우드 CDN 시스템을 이용한 서비스에서 도 2의 S230 내지 S260 사이의 헬스 정보에 따라 컨텐츠를 제공하는 에지 서버를 추가적으로 연결하는 상세 순서도이다.
우선 서비스 중인 모든 에지 서버의 헬스 정보를 모아 데이터베이스에 저장한 후 각 에지 서버 별로 저장된 헬스 정보를 에지 서버 그룹마다 각각 확인하여 CPU 사용량, 메모리 사용량, 에지 서버에 연결된 세션 수 및 트래픽 양을 확인한다. 헬스 정보의 기준 값(health 기준 값)을 초과하는 그룹이 있으면 헬스 정보의 기준 값 초과 그룹으로 지정하고 그렇지 않으면 기준 값을 초과하지 않는 그룹으로 지정한다. 모든 그룹에 대해서 이 작업이 끝나면, 이제 다음 단계인 헬스 정보의 기준 값을 초과한 그룹에 에지 서버를 추가하는 작업을 한다. 우선 헬스 정보의 기준 값을 초과하는 그룹이 있으면 헬스 정보의 기준 값을 초과하지 않는 그룹이 존재하는 지 확인한다. 그룹이 존재하면, 그룹 내에서 에지 서버를 기 설명한 헬스 정보의 기준 값을 초과하는 그룹에 추가하여 컨텐츠를 서비스하도록 한다. 해당 에지 서버는 헬스 정보의 기준 값을 초과하지 않는 그룹에서는 제외한다. 이 작업을 주기적인 시간마다 수행하게 된다.
네트워크나 인터넷 상황, 서비스하는 컨텐츠 인기(선호도)에 따라 헬스 정보의 기준 값을 초과했던 그룹이 헬스 정보의 기준 값을 초과하지 않는 그룹으로 지정되기도 하며, 반대로 헬스 정보의 기준 값을 초과 하지 않았던 그룹이 초과하는 그룹으로 바뀔 수도 있다. 이렇게 실시간으로 에지 서버 부하량에 반응함으로써, 보다 안정적이고 품질 높은 컨텐츠 서비스를 제공할 수 있다.
이와 같이 본 발명의 실시예에 따른 클라우드 CDN 시스템 및 이를 이용한 컨텐츠 제공방법에 따르면, 다수의 엔드 유저(300)의 접속으로 컨텐츠 데이터 트래픽이 하나의 노드에 집중되는 트래픽 부하를 줄일 수 있다. 또한, 에지 서버의 헬스 정보를 이용하여 CDN 서비스의 종류에 따른 최적화된 에지 서버 그룹을 선택할 수 있다.
이제까지 본 발명에 대하여 실시예들을 중심으로 살펴보았다. 본 발명이 속하는 기술분야에서 통상의 지식을 가진 자는 본 발명의 본질적인 특성에서 벗어나지 않는 범위에서 변형된 형태로 구현될 수 있음을 이해할 수 있을 것이다. 그러므로 개시된 실시예들은 한정적인 관점이 아니라 설명적인 관점에서 고려되어야 한다. 따라서 본 발명의 범위는 전술한 실시예에 한정되지 않고 특허청구범위에 기재된 내용 및 그와 동등한 범위 내에 있는 다양한 실시 형태가 포함되도록 해석되어야 할 것이다.
100: 클라우드 CDN 시스템,
110: 에지 서버 그룹, 120: 제어 모듈,
130: 내부 CDN 서버, 200: CDN 서버,
300: 엔드 유저
110: 에지 서버 그룹, 120: 제어 모듈,
130: 내부 CDN 서버, 200: CDN 서버,
300: 엔드 유저
Claims (12)
- 복수의 CDN 서버에 저장된 컨텐츠의 복사본 또는 상기 CDN 서버에서 내부 CDN 서버에 업로드된 컨텐츠의 복사본을 상기 CDN 서버의 도메인을 통하여 접속된 복수의 엔드 유저에게 제공하는 복수의 에지 서버 그룹 및
상기 복수의 에지 서버 그룹으로부터 헬스 정보를 수집하고, 상기 헬스 정보에 포함되는 측정 값 중에서 하나 이상이 기준 값을 초과하는 제1 에지 서버 그룹이 검출되면, 상기 헬스 정보에 포함되는 측정 값이 가장 작은 제2 에지 서버 그룹을 선택하여 상기 제1 에지 서버 그룹에 연결된 CDN 서버 또는 내부 CDN 서버를 상기 제2 에지 서버 그룹에 포함되는 적어도 하나의 에지 서버와 추가적으로 연결하는 제어 모듈을 포함하고,
상기 제어 모듈은,
상기 제1 에지 서버 그룹에게 할당된 상기 CDN 서버의 도메인을 통하여 상기 CDN 서버의 형태를 판단하고,
상기 CDN 서버와 동일한 그룹에 속하는 다른 CDN 서버와 연결된 에지 서버 그룹 중에서 상기 헬스 정보에 해당하는 측정 값이 가장 작은 상기 제2 에지 서버 그룹을 선택하는 클라우드 CDN 시스템. - 제1항에 있어서,
상기 제어 모듈은,
상기 제1 에지 서버 그룹에 연결된 CDN 서버 또는 내부 CDN 서버를 상기 제2 에지 서버 그룹에 포함되는 적어도 하나의 에지 서버와 연결하여 상기 제1 에지 서버 그룹이 엔드 유저에게 제공하는 컨텐츠를 상기 제2 에지 서버 그룹에 포함되는 적어도 하나의 에지 서버가 상기 엔드 유저에게 제공하도록 하는 클라우드 CDN 시스템. - 제2항에 있어서,
상기 헬스 정보는,
상기 에지 서버 그룹의 CPU 사용량, 메모리 사용량, 상기 에지 서버 그룹에 연결된 세션의 수 및 상기 에지 서버 그룹의 트래픽 양 중에서 적어도 하나를 포함하는 클라우드 CDN 시스템. - 제3항에 있어서,
상기 복수의 CDN 서버는,
컨텐츠 제공 서비스의 유형에 따라 캐쉬 서버, 다운로드 서버, VOD 서버 및 LIVE 서버로 그룹핑되는 클라우드 CDN 시스템. - 삭제
- 제4항에 있어서,
상기 제어 모듈은,
상기 CDN 서버가 캐쉬 서버 형태인 경우, 상기 헬스 정보 중에서 세션의 수를 기준 값과 비교하여 상기 제1 에지 서버 그룹을 검출하고,
상기 CDN 서버가 다운로드 서버, VOD 서버 및 LIVE 서버 중에서 어느 하나의 형태인 경우, 상기 헬스 정보 중에서 트래픽 양을 기준 값과 비교하여 상기 제1 에지 서버 그룹을 검출하는 클라우드 CDN 시스템. - 복수의 에지 서버 그룹과 제어 모듈을 포함하는 클라우드 CDN 시스템을 이용한 컨텐츠 제공방법에 있어서,
상기 복수의 에지 서버 그룹이 복수의 CDN 서버에 저장된 컨텐츠의 복사본 또는 상기 CDN 서버에서 내부 CDN 서버에 업로드된 컨텐츠의 복사본을 상기 CDN 서버의 도메인을 통하여 접속된 복수의 엔드 유저에게 제공하는 단계 및
상기 제어 모듈이 상기 복수의 에지 서버 그룹으로부터 헬스 정보를 수집하고, 상기 헬스 정보에 포함되는 측정 값 중에서 하나 이상이 기준 값을 초과하는 제1 에지 서버 그룹이 검출되면, 상기 헬스 정보에 포함되는 측정 값이 가장 작은 제2 에지 서버 그룹을 선택하여 상기 제1 에지 서버 그룹에 연결된 CDN 서버 또는 내부 CDN 서버를 상기 제2 에지 서버 그룹에 포함되는 적어도 하나의 에지 서버와 추가적으로 연결하는 단계를 포함하고,
상기 CDN 서버 또는 내부 CDN 서버를 상기 제2 에지 서버 그룹과 연결하는 단계는,
상기 제1 에지 서버 그룹에게 할당된 상기 CDN 서버의 도메인을 통하여 상기 CDN 서버의 형태를 판단하고,
상기 CDN 서버와 동일한 그룹에 속하는 다른 CDN 서버와 연결된 에지 서버 그룹 중에서 상기 헬스 정보에 해당하는 측정 값이 가장 작은 상기 제2 에지 서버 그룹을 선택하는 클라우드 CDN 시스템을 이용한 컨텐츠 제공방법. - 제7항에 있어서,
상기 CDN 서버 또는 내부 CDN 서버를 상기 제2 에지 서버 그룹과 연결하는 단계는,
상기 제1 에지 서버 그룹에 연결된 CDN 서버 또는 내부 CDN 서버를 상기 제2 에지 서버 그룹에 포함되는 적어도 하나의 에지 서버와 연결하여 상기 제1 에지 서버 그룹이 엔드 유저에게 제공하는 컨텐츠를 상기 제2 에지 서버 그룹에 포함되는 적어도 하나의 에지 서버가 상기 엔드 유저에게 제공하도록 하는 클라우드 CDN 시스템을 이용한 컨텐츠 제공방법. - 제8항에 있어서,
상기 헬스 정보는,
상기 에지 서버 그룹의 CPU 사용량, 메모리 사용량, 상기 에지 서버 그룹에 연결된 세션의 수 및 상기 에지 서버 그룹의 트래픽 양 중에서 적어도 하나를 포함하는 클라우드 CDN 시스템을 이용한 컨텐츠 제공방법. - 제9항에 있어서,
상기 컨텐츠의 복사본을 복수의 엔드 유저에게 제공하는 단계는,
컨텐츠 제공 서비스의 유형에 따라 캐쉬 서버, 다운로드 서버, VOD 서버 및 LIVE 서버로 그룹핑되는 클라우드 CDN 시스템을 이용한 컨텐츠 제공방법. - 삭제
- 제10항에 있어서,
상기 CDN 서버 또는 내부 CDN 서버를 상기 제2 에지 서버 그룹과 연결하는 단계는,
상기 CDN 서버가 캐쉬 서버 형태인 경우, 상기 헬스 정보 중에서 세션의 수를 기준 값과 비교하여 상기 제1 에지 서버 그룹을 검출하고,
상기 CDN 서버가 다운로드 서버, VOD 서버 및 LIVE 서버 중에서 어느 하나의 형태인 경우, 상기 헬스 정보 중에서 트래픽 양을 기준 값과 비교하여 상기 제1 에지 서버 그룹을 검출하는 클라우드 CDN 시스템을 이용한 컨텐츠 제공방법.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020140080524A KR101574074B1 (ko) | 2014-06-30 | 2014-06-30 | 클라우드 cdn 시스템 및 이를 이용한 컨텐츠 제공방법 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020140080524A KR101574074B1 (ko) | 2014-06-30 | 2014-06-30 | 클라우드 cdn 시스템 및 이를 이용한 컨텐츠 제공방법 |
Publications (1)
Publication Number | Publication Date |
---|---|
KR101574074B1 true KR101574074B1 (ko) | 2015-12-08 |
Family
ID=54872937
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020140080524A KR101574074B1 (ko) | 2014-06-30 | 2014-06-30 | 클라우드 cdn 시스템 및 이를 이용한 컨텐츠 제공방법 |
Country Status (1)
Country | Link |
---|---|
KR (1) | KR101574074B1 (ko) |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR102110312B1 (ko) * | 2018-12-27 | 2020-05-13 | (주)아이앤아이소프트 | Cdn 선택 방법 및 장치 |
US11695855B2 (en) | 2021-05-17 | 2023-07-04 | Margo Networks Pvt. Ltd. | User generated pluggable content delivery network (CDN) system and method |
US11860982B2 (en) | 2022-05-18 | 2024-01-02 | Margo Networks Pvt. Ltd. | Peer to peer (P2P) encrypted data transfer/offload system and method |
US11930439B2 (en) | 2019-01-09 | 2024-03-12 | Margo Networks Private Limited | Network control and optimization (NCO) system and method |
US12062068B2 (en) | 2021-05-04 | 2024-08-13 | Margo Networks Pvt. Ltd. | Oneapp system and method |
-
2014
- 2014-06-30 KR KR1020140080524A patent/KR101574074B1/ko active IP Right Grant
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR102110312B1 (ko) * | 2018-12-27 | 2020-05-13 | (주)아이앤아이소프트 | Cdn 선택 방법 및 장치 |
US11930439B2 (en) | 2019-01-09 | 2024-03-12 | Margo Networks Private Limited | Network control and optimization (NCO) system and method |
US12062068B2 (en) | 2021-05-04 | 2024-08-13 | Margo Networks Pvt. Ltd. | Oneapp system and method |
US11695855B2 (en) | 2021-05-17 | 2023-07-04 | Margo Networks Pvt. Ltd. | User generated pluggable content delivery network (CDN) system and method |
US11860982B2 (en) | 2022-05-18 | 2024-01-02 | Margo Networks Pvt. Ltd. | Peer to peer (P2P) encrypted data transfer/offload system and method |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN106031130B (zh) | 具有边缘代理的内容传送网络架构 | |
US20200084268A1 (en) | Content distribution network | |
KR101574074B1 (ko) | 클라우드 cdn 시스템 및 이를 이용한 컨텐츠 제공방법 | |
JP5088969B2 (ja) | ハイブリッドcdn−p2pにおけるコンテンツ配信方法 | |
JP5068858B2 (ja) | スーパーピアトゥピアネットワークのユーザによって発信されたコンテンツデータパッケージを配信する方法 | |
US9819760B2 (en) | Method and system for accelerated on-premise content delivery | |
AU2011274249B2 (en) | Systems and methods for storing digital content | |
US20180131738A1 (en) | Cloud-based video delivery | |
US20110219109A1 (en) | System and method for sharing transparent proxy between isp and cdn | |
JP5970541B2 (ja) | 情報処理システム、管理サーバ群、および、サーバ管理プログラム | |
US20100115613A1 (en) | Cacheable Mesh Browsers | |
CN102833293A (zh) | P2sp网络中资源下载的方法及客户端 | |
EP3905091B1 (en) | Enhanced online privacy | |
US20230186339A1 (en) | Method and System for Sharing Personal Information with Web Sites | |
CN107113337B (zh) | 用于网络内容传送的方法和系统 | |
US20060236386A1 (en) | Method and apparatus for cooperative file distribution in the presence of firewalls | |
CN105049466A (zh) | 用于信息中心网络的可计算内容存储 | |
US10075553B1 (en) | Systems and methods for automatically rewriting network page code | |
KR20110041194A (ko) | 클라우드 컴퓨팅 네트워크 시스템 및 그것의 파일 분산 방법 | |
Li et al. | Challenges, designs, and performances of large-scale open-P2SP content distribution | |
CN109716731A (zh) | 用于提供可靠和高效数据传送的系统和方法 | |
KR20150011087A (ko) | 컨텐츠 전송 서비스를 위한 분산 캐싱 관리 방법 및 이를 위한 중앙 관리 장치 | |
CN106210760A (zh) | 流媒体资源的缓存方法及装置 | |
JP5165045B2 (ja) | キャッシュシステム及びコンテンツ配信制御方法 | |
CN105359485A (zh) | 由客户终端获得多媒体内容的内容部分的方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
E701 | Decision to grant or registration of patent right | ||
GRNT | Written decision to grant | ||
FPAY | Annual fee payment |
Payment date: 20181106 Year of fee payment: 4 |