도 1은 다양한 실시예들에 따른 네트워크 환경(100) 내의 전자 장치(101)의 블록도이다.
도 1을 참조하면, 네트워크 환경(100)에서 전자 장치(101)는 제1 네트워크(198)(예: 근거리 무선 통신 네트워크)를 통하여 전자 장치(102)와 통신하거나, 또는 제2 네트워크(199)(예: 원거리 무선 통신 네트워크)를 통하여 전자 장치(104) 또는 서버(108)와 통신할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 서버(108)를 통하여 전자 장치(104)와 통신할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 프로세서(120), 메모리(130), 입력 장치(150), 음향 출력 장치(155), 표시 장치(160), 오디오 모듈(170), 센서 모듈(176), 인터페이스(177), 햅틱 모듈(179), 카메라 모듈(180), 전력 관리 모듈(188), 배터리(189), 통신 모듈(190), 가입자 식별 모듈(196), 또는 안테나 모듈(197)을 포함할 수 있다. 어떤 실시예에서는, 전자 장치(101)에는, 이 구성 요소들 중 적어도 하나(예: 표시 장치(160) 또는 카메라 모듈(180))가 생략되거나, 하나 이상의 다른 구성 요소가 추가될 수 있다. 어떤 실시예에서는, 이 구성 요소들 중 일부들은 하나의 통합된 회로로 구현될 수 있다. 예를 들면, 센서 모듈(176)(예: 지문 센서, 홍채 센서, 또는 조도 센서)은 표시 장치(160)(예: 디스플레이)에 임베디드(embedded)된 채 구현될 수 있다.
프로세서(120)는, 예를 들면, 소프트웨어(예: 프로그램(140))를 실행하여 프로세서(120)에 연결된 전자 장치(101)의 적어도 하나의 다른 구성 요소(예: 하드웨어 또는 소프트웨어 구성 요소)를 제어할 수 있고, 다양한 데이터 처리 또는 연산을 수행할 수 있다. 일 실시예에 따르면, 데이터 처리 또는 연산의 적어도 일부로서, 프로세서(120)는 다른 구성 요소(예: 센서 모듈(176) 또는 통신 모듈(190))로부터 수신된 명령 또는 데이터를 휘발성 메모리(volatile memory)(132)에 로드(load)하고, 휘발성 메모리(132)에 저장된 명령 또는 데이터를 처리하고, 결과 데이터를 비휘발성 메모리(non-volatile memory)(134)에 저장할 수 있다. 일 실시예에 따르면, 프로세서(120)는 메인 프로세서(121)(예: 중앙 처리 장치(CPU, central processing unit) 또는 어플리케이션 프로세서(AP, application processor)), 및 이와는 독립적으로 또는 함께 운영 가능한 보조 프로세서(123)(예: 그래픽 처리 장치(GPU, graphic processing unit), 이미지 시그널 프로세서(ISP, image signal processor), 센서 허브 프로세서(sensor hub processor), 또는 커뮤니케이션 프로세서(CP, communication processor))를 포함할 수 있다. 추가적으로 또는 대체적으로, 보조 프로세서(123)는 메인 프로세서(121)보다 저전력을 사용하거나, 또는 지정된 기능에 특화되도록 설정될 수 있다. 보조 프로세서(123)는 메인 프로세서(121)와 별개로, 또는 그 일부로서 구현될 수 있다.
보조 프로세서(123)는, 예를 들면, 메인 프로세서(121)가 인액티브(inactive)(예: 슬립(sleep)) 상태에 있는 동안 메인 프로세서(121)를 대신하여, 또는 메인 프로세서(121)가 액티브(active)(예: 어플리케이션 실행) 상태에 있는 동안 메인 프로세서(121)와 함께, 전자 장치(101)의 구성 요소들 중 적어도 하나의 구성 요소(예: 표시 장치(160), 센서 모듈(176), 또는 통신 모듈(190))과 관련된 기능 또는 상태들의 적어도 일부를 제어할 수 있다. 일 실시예에 따르면, 보조 프로세서(123)(예: 이미지 시그널 프로세서 또는 커뮤니케이션 프로세서)는 기능적으로 관련 있는 다른 구성 요소(예: 카메라 모듈(180) 또는 통신 모듈(190))의 일부로서 구현될 수 있다.
메모리(130)는, 전자 장치(101)의 적어도 하나의 구성 요소(예: 프로세서(120) 또는 센서모듈(176))에 의해 사용되는 다양한 데이터를 저장할 수 있다. 데이터는, 예를 들어, 소프트웨어(예: 프로그램(140)) 및, 이와 관련된 명령에 대한 입력 데이터 또는 출력 데이터를 포함할 수 있다. 메모리(130)는, 휘발성 메모리(132) 또는 비휘발성 메모리(134)를 포함할 수 있다.
프로그램(140)은 메모리(130)에 소프트웨어로서 저장될 수 있으며, 예를 들면, 운영 체제(OS, operating system)(142), 미들웨어(middleware)(144) 또는 어플리케이션(146)을 포함할 수 있다.
입력 장치(150)는, 전자 장치(101)의 구성 요소(예: 프로세서(120))에 사용될 명령 또는 데이터를 전자 장치(101)의 외부(예: 사용자)로부터 수신할 수 있다. 입력 장치(150)는, 예를 들면, 마이크, 마우스, 키보드, 또는 디지털 펜(예: 스타일러스 펜)을 포함할 수 있다.
음향 출력 장치(155)는 음향 신호를 전자 장치(101)의 외부로 출력할 수 있다. 음향 출력 장치(155)는, 예를 들면, 스피커(speaker) 또는 리시버(receiver)를 포함할 수 있다. 스피커는 멀티미디어 재생 또는 녹음 재생과 같이 일반적인 용도로 사용될 수 있고, 리시버는 착신 전화를 수신하기 위해 사용될 수 있다. 일 실시예에 따르면, 리시버는 스피커와 별개로, 또는 그 일부로서 구현될 수 있다.
표시 장치(160)는 전자 장치(101)의 외부(예: 사용자)로 정보를 시각적으로 제공할 수 있다. 표시 장치(160)는, 예를 들면, 디스플레이, 홀로그램 장치, 또는 프로젝터 및 해당 장치를 제어하기 위한 제어 회로를 포함할 수 있다. 일 실시예에 따르면, 표시 장치(160)는 터치를 감지하도록 설정된 터치 회로(touch circuitry), 또는 상기 터치에 의해 발생되는 힘의 세기를 측정하도록 설정된 센서 회로(예: 압력 센서(pressure sensor))를 포함할 수 있다.
오디오 모듈(170)은 소리를 전기 신호로 변환시키거나, 반대로 전기 신호를 소리로 변환시킬 수 있다. 일 실시예에 따르면, 오디오 모듈(170)은, 입력 장치(150)를 통해 소리를 획득하거나, 음향 출력 장치(155), 또는 전자 장치(101)와 직접 또는 무선으로 연결된 외부 전자 장치(예: 전자 장치(102))(예: 스피커 또는 헤드폰))를 통해 소리를 출력할 수 있다.
센서 모듈(176)은 전자 장치(101)의 작동 상태(예: 전력 또는 온도), 또는 외부의 환경 상태(예: 사용자 상태)를 감지하고, 감지된 상태에 대응하는 전기 신호 또는 데이터 값을 생성할 수 있다. 일 실시예에 따르면, 센서 모듈(176)은, 예를 들면, 제스처 센서(gesture sensor), 자이로 센서(gyro sensor), 기압 센서(barometer sensor), 마그네틱 센서(magnetic sensor), 가속도 센서(acceleration sensor), 그립 센서(grip sensor), 근접 센서(proximity sensor), 컬러 센서(color sensor)(예: RGB(red, green, blue) 센서), IR(infrared) 센서, 생체 센서(biometric sensor), 온도 센서(temperature sensor), 습도 센서(humidity sensor), 또는 조도 센서(illuminance sensor)를 포함할 수 있다.
인터페이스(177)는 전자 장치(101)의 외부 전자 장치(예: 전자 장치(102))와 직접 또는 무선으로 연결되기 위해 사용될 수 있는 하나 이상의 지정된 프로토콜(protocol)들을 지원할 수 있다. 일 실시예에 따르면, 인터페이스(177)는, 예를 들면, HDMI(high definition multimedia interface), USB(universal serial bus) 인터페이스, SD(secure digital) 카드 인터페이스, 또는 오디오 인터페이스를 포함할 수 있다.
연결 단자(connection terminal)(178)는, 그를 통해서 전자 장치(101)가 외부 전자 장치(예: 전자 장치(102))와 물리적으로 연결될 수 있는 커넥터를 포함할 수 있다. 일 실시예에 따르면, 연결 단자(178)는, 예를 들면, HDMI 커넥터, USB 커넥터, SD 카드 커넥터, 또는 오디오 커넥터(예: 헤드폰 커넥터)를 포함할 수 있다.
햅틱 모듈(haptic module)(179)은 전기적 신호를 사용자가 촉각 또는 운동 감각을 통해서 인지할 수 있는 기계적인 자극(예: 진동 또는 움직임) 또는 전기적인 자극으로 변환할 수 있다. 일 실시예에 따르면, 햅틱 모듈(179)은, 예를 들면, 모터(motor), 압전 소자(piezoelectric element), 또는 전기 자극 장치(electrical stimulation device)를 포함할 수 있다.
카메라 모듈(180)은 정지 영상 및 동영상을 촬영할 수 있다. 일 실시예에 따르면, 카메라 모듈(180)은 하나 이상의 렌즈들, 이미지 센서들, 이미지 시그널 프로세서들, 또는 플래시들을 포함할 수 있다.
전력 관리 모듈(188)은 전자 장치(101)에 공급되는 전력을 관리할 수 있다. 일 실시예에 따르면, 전력 관리 모듈(188)은, 예를 들면, PMIC(power management integrated circuit)의 적어도 일부로서 구현될 수 있다.
배터리(189)는 전자 장치(101)의 적어도 하나의 구성 요소에 전력을 공급할 수 있다. 일 실시예에 따르면, 배터리(189)는, 예를 들면, 재충전 불가능한 1차 전지, 재충전 가능한 2차 전지 또는 연료 전지(fuel cell)를 포함할 수 있다.
통신 모듈(190)은 전자 장치(101)와 외부 전자 장치(예: 전자 장치(102), 전자 장치(104), 또는 서버(108)) 간의 직접(예: 유선) 통신 채널 또는 무선 통신 채널의 수립, 및 수립된 통신 채널을 통한 통신 수행을 지원할 수 있다. 통신 모듈(190)은 프로세서(120)(예: 어플리케이션 프로세서)와 독립적으로 운영되고, 직접(예: 유선) 통신 또는 무선 통신을 지원하는 하나 이상의 커뮤니케이션 프로세서를 포함할 수 있다. 일 실시예에 따르면, 통신 모듈(190)은 무선 통신 모듈(192)(예: 셀룰러 통신 모듈, 근거리 무선 통신 모듈, 또는 GNSS(global navigation satellite system) 통신 모듈) 또는 유선 통신 모듈(194)(예: LAN(local area network) 통신 모듈, 또는 전력선 통신 모듈)을 포함할 수 있다. 이들 통신 모듈 중 해당하는 통신 모듈은 제1 네트워크(198)(예: 블루투스, Wi-Fi direct 또는 IrDA(infrared data association) 같은 근거리 통신 네트워크) 또는 제2 네트워크(199)(예: 셀룰러 네트워크, 인터넷, 또는 컴퓨터 네트워크(예: LAN 또는 WAN(wide area network))와 같은 원거리 통신 네트워크)를 통하여 외부 전자 장치와 통신할 수 있다. 이런 여러 종류의 통신 모듈들은 하나의 구성 요소(예: 단일 칩)로 통합되거나, 또는 서로 별도의 복수의 구성 요소들(예: 복수 칩들)로 구현될 수 있다.
무선 통신 모듈(192)은 가입자 식별 모듈(196)에 저장된 가입자 정보(예: 국제 모바일 가입자 식별자(IMSI, international mobile subscriber identity))를 이용하여 제1 네트워크(198) 또는 제2 네트워크(199)와 같은 통신 네트워크 내에서 전자 장치(101)를 확인 및 인증할 수 있다.
안테나 모듈(197)은 신호 또는 전력을 외부(예: 외부 전자 장치)로 송신하거나 외부로부터 수신할 수 있다. 일 실시예에 따르면, 안테나 모듈(197)은 서브스트레이트(예: PCB) 위에 형성된 도전체 또는 도전성 패턴으로 이루어진 방사체를 포함하는 하나의 안테나를 포함할 수 있다. 일 실시예에 따르면, 안테나 모듈(197)은 복수의 안테나들을 포함할 수 있다. 이런 경우, 제1 네트워크(198) 또는 제2 네트워크(199)와 같은 통신 네트워크에서 사용되는 통신 방식에 적합한 적어도 하나의 안테나가, 예를 들면, 통신 모듈(190)에 의하여 상기 복수의 안테나들로부터 선택될 수 있다. 신호 또는 전력은 상기 선택된 적어도 하나의 안테나를 통하여 통신 모듈(190)과 외부 전자 장치 간에 송신되거나 수신될 수 있다. 어떤 실시예에 따르면, 방사체 이외에 다른 부품(예: RFIC)가 추가로 안테나 모듈(197)의 일부로 형성될 수 있다.
상기 구성 요소들 중 적어도 일부는 주변 기기들간 통신 방식(예: 버스, GPIO(general purpose input and output), SPI(serial peripheral interface), 또는 MIPI(mobile industry processor interface))를 통해 서로 연결되고, 신호(예: 명령 또는 데이터)를 상호 간에 교환할 수 있다.
일 실시예에 따르면, 명령 또는 데이터는 제2 네트워크(199)에 연결된 서버(108)를 통해서 전자 장치(101)와 외부의 전자 장치(104) 간에 송신 또는 수신될 수 있다. 전자 장치(102, 104) 각각은 전자 장치(101)와 동일한 또는 다른 종류의 장치일 수 있다.
일 실시예에 따르면, 전자 장치(101)에서 실행되는 동작들의 전부 또는 일부는 외부 전자 장치들(102, 104 또는 108) 중 하나 이상의 외부 장치들에서 실행될 수 있다. 예를 들면, 전자 장치(101)가 어떤 기능이나 서비스를 자동으로, 또는 사용자 또는 다른 장치로부터의 요청에 반응하여 수행해야 할 경우에, 전자 장치(101)는 기능 또는 서비스를 자체적으로 실행시키는 대신에 또는 추가적으로, 하나 이상의 외부 전자 장치들(102, 104)에게 그 기능 또는 그 서비스의 적어도 일부를 수행하라고 요청할 수 있다. 상기 요청을 수신한 하나 이상의 외부 전자 장치들(102, 104)은 요청된 기능 또는 서비스의 적어도 일부, 또는 상기 요청과 관련된 추가 기능 또는 서비스를 실행하고, 그 실행의 결과를 전자 장치(101)로 전달할 수 있다. 전자 장치(101)는 상기 결과를, 그대로 또는 추가적으로 처리하여, 상기 요청에 대한 응답의 적어도 일부로서 제공할 수 있다. 이를 위하여, 예를 들면, 클라우드 컴퓨팅(cloud computing), 분산 컴퓨팅(distributed computing), 또는 클라이언트-서버 컴퓨팅(client-server computing) 기술이 이용될 수 있다.
본 문서에 개시된 다양한 실시예들에 따른 전자 장치(101)는 다양한 형태의 장치가 될 수 있다. 전자 장치(101)는, 예를 들면, 휴대용 통신 장치(예: 스마트 폰), 휴대용 멀티미디어 장치, 휴대용 의료 기기, 카메라, 웨어러블 장치(wearable device), 또는 가전 장치를 포함할 수 있다. 본 문서의 실시예에 따른 전자 장치(101)는 전술한 기기들에 한정되지 않는다.
본 문서의 다양한 실시예들 및 이에 사용된 용어들은 본 문서에 기재된 기술적 특징들을 특정한 실시예들로 한정하려는 것이 아니며, 해당 실시예의 다양한 변경(modifications), 균등물(equivalents), 또는 대체물(alternatives)을 포함하는 것으로 이해되어야 한다. 도면의 설명과 관련하여, 유사한 또는 관련된 구성 요소에 대해서는 유사한 참조 부호가 사용될 수 있다. 아이템에 대응하는 명사의 단수 형은 관련된 문맥상 명백하게 다르게 지시하지 않는 한, 상기 아이템 한 개 또는 복수 개를 포함할 수 있다.
본 문서에서, "A 또는 B", "A 및 B 중 적어도 하나", “A 또는 B 중 적어도 하나”, "A, B 또는 C", "A, B 및 C 중 적어도 하나" 및 “A, B, 또는 C 중 적어도 하나”와 같은 문구들 각각은 그 문구들 중 해당하는 문구에 함께 나열된 항목들 중 어느 하나, 또는 그들의 모든 가능한 조합을 포함할 수 있다. "제1", "제2", 또는 "첫째" 또는 "둘째"와 같은 용어들은 단순히 해당 구성 요소를 다른 해당 구성 요소와 구분하기 위해 사용될 수 있으며, 해당 구성 요소들을 다른 측면(예: 중요성 또는 순서)에서 한정하지 않는다. 어떤(예: 제1) 구성 요소가 다른(예: 제2) 구성 요소에 "기능적으로” 또는 “통신적으로"라는 용어와 함께 또는 이런 용어 없이, “커플드” 또는 “커넥티드”라고 언급된 경우, 그것은 상기 어떤 구성 요소가 상기 다른 구성 요소에 직접적으로(예: 유선으로), 무선으로, 또는 제3 구성 요소를 통하여 연결될 수 있다는 것을 의미한다.
본 문서에서 사용된 용어 "모듈"은 하드웨어, 소프트웨어 또는 펌웨어(firmware)로 구현된 유닛(unit)을 포함할 수 있으며, 예를 들면, 로직(logic), 논리 블록(logic block), 부품(component), 또는 회로(circuit)의 용어와 상호 호환적으로 사용될 수 있다. 모듈은, 일체로 구성된 부품 또는 하나 또는 그 이상의 기능을 수행하는, 상기 부품의 최소 단위 또는 그 일부가 될 수 있다. 일 실시예에 따르면, 모듈은 ASIC(application-specific integrated circuit)의 형태로 구현될 수 있다.
본 문서의 다양한 실시예들은 기기(machine)(예: 전자 장치(101))에 의해 읽을 수 있는 저장 매체(storage medium)(예: 내장 메모리(136) 또는 외장 메모리(138))에 저장된 하나 이상의 명령어들(instructions)을 포함하는 소프트웨어(예: 프로그램(140))로서 구현될 수 있다. 예를 들면, 기기(예: 전자 장치(101))의 프로세서(예: 프로세서(120))는, 저장 매체로부터 저장된 하나 이상의 명령어들 중 적어도 하나의 명령을 호출하고, 그것을 실행할 수 있다. 이것은 기기가 상기 호출된 적어도 하나의 명령어에 따라 적어도 하나의 기능을 수행하도록 운영되는 것을 가능하게 한다. 상기 하나 이상의 명령어들은 컴파일러(compiler) 생성된 코드 또는 인터프리터(interpreter)에 의해 실행될 수 있는 코드(code)를 포함할 수 있다. 기기로 읽을 수 있는 저장 매체는, 비일시적(non-transitory) 저장 매체의 형태로 제공될 수 있다. 여기서, ‘비일시적’은 저장 매체가 실재(tangible)하는 장치이고, 신호(signal)(예: 전자기파)를 포함하지 않는다는 것을 의미할 뿐이며, 이 용어는 데이터가 저장 매체에 반영구적으로 저장되는 경우와 임시적으로 저장되는 경우를 구분하지 않는다.
일 실시예에 따르면, 본 문서에 개시된 다양한 실시예들에 따른 방법은 컴퓨터 프로그램 제품(computer program product)에 포함되어 제공될 수 있다. 컴퓨터 프로그램 제품은 상품으로서 판매자 및 구매자 간에 거래될 수 있다. 컴퓨터 프로그램 제품은 기기로 읽을 수 있는 저장 매체(예: CD-ROM, compact disc read only memory)의 형태로 배포되거나, 또는 어플리케이션 스토어(예: 플레이 스토어TM)를 통해 또는 두 개의 사용자 장치들(예: 스마트 폰들) 간에 직접, 온라인으로 배포(예: 다운로드 또는 업로드)될 수 있다. 온라인 배포의 경우에, 컴퓨터 프로그램 제품의 적어도 일부는 제조사의 서버, 어플리케이션 스토어의 서버, 또는 중계 서버의 메모리와 같은 기기로 읽을 수 있는 저장 매체에 적어도 일시 저장되거나, 임시적으로 생성될 수 있다.
다양한 실시예들에 따르면, 상기 기술한 구성 요소들의 각각의 구성 요소(예: 모듈 또는 프로그램)는 단수 또는 복수의 개체를 포함할 수 있다. 다양한 실시예들에 따르면, 전술한 해당 구성 요소들 중 하나 이상의 구성 요소들 또는 동작들이 생략되거나, 또는 하나 이상의 다른 구성 요소들 또는 동작들이 추가될 수 있다. 대체적으로 또는 추가적으로, 복수의 구성 요소들(예: 모듈 또는 프로그램)은 하나의 구성 요소로 통합될 수 있다. 이런 경우, 통합된 구성 요소는 상기 복수의 구성 요소들 각각의 구성 요소의 하나 이상의 기능들을 상기 통합 이전에 상기 복수의 구성 요소들 중 해당 구성 요소에 의해 수행되는 것과 동일 또는 유사하게 수행할 수 있다. 다양한 실시예들에 따르면, 모듈, 프로그램 또는 다른 구성 요소에 의해 수행되는 동작들은 순차적으로, 병렬적으로, 반복적으로, 또는 휴리스틱(heuristic)하게 실행되거나, 상기 동작들 중 하나 이상이 다른 순서로 실행되거나, 생략되거나, 또는 하나 이상의 다른 동작들이 추가될 수 있다.
본 발명의 다양한 실시예들을 서술하기에 앞서, 본 발명의 일 실시예가 적용될 수 있는 전자 장치(101)에 대하여 설명한다.
도 2는 다양한 실시예들에 따른 레거시 네트워크 통신 및 5G 네트워크 통신을 지원하기 위한 전자 장치(101)의 블록도(200)이다.
도 2를 참조하면, 전자 장치(101)는 제1 커뮤니케이션 프로세서(212), 제2 커뮤니케이션 프로세서(214), 제1 RFIC(222), 제2 RFIC(224), 제3 RFIC(226), 제4 RFIC(228), 제1 RFFE(radio frequency front end)(232), 제2 RFFE(234), 제1 안테나 모듈(242), 제2 안테나 모듈(244), 및 안테나(248)를 포함할 수 있다. 전자 장치(101)는 프로세서(120) 및 메모리(130)를 더 포함할 수 있다.
네트워크(199)는 제1 네트워크(292)와 제2 네트워크(294)를 포함할 수 있다. 다른 실시예에 따르면, 전자 장치(101)는 도 1에 기재된 부품들 중 적어도 하나의 부품을 더 포함할 수 있고, 네트워크(199)는 적어도 하나의 다른 네트워크를 더 포함할 수 있다. 일 실시예에 따르면, 제1 커뮤니케이션 프로세서(212), 제2 커뮤니케이션 프로세서(214), 제1 RFIC(222), 제2 RFIC(224), 제4 RFIC(228), 제1 RFFE(232), 및 제2 RFFE(234)는 무선 통신 모듈(192)의 적어도 일부를 형성할 수 있다. 다른 실시예에 따르면, 제4 RFIC(228)는 생략되거나, 제3 RFIC(226)의 일부로서 포함될 수 있다.
제1 커뮤니케이션 프로세서(212)는 제1 네트워크(292)와의 무선 통신에 사용될 대역의 통신 채널의 수립, 및 수립된 통신 채널을 통한 레거시 네트워크(legacy network) 통신을 지원할 수 있다. 다양한 실시예들에 따르면, 제1 네트워크(292)는 2세대(2G), 3G, 4G, 또는 LTE(long term evolution) 네트워크를 포함하는 레거시 네트워크일 수 있다.
제2 커뮤니케이션 프로세서(214)는 제2 네트워크(294)와의 무선 통신에 사용될 대역 중 지정된 대역(예: 약 6GHz ~ 약 60GHz)에 대응하는 통신 채널의 수립, 및 수립된 통신 채널을 통한 5G 네크워크 통신을 지원할 수 있다. 다양한 실시예들에 따르면, 제2 네트워크(294)는 3GPP에서 정의하는 5G 네트워크일 수 있다.
추가적으로, 일 실시예에 따르면, 제1 커뮤니케이션 프로세서(212) 또는 제2 커뮤니케이션 프로세서(214)는 제2 네트워크(294)와의 무선 통신에 사용될 대역 중 다른 지정된 대역(예: 약 6GHz 이하)에 대응하는 통신 채널의 수립, 및 수립된 통신 채널을 통한 5G 네크워크 통신을 지원할 수 있다. 일 실시예에 따르면, 제1 커뮤니케이션 프로세서(212)와 제2 커뮤니케이션 프로세서(214)는 단일(single) 칩 또는 단일 패키지 내에 구현될 수 있다. 다양한 실시예들에 따르면, 제1 커뮤니케이션 프로세서(212) 또는 제2 커뮤니케이션 프로세서(214)는 프로세서(120), 보조 프로세서(123), 또는 통신 모듈(190)과 단일 칩 또는 단일 패키지 내에 형성될 수 있다.
제1 RFIC(222)는, 송신 시에, 제1 커뮤니케이션 프로세서(212)에 의해 생성된 기저대역(baseband) 신호를 제1 네트워크(292)(예: 레거시 네트워크)에 사용되는 약 700MHz 내지 약 3GHz의 라디오 주파수(RF) 신호로 변환할 수 있다. 수신 시에는, RF 신호가 안테나(예: 제1 안테나 모듈(242))를 통해 제1 네트워크(292)(예: 레거시 네트워크)로부터 획득되고, RFFE(예: 제1 RFFE(232))를 통해 전처리(preprocess)될 수 있다. 제1 RFIC(222)는 전처리된 RF 신호를 제1 커뮤니케이션 프로세서(212)에 의해 처리될 수 있도록 기저대역 신호로 변환할 수 있다.
제2 RFIC(224)는, 송신 시에, 제1 커뮤니케이션 프로세서(212) 또는 제2 커뮤니케이션 프로세서(214)에 의해 생성된 기저대역 신호를 제2 네트워크(294)(예: 5G 네트워크)에 사용되는 Sub6 대역(예: 약 6GHz 이하)의 RF 신호(이하, 5G Sub6 RF 신호)로 변환할 수 있다. 수신 시에는, 5G Sub6 RF 신호가 안테나(예: 제2 안테나 모듈(244))를 통해 제2 네트워크(294)(예: 5G 네트워크)로부터 획득되고, RFFE(예: 제2 RFFE(234))를 통해 전처리될 수 있다. 제2 RFIC(224)는 전처리된 5G Sub6 RF 신호를 제1 커뮤니케이션 프로세서(212) 또는 제2 커뮤니케이션 프로세서(214) 중 대응하는 커뮤니케이션 프로세서에 의해 처리될 수 있도록 기저대역 신호로 변환할 수 있다.
제3 RFIC(226)는 제2 커뮤니케이션 프로세서(214)에 의해 생성된 기저대역 신호를 제2 네트워크(294)(예: 5G 네트워크)에서 사용될 5G Above6 대역(예: 약 6GHz ~ 약 60GHz)의 RF 신호(이하, 5G Above6 RF 신호)로 변환할 수 있다. 수신 시에는, 5G Above6 RF 신호가 안테나(예: 안테나(248))를 통해 제2 네트워크(294)(예: 5G 네트워크)로부터 획득되고 제3 RFFE(236)를 통해 전처리될 수 있다. 제3 RFIC(226)는 전처리된 5G Above6 RF 신호를 제2 커뮤니케이션 프로세서(214)에 의해 처리될 수 있도록 기저대역 신호로 변환할 수 있다. 일 실시예에 따르면, 제3 RFFE(236)는 제3 RFIC(226)의 일부로서 형성될 수 있다.
전자 장치(101)는, 일 실시예에 따르면, 제3 RFIC(226)와 별개로 또는 적어도 그 일부로서, 제4 RFIC(228)를 포함할 수 있다. 이런 경우, 제4 RFIC(228)는 제2 커뮤니케이션 프로세서(214)에 의해 생성된 기저대역 신호를 중간(intermediate) 주파수 대역(예: 약 9GHz ~ 약 11GHz)의 RF 신호(이하, IF 신호)로 변환한 뒤, 상기 IF 신호를 제3 RFIC(226)로 전달할 수 있다. 제3 RFIC(226)는 IF 신호를 5G Above6 RF 신호로 변환할 수 있다. 수신 시에, 5G Above6 RF 신호가 안테나(예: 안테나(248))를 통해 제2 네트워크(294)(예: 5G 네트워크)로부터 수신되고 제3 RFIC(226)에 의해 IF 신호로 변환될 수 있다. 제4 RFIC(228)는 IF 신호를 제2 커뮤니케이션 프로세서(214)가 처리할 수 있도록 기저대역 신호로 변환할 수 있다.
일 실시예에 따르면, 제1 RFIC(222)와 제2 RFIC(224)는 단일 칩 또는 단일 패키지의 적어도 일부로 구현될 수 있다. 일 실시예에 따르면, 제1 RFFE(232)와 제2 RFFE(234)는 단일 칩 또는 단일 패키지의 적어도 일부로 구현될 수 있다. 일 실시예에 따르면, 제1 안테나 모듈(242) 또는 제2 안테나 모듈(244) 중 적어도 하나의 안테나 모듈은 생략되거나 다른 안테나 모듈과 결합되어 대응하는 복수의 대역들의 RF 신호들을 처리할 수 있다.
일 실시예에 따르면, 제3 RFIC(226)와 안테나(248)는 동일한 서브스트레이트에 배치되어 제3 안테나 모듈(246)을 형성할 수 있다. 예를 들어, 무선 통신 모듈(192) 또는 프로세서(120)가 제1 서브스트레이트(예: main PCB)에 배치될 수 있다. 이런 경우, 제1 서브스트레이트와 별도의 제2 서브스트레이트(substrate)(예: sub PCB)의 일부 영역(예: 하면)에 제3 RFIC(226)가, 다른 일부 영역(예: 상면)에 안테나(248)가 배치되어, 제3 안테나 모듈(246)이 형성될 수 있다. 제3 RFIC(226)와 안테나(248)를 동일한 서브스트레이트에 배치함으로써 그 사이의 전송 선로의 길이를 줄이는 것이 가능하다. 이는, 예를 들면, 5G 네트워크 통신에 사용되는 고주파 대역(예: 약 6GHz ~ 약 60GHz)의 신호가 전송 선로에 의해 손실(예: 감쇄)되는 것을 줄일 수 있다. 이로 인해, 전자 장치(101)는 제2 네트워크(294)(예: 5G 네트워크)와의 통신의 품질 또는 속도를 향상시킬 수 있다.
일 실시예에 따르면, 안테나(248)는 빔 포밍(beamforming)에 사용될 수 있는 복수개의 안테나 엘리먼트들(antenna elements)을 포함하는 안테나 어레이(antenna array)로 형성될 수 있다. 이런 경우, 제3 RFIC(226)는, 예를 들면, 제3 RFFE(236)의 일부로서, 복수개의 안테나 엘리먼트들에 대응하는 복수개의 위상 변환기(phase shifter)(238)들을 포함할 수 있다. 송신 시에, 복수개의 위상 변환기(238)들 각각은 대응하는 안테나 엘리먼트를 통해 전자 장치(101)의 외부(예: 5G 네트워크의 베이스 스테이션)로 송신될 5G Above6 RF 신호의 위상을 변환할 수 있다. 수신 시에, 복수개의 위상 변환기(238)들 각각은 대응하는 안테나 엘리먼트를 통해 상기 외부로부터 수신된 5G Above6 RF 신호의 위상을 동일한 또는 실질적으로 동일한 위상으로 변환할 수 있다. 이것은 전자 장치(101)와 상기 외부 간의 빔 포밍을 통한 송신 또는 수신을 가능하게 한다.
제2 네트워크(294)(예: 5G 네트워크)는 제1 네트워크(292)(예: 레거시 네트워크)와 독립적으로 운영되거나(예: Stand-Alone(SA)), 연결되어 운영될 수 있다(예: Non-Stand Alone(NSA)). 예를 들면, 5G 네트워크에는 액세스 네트워크(예: 5G radio access network(RAN) 또는 next generation RAN(NG RAN))만 있고, 코어 네트워크(예: next generation core(NGC))는 없을 수 있다. 이런 경우, 전자 장치(101)는 5G 네트워크의 액세스 네트워크에 액세스한 후, 레거시 네트워크의 코어 네트워크(예: evolved packed core(EPC))의 제어 하에 외부 네트워크(예: 인터넷)에 액세스할 수 있다. 레거시 네트워크와 통신을 위한 프로토콜 정보(예: LTE 프로토콜 정보) 또는 5G 네트워크와 통신을 위한 프로토콜 정보(예: New Radio(NR) 프로토콜 정보)는 메모리(230)에 저장되어, 다른 부품(예: 프로세서(120), 제1 커뮤니케이션 프로세서(212), 또는 제2 커뮤니케이션 프로세서(214))에 의해 액세스될 수 있다.
이하에서, 도면 및 설명에서 서술되는 5G 네트워크 기술은 ITU(international telecommunication union) 또는 3GPP에 의하여 정의되는 표준 규격(예: TS(technical specification) 23.501))을 참조하며, MEC 기술은 ETSI(European telecommunication standards institute)에 의하여 정의되는 표준 규격(예: MEC 001 내지 MEC 016)을 참조할 수 있다. 이하에서는, MEC 기술에 기반하여 내용을 서술하지만, 동일 또는 유사한 원리가 오픈포그 컨소시엄(openfog consortium)에 의하여 정의되는 포그 컴퓨팅(fog computing) 기술에 적용될 수 있다.
도 3은 다양한 실시예들에 따른 네트워크 환경(300)에서 MEC 기술을 설명하기 위해 개략 도시하는 도면이다.
도 3을 참조하면, 네트워크 환경(300)(예: 도 1의 네트워크 환경(100))에 포함되는 구성요소들 각각은 물리적인 개체(entity) 단위를 의미하거나, 개별적인 기능(function)을 수행할 수 있는 소프트웨어 또는 모듈 단위를 의미할 수 있다.
일 실시예에 따르면, 전자 장치(101)는 사용자에 의해 사용되는 장치를 의미할 수 있다. 전자 장치(101)는, 예를 들어, 단말(terminal), 사용자 단말(UE, user equipment), 이동국(mobile station), 가입자국(subscriber station), 원격 단말(remote terminal), 무선 단말(wireless terminal), 또는 사용자 장치(user device)를 의미할 수 있다.
일 실시예에 따르면, AN(access network)(302)은 전자 장치(101)와의 무선 통신을 위한 채널(channel)을 제공할 수 있다. AN(302)은 RAN(radio access network), 기지국(base station), 이노드비(eNB, eNodeB), 5G 노드(5G node), 송수신 포인트(TRP, transmission/reception point), 또는 5GNB(5th generation NodeB)를 의미할 수 있다.
일 실시예에 따르면, CN(core network)(303)은 전자 장치(101)의 가입자 정보, 전자 장치(101)의 이동성(mobility), 전자 장치(101)의 접속 권한(access authorization), 데이터 패킷의 트래픽(traffic), 또는 과금 정책 중 적어도 하나를 관리할 수 있다. CN(303)은 UPF(user plane function) 노드, AMF(access & mobility management function) 노드, SMF(session management function) 노드, UDM(unified data management) 노드, 또는 PCF(policy control function) 노드 중 적어도 하나를 포함할 수 있다.
일 실시예에 따르면, DN(data network)(예: 제1 DN(304-1), 제2 DN(304-2))은 CN(303) 및 AN(302)을 통해 전자 장치(101)에게 데이터(또는 데이터 패킷)를 송수신 함으로써 서비스(예: 인터넷 서비스, IMS(IP multimedia subsystem) 서비스)를 제공할 수 있다. 예를 들어, DN(304-1, 304-2)은 통신 사업자에 의하여 관리될 수 있다. 일 실시예에 따르면, 제1 DN(304-1)은 리모트(remote) 서버(306)와 연결되고, 제2 DN(304-2)은 엣지 서버(305)(예: MEC 서버)와 연결될 수 있다. 예를 들어, CN(303)이 AN(302)(또는 엣지 서버(305))와 인접한 위치에 배치되면, 제2 DN(304-2)은 CN(303)과 인접한 위치에 배치될 수 있다.
일 실시예에 따르면, 리모트 서버(306)는 어플리케이션과 관련된 콘텐츠를 제공할 수 있다. 예를 들어, 리모트 서버(306)는 콘텐츠 사업자에 의하여 관리될 수 있다.
일 실시예에 따르면, 복수의 어플리케이션들(예: 제1 어플리케이션(제1 App)(310-1), 제2 어플리케이션(제2 App)(310-2), ...)이 전자 장치(101)에 설치(install)(또는 저장)될 수 있다. 복수의 어플리케이션들은, 예를 들어, 전자 장치(101)에 미리 설치된 기본 어플리케이션, 통신 사업자에 의하여 제공되는 어플리케이션, 또는 3rd 파티(party) 어플리케이션 중 하나일 수 있다. 복수의 어플리케이션들은 데이터 전송 속도, 지연 시간(또는 속도)(latency), 신뢰성(reliability), 네트워크에 접속(access)된 전자 장치의 수, 전자 장치(101)의 네트워크 접속 주기, 또는 평균 데이터 사용량 중 적어도 하나에 기반하여 서로 다른 네트워크 서비스를 요구(require)할 수 있다. 서로 다른 네트워크 서비스는, 예를 들어, eMBB(enhanced mobile broadband), URLLC(ultra- reliable and low latency communication), 또는 mMTC(massive machine type communication)를 포함할 수 있다. eMBB는, 예를 들어, 스마트폰 서비스와 같이 높은 데이터 전송 속도와 낮은 지연 시간(latency)을 요구하는 네트워크 서비스를 의미할 수 있다. URLLC는, 예를 들어, 재난 구조 네트워크나 V2X(vehicle to everything)과 같이 낮은 지연 시간과 높은 신뢰성(reliability)을 요구하는 네트워크 서비스를 의미할 수 있다. mMTC는, 예를 들어, IoT(internet of things)와 같이 복수의 개체(entity)들 간 서로 연결되면서 낮은 지연 시간을 요구하지 않는 네트워크 서비스를 의미할 수 있다.
일 실시예에 따르면, 엣지 서버(305)(예: MEC 서버)는 전자 장치(101)가 연결된 기지국(예: AN(302))의 내부 또는 기지국과 지리적으로 가까운 위치에 배치되고, 리모트 서버(306)가 제공하는 콘텐츠와 적어도 일부가 동일한 콘텐츠를 제공할 수 있다. 도 3에서는 도시되지 않았으나, 엣지 서버(305)는 CN(303) 내부에 배치되거나 별도의 사용자 컴퓨터에 배치될 수 있다. 예를 들어, 리모트 서버(306)는 전자 장치(101)의 위치와 무관하게 전자 장치(101)에게 콘텐츠를 제공하는 반면에, 엣지 서버(305)는 엣지 서버(305)와 인접한 위치에 위치한 전자 장치(101)에게 콘텐츠를 제공하는 지역성을 가질 수 있다. 일 실시예에 따르면, 전자 장치(101)의 복수의 어플리케이션들(310-1, 310-2)은 리모트 서버(306)와 데이터 전송을 수행하거나, 또는 엣지 서버(305)와 엣지 컴퓨팅(예: MEC)에 기반한 데이터 전송을 수행할 수 있다.
일 실시예에 따르면, 전자 장치(101)의 복수의 어플리케이션들(310-1, 310-2)은 요구되는 서비스 타입(예: 네트워크 서비스 타입, 어플리케이션 서비스 타입 및/또는 요구 사항)에 기반하여 리모트 서버(306)와 데이터 전송을 수행하거나, 또는 엣지 서버(305)와 엣지 컴퓨팅에 기반한 데이터 전송을 수행할 수 있다. 예를 들어, 제1 어플리케이션(제1 App)(310-1)이 낮은 지연 시간을 요구하지 않으면, 제1 어플리케이션(310-1)은 리모트 서버(306)와 데이터 전송을 수행할 수 있다. 다른 예를 들어, 제2 어플리케이션(310-2)이 낮은 지연 시간을 요구하면, 제2 어플리케이션(제2 App)(310-2)은 엣지 서버(305)와 데이터 전송을 수행할 수 있다.
다른 실시예에 따르면, 복수의 어플리케이션들(310-1, 320-2)은 별도의 요구(requirement)를 고려하지 않고 전자 장치(101)(또는 어플리케이션)가 엣지 컴퓨팅 서비스에 가입되어 있는지에 기반하여 데이터 전송을 수행할 수 있다. 다른 실시예에 따르면, 어플리케이션이 통신 사업자에 의하여 제공되는 어플리케이션이면, 어플리케이션은 별도의 요구 또는 엣지 컴퓨팅 서비스 가입 여부를 고려하지 않고 데이터 전송을 수행할 수 있다.
도 4는 다양한 실시예들에 따른 네트워크 환경(400)에서 MEC 기반 데이터 전송을 수행하는 전자 장치(101) 및 MEC 시스템(405)을 도시하는 도면이다.
일 실시들에 따르면, 도 4에 도시된 MEC 호스트(host)(447)는 도 3을 참조한 설명 부분에서 설명한 바와 같은 엣지 서버(305)에 대응할 수 있으며, 도 4에는 도시되지 않았지만, 전자 장치(101)는 MEC 호스트(447) 또는 MMP(MEC Management Proxy) 서버(430)(예: 라이프 사이클 관리(LCM, life cycle management) 프록시(proxy) 서버) 사이에 배치되는 AN(302)를 통해 무선 통신을 수행할 수 있다.
도 4에 도시한 바와 같이, 도 4는, 예를 들면, 엣지 컴퓨팅 서비스(예: MEC 서비스)를 위해 전자 장치(101) 내 서비스 에이전트(service agent)(412)(예: MSA, multi-access service agent)와 서비스 인에이블러(service enabler)(414)(예: MSE, multi-access service enabler)를 포함하는 MEC 서비스 모듈(또는 MEC 서비스 레이어)(410)과 연동하는 네트워크 엔티티들을 나타낼 수 있다.
도 4를 참조하면, 네트워크 환경(400)(예: 도 3의 네트워크 환경(300))에서, MEC 사용자 평면(user plane)은 전자 장치(101)의 사용자에게 서비스를 제공하기 위하여 어플리케이션들(또는 클라이언트 어플리케이션(client application))(예: 제1 App(310-1), 제2 App(310-2), ...) 및 MEC 호스트(447)(예: 엣지 서버(305)(또는 MEC 서버))에 설치된 MEC 어플리케이션들(MEC Apps)(또는 엣지 어플리케이션 또는 ME(multi-access edge) 어플리케이션)(예: 제1 MEC App(460-1), 제2 MEC App(460-2), ...) 간 사용자 데이터 패킷을 전송하기 위한 경로(path)(예: 데이터 경로(data path))를 의미할 수 있다. 일 실시예에 따르면, MEC 제어 평면(control plane)은 사용자 평면 상에서 송수신 되는 사용자 데이터 패킷을 위한 엣지 컴퓨팅 시스템(예: MEC 시스템(405))의 제어 정보를 전송하기 위한 경로(예: 제어 경로(control path))를 의미할 수 있다.
다양한 실시예들에 따르면, 도 4의 예시에서 서비스 에이전트(예: MSA)(412) 및 서비스 인에이블러(예: MSE)(414)와 MMP 서버(430) 간에 연동하는 제어 경로(예: MEC 제어 평면)에서, 인증(authentication), 권한(authorization) 부여, 및 디스커버리(discovery) 절차에 관하여 개시한다. 일 실시예에 따르면, 디스커버리 절차 이후 전자 장치(101)의 어플리케이션들(예: 제1 App(310-1), 제2 App(310-2))과 MEC 호스트(447)의 MEC 어플리케이션들(예: 제1 MEC App(460-1), 제2 ME App(460-2)) 간에 데이터 경로(예: MEC 사용자 평면)를 통해 MEC 데이터 서비스가 제공될 수 있다. 도 4에서 도시되지는 않았으나, 전자 장치(101)는 DNS(domain name system) 쿼리/응답(query/response) 데이터 경로를 통해 DNS 서버와 데이터 통신을 수행할 수 있다.
일 실시예에 따르면, MEC 시스템(405)은 통신 사업자의 네트워크에 배치되고, MEC에 기반한 데이터 전송에 이용될 수 있다. MEC 시스템(405)은 MMP 서버(430), OSS(operation support system)(435), 오케스트레이터(orchestrator)(440), MEP(ME platform) 매니저(445), 및 MEC 호스트(447)를 포함할 수 있다. 일 실시예에 따르면, MEC 호스트(447)는 복수 개일 수 있다.
일 실시예에 따르면, MMP 서버(430)는 사용자 단말(UE, user equipment)(예: 전자 장치(101))에 엣지 컴퓨팅 시스템(예: MEC 시스템(405))에 대한 사용자 어플리케이션 인터페이스(참조: ETSI MEC 016 표준 참고)를 제공할 수 있다. 예를 들어, 전자 장치(101)는 MMP 서버(430)에게 MEC 시스템(405)이 제공 가능한 어플리케이션(들)에 관한 정보(예: 가용 어플리케이션 목록)를 요청할 수 있고, MEC 시스템(405)에 특정 어플리케이션의 실행 요청(예: context creation) 및 중지 요청(예: context termination)을 전달할 수 있다. 다른 예를 들어, MMP 서버(430)는 MEC 시스템(405)에 설치된 어플리케이션들(예: 460-1, 460-2, ...)의 라이프 사이클(life cycle)(예:)에 대한 관리를 수행할 수 있다. 예를 들어, MMP 서버(430)는 전자 장치(101)의 요청을 수신하고, 수신된 요청을 MEC 시스템(405)(예: OSS(435) 및 오케스트레이터(440))으로 전달하여, MEC 시스템(405)에 설치된 어플리케이션들(예: 460-1, 460-2, ...)의 라이프 사이클에 대한 관리를 수행할 수 있다.
일 실시예에 따르면, OSS(435)는 어플리케이션의 인스턴스화(instantiation) 또는 어플리케이션의 종료(termination)를 승인(grant)할 수 있다. 어플리케이션의 인스턴스는 어플리케이션을 실행하기 위한 명령어들(또는 인스트럭션들(instructions))의 집합일 수 있으며, 인스턴스화는 MEC 호스트(447)의 프로세서가 인스턴스를 통해 MEC 어플리케이션을 실행하는 동작을 의미할 수 있다.
일 실시예에 따르면, 오케스트레이터(440)는 이용 가능한 자원(resource), 이용 가능한 MEC 서비스, 어플리케이션의 규칙(rule) 및 요구사항(requirement), 운영자(operator)의 정책, 또는 토폴로지(topology) 중 적어도 하나에 기반하여 MEC에 기반한 데이터 전송의 전반적인 기능을 관리 및 유지할 수 있다. 예를 들어, 오케스트레이터(440)는 전자 장치(101)의 어플리케이션에 적합한 MEC 호스트(예: 도 4의 MEC 호스트(447))를 선택하거나, 어플리케이션의 인스턴스화의 트리거링(triggering) 또는 종료를 수행할 수 있다.
일 실시예에 따르면, MEP 매니저(445)는 어플리케이션의 규칙, 요구사항, 서비스 승인, 또는 트래픽 규칙 중 적어도 하나를 관리할 수 있다.
일 실시예에 따르면, MEC 호스트(447)는 전자 장치(101)에 설치된 적어도 하나의 어플리케이션들(예: 310-1, 310-2, ...)에 대응하는 적어도 하나의 MEC 어플리케이션들(예: 460-1, 460-2)을 포함할 수 있다. 일 실시예에 따르면, MEC 호스트(447)는 ME 플랫폼(platform)(450)을 포함할 수 있다. ME 플랫폼(450)은 MEP 매니저(445)로부터 트래픽 규칙을 수신하고, MEC 사용자 평면 상에서 트래픽 규칙을 조절할 수 있다.
일 실시예에 따르면, MEC 호스트(447)는 전자 장치(101)의 MEC 서비스 모듈(또는 MEC 서비스 레이어)(410)과 데이터를 교환하도록 구성되는 MEL(MEC enabling layer) 서버(455)를 포함할 수 있다. MEL 서버(455)는, 예를 들어, MMP 서버(430)와 동일 또는 유사한 기능을 수행할 수 있다. 일 실시예에 따르면, MEC 서비스 모듈(410)은 MMP 서버(430) 또는 MEL 서버(455)와 이하 서술되는 제어 데이터 교환을 수행할 수 있다. 일 실시예에 따르면, MEL 서버(455)는 MEC 호스트(447)에서 동작하는 어플리케이션(또는 서비스)일 수 있다. 다른 실시예에 따르면, MEL 서버(455)는 MEC 호스트(427)의 외부에 배치될 수 있다. 이 경우, MEL 서버(455)는 OSS(435), 오케스트레이터(440), 또는 MEP 매니저(445) 중 적어도 하나와 연결될 수 있다. 일 실시예에 따르면, MEL 서버(455)는 MEC 호스트(447)의 구성 요소에 포함하지 않을 수 있다. 예를 들어, 도 4에서 MEL 서버(455)는 생략(또는 제외)될 수 있다.
일 실시예에 따르면, 제어 데이터는 MEC 시스템(405)이 제공 가능한 어플리케이션 디스커버리(discovery), 라이프 사이클 동기화(LCS, life cycle synchronization), 또는 인증(authentication) 절차(procedure) 중 적어도 하나에 대한 데이터를 포함할 수 있다.
일 실시예에 따르면, 전자 장치(101)는 복수의 어플리케이션들(예: 310-1, 310-2, ...)을 포함하는 어플리케이션 레이어(446)(예: 도 1의 어플리케이션(146)) 및 MEC 기반 데이터 전송을 통합적으로 관리하기 위한 MEC 서비스 모듈(410)을 포함할 수 있다. 어플리케이션 레이어(446) 및 MEC 서비스 모듈(410) 각각은 소프트웨어 또는 프로그램 모듈을 의미할 수 있다. 소프트웨어 또는 프로그램 모듈은 전자 장치(101)에 포함되는 프로세서(예: 도 1의 프로세서(120))가 실행하는 명령어들로 구성될 수 있다. 전자 장치(101)는 레이어들 별로 데이터를 처리하고, 네트워크 인터페이스(network interface)(420)(또는 통신 회로)(예: 도 1 또는 도 2의 무선 통신 모듈(192))를 통해 데이터 전송을 수행할 수 있다. 일 실시예에 따르면, 네트워크 인터페이스(420)는 도 1의 보조 프로세서(123) 또는 통신 모듈(190) 중 적어도 일부일 수 있다. 도 4에서는 어플리케이션 레이어(446)와 별도의 레이어로 구성되는 MEC 서비스 모듈(또는 MEC 서비스 레이어)(410)을 도시하였지만, 다른 실시예에 따르면, MEC 서비스 모듈(410)은 적어도 일부가 어플리케이션 레이어(446)에 포함되는 어플리케이션의 형태로 구성될 수 있다.
일 실시예에 따르면, MEC 서비스 모듈(410)은 서비스 에이전트(예: MSA)(412) 및 서비스 인에이블러(예: MSE)(414)을 포함할 수 있다. 다양한 실시예들에 따르면, MEC 서비스 모듈(410)은 다양한 실시예들에 따른 인증 및 권한 부여(예: AA(authentication/authorization)) 및 정책(policy)(예: 어플리케이션 라우팅 정책(app routing policy), 디스커버리 정책(discovery policy)(또는 모니터링 정책(monitoring policy))(예: 모니터링할 정보 리스트))을 수신하여 처리할 수 있다. 일 실시예에 따르면, MEC 서비스 모듈(410)은 서비스 에이전트(예: MSA)(412)를 이용하여 AA(authentication/authorization) 및 정책(예: 모니터링할 정보 리스트)를 수신하고, 서비스 인에이블러(예: MSE)(414)를 이용하여 수신된 정책에 기반한 라우트(route) 설정 및 MEC 디스커버리 절차를 수행할 수 있다.
다양한 실시예들에 따르면, MEC 서비스 모듈(410)은 MEC 서비스 모듈(410) 내의 엔티티(entity)(예: 서비스 에이전트(MSA)(412) 또는 서비스 인에이블러(MSE)(414)) 중 적어도 어느 하나가 MEC 디스커버리 조건에 대한 모니터링을 수행하도록 동작할 수 있으며, 해당 엔티티에 의해 모니터링된 결과를 서비스 인에이블러(MSE)(414)에 전달하도록 동작할 수 있다. 일 실시예에 따르면, MEC 서비스 모듈(410)은 서비스 에이전트(MSA)(412)를 통해 AA 및 디스커버리 관련 정책을 획득(또는 수신)하도록 할 수 있다. 일 실시예에 따라, 서비스 에이전트(412)가 모니터링을 수행하는 경우, 서비스 에이전트(412)에 의해 MEC 디스커버리 조건을 모니터링 하여, 조건을 충족할 시, 서비스 인에이블러(MSE)(414)에 MEC 디스커버리 요청을 전달하고, 서비스 인에이블러(414)를 통해 MEC 디스커버리 절차를 수행할 수 있다. 다른 실시예에 따라, 서비스 인에이블러(414)가 모니터링을 수행하는 경우, 서비스 에이전트(412)가 서비스 인에이블러(414)로 정책을 전달하고, 서비스 인에이블러(414)는 전달된 정책에 따라 MEC 디스커버리 조건을 모니터링 하여, 조건을 충족할 시 MEC 디스커버리 절차를 수행할 수 있다.
일 실시예에 따르면, 서비스 에이전트(412)는 전자 장치(101)의 컨텍스트(context) 정보를 모니터링 할 수 있다. 컨텍스트 정보는, 예를 들어, 전자 장치(101)에 설치된 어플리케이션들(예: 310-1, 310-2, ...) 중 MEC에 기반한 데이터 전송을 지원하는 어플리케이션에 관한 정보, 전자 장치(101)의 이동성과 관련된 정보, 어플리케이션의 라이프 사이클 정보, 전자 장치(101)의 상태에 관한 정보, 센서에 의하여 획득된 정보, 또는 네트워크 성능 중 적어도 하나를 의미할 수 있다. 전자 장치(101)의 이동성과 관련된 정보는, 예를 들어, 전자 장치(101)의 움직임을 나타내는 정보, 전자 장치(101)와 연결된 기지국의 변경과 관련된 정보, 또는 전자 장치(101)가 지정된 영역에 진입하는 지와 관련된 정보 중 적어도 하나를 포함할 수 있다. 지정된 지역은, 예를 들어, LADN(local area data network), TA(tracking area), 기지국의 셀(cell), 기지국 간 핸드오버(handover)가 발생하는 영역, 또는 위치 기반 서비스(예: 셀룰러, 위성, 또는 Wi-Fi(wireless fidelity)에 기반한 위치 측정 기술)에 의하여 결정된 영역 중 적어도 하나를 의미할 수 있다. 어플리케이션의 라이프 사이클 정보는, 예를 들어, 일련의 주기를 가지는 어플리케이션의 상태(예: 라이프 사이클)를 나타낼 수 있다. 전자 장치(101)의 상태에 관한 정보는, 예를 들어, 디스플레이(예: 도 1의 표시 장치(160))의 온/오프(on/off) 상태, 배터리(예: 도 1의 배터리(189)) 상태, 메모리(예: 도 1의 메모리(130)) 사용 상태, 수신 신호 세기, 타임아웃(time-out) 정보, 또는 CPU(예: 도 1의 프로세서(120)) 사용 상태 중 적어도 하나를 의미할 수 있다. 센서에 의하여 획득된 정보는, 예를 들어, 도 1에 설명된 센서 모듈(176)에 의하여 획득된 정보를 의미할 수 있다. 네트워크 성능은, 예를 들어, 전자 장치(101)가 연결된 네트워크의 주파수 대역폭(bandwidth) 또는 지연 시간(latency) 중 적어도 하나를 의미할 수 있다. 다양한 실시예들에 따른, 서비스 에이전트(412)에 관하여 후술하는 도면들을 참조하여 상세히 설명된다.
일 실시 예에 따르면, 서비스 인에이블러(414)는 모니터링된 컨텍스트 정보에 기반하여 어플리케이션들(예: 310-1, 310-2, ...)의 MEC 기반 데이터 전송을 관리(또는 처리)할 수 있다.
예를 들어, 복수의 어플리케이션들(예: 310-1, 310-2, ...)이 개별적으로 MEC 시스템(405)에 정보를 요청하지 않고, 다양한 실시예들에 따른 서비스 인에이블러(414)는 전자 장치(101)의 이동성과 관련된 이벤트가 감지되면 MMP 서버(430) 또는 MEC 호스트(447)에게 MEC 시스템(405)이 제공 가능한 어플리케이션들(예: MEC 어플리케이션들(460-1, 460-2, ...))과 관련된 정보를 요청하거나 수신함으로써 전자 장치(101)의 부하를 줄일 수 있다.
다른 예를 들어, 서비스 인에이블러(414)는 MEC 어플리케이션들(460-1, 460-2, ...) 또는 어플리케이션들(예: 310-1, 310-2, ...) 중 적어도 하나의 어플리케이션이 MEC에 기반한 데이터 전송을 수행할 수 있는 지정된 조건을 만족하는 지를 결정하고, 지정된 조건을 만족하는 적어도 하나의 어플리케이션이 MEC 기반 데이터 전송을 수행하도록 해당 어플리케이션에 알려줄 수 있다(notify). 지정된 조건을 만족하는 적어도 하나의 어플리케이션이 전자 장치(101)에 설치되어 있지 않으면, 서비스 인에이블러(414)는 어플리케이션을 설치하도록 어플리케이션 레이어(446) 및/또는 프레임워크(framework)(예: 미들웨어(144) 및/또는 운영 체제(142))에 가이드 할 수 있다. 예를 들어, 어플리케이션 레이어(446) 및/또는 프레임워크는 서비스 인에이블러(414)의 요청에 따라, 전자 장치(101)에 신규 어플리케이션을 설치하도록 할 수 있다. 다양한 실시예들에서, 전자 장치(101)는 신규 어플리케이션에 대한 정보(예: URI 또는 IP 주소, 어플리케이션 이름)를 MEC 시스템(405)(예: MEC 호스트(447))로부터 수신(또는 획득)할 수 있다.
다른 예를 들어, 서비스 인에이블러(414)는 라이프 사이클 동기화와 관련된 지정된 조건(이하, 제2 조건)이 감지되면, 라이프 사이클 동기화를 MMP 서버(430)(예: LCM 프록시 서버) 또는 엣지 서버(305)(또는 MEC 서버)에게 요청함으로써, 엣지 서버(305)의 자원 소모를 줄일 수 있다. 예를 들어, 서비스 인에이블러(414)는 어플리케이션들(310-1, 310-2, …)의 사용 여부를 MMP 서버(430)로 통지할 수 있다. 일 실시예에 따라, 어플리케이션들(예: 310-1, 310-2, …)이 사용 중일 때만 MEC 어플리케이션들(예: 460-1, 460-2, …)이 동작(예: 데이터 전송)을 수행하고, 어플리케이션들(예: 310-1, 310-2, …)이 미사용 중(예: screen off, 클라이언트 어플리케이션 백그라운드(background) 상태 변경, 사용자 이동 속도가 일정 이상 중 적어도 하나 만족)일 때에는 MEC 어플리케이션들(460-1, 460-2, …)이 동작(예: 데이터 전송)을 중지할 수 있다. 일 실시예에 따르면, 서비스 인에이블러(414)가 상기와 같이 어플리케이션들(310-1, 310-2, …)의 사용 여부를 MMP 서버(430)에 알려줌으로써, MEC 호스트(447)(또는 엣지 서버(305))의 자원을 효율적으로 관리하도록 할 수 있다. 일 실시예에 따라, 미사용 중인 어플리케이션에 대해서는 MEC 어플리케이션의 자원 할당을 해제하여 MEC 호스트(447)의 자원 소모를 줄일 수 있다.
다른 예를 들어, 복수의 어플리케이션들(예: 310-1, 310-2, ...)이 MEC에 기반한 데이터 전송을 위하여 개별적으로 인증 절차를 수행하는 방법과 달리, 서비스 인에이블러(414)는 전자 장치(101)에 대한 인증 절차를 MMP 서버(430)(또는 엣지 서버(305))와 통합적으로 수행함으로써 네트워크 부하를 줄일 수 있다.
도 5는 다양한 실시예들에 따른 네트워크 환경에서 MEC 기반 서비스를 지원하기 위한 전자 장치(101) 및 외부 서버(500)를 도시하는 도면이다.
도 5에 도시한 바와 같이, 도 5의 전자 장치(101)는 MEC AA(MEC Authentication/Authorization) 절차와 MEC 디스커버리(discovery) 절차를 위한 소프트웨어 구조(software architecture)의 일 예를 나타낼 수 있다.
일 실시예에 따라, 전자 장치(101)는 엣지 컴퓨팅 서비스(multi-access edge computing services)(이하, ‘MEC 서비스’라 한다)를 위한 어플리케이션(들)(이하, ‘클라이언트 어플리케이션(client App(application))’이라 한다)(510), 서비스 에이전트(예: MSA)(520)(이하, ‘MSA(520)’이라 한다), 서비스 인에이블러(예: MSE)(530)(이하, ‘MSE(530)’이라 한다)를 포함할 수 있다. 일 실시예에 따라, 전자 장치(101)는 데이터 전송에 관련된 PDU(protocol data unit) 세션(session)의 설정(establishment)을 위한 네트워크 인터페이스(540)(예: 도 1 또는 도 2의 무선 통신 모듈(192))를 포함할 수 있고, 도시되지는 않았으나, 네트워크 인터페이스(540)의 구동을 제어하는 네트워크 드라이버(network driver)(예: 소프트웨어 드라이버)를 포함할 수 있다. 일 실시예에 따르면, 클라이언트 어플리케이션(510), MSA(520), 및 MSE(530)는 전자 장치(101)에 소프트웨어로 탑재되거나 물리적인 구성을 갖도록 구성될 수 있다. 일 실시예에 따르면, MSA(520)와 MSE(530)는 프로세서(예: 도 1의 프로세서(120))의 일부로서 구동될 수 있다. 일 실시예에 따르면, MSA(520)와 MSE(530)는 프로세서(120)와 독립적으로 운용되는 별도의 하드웨어 구성일 수 있다. 다른 실시예에 따르면, MSA(520)와 MSE(540)는 소프트웨어(예: 도 1의 프로그램(140))일 수 있다. 예를 들어, 소프트웨어 형태의 MSA(520)와 MSE(540)는 메모리(예: 도 1 또는 도 2의 메모리(130))에 명령어(또는 인스트럭션(instruction))들의 형태로 저장되고 프로세서(120)에 의해 MSA(520)와 MSE(530)의 동작들이 실행될 수 있다.
일 실시예에 따르면, 클라이언트 어플리케이션(510)은 사용자에 의해 전자 장치(101)에 설치되는 3rd 파티(party) 어플리케이션을 포함할 수 있다. 일 실시예에 따르면, 클라이언트 어플리케이션(510)은 MEC 또는 포그 컴퓨팅)와 같은 MEC 서비스를 사용하는 어플리케이션일 수 있다. 일 실시예에 따르면, 클라이언트 어플리케이션(510)은 무과금(예: FOC, free of charge) 서비스와 같은 차별화된 서비스를 사용하는 어플리케이션을 포함할 수 있다.
일 실시예에 따라, MEC를 위한 클라이언트 어플리케이션(510)은, MEC 호스트(예: 도 4의 MEC 호스트(447))에서 구동되는 MEC 어플리케이션(예: 도 4의 제1 MEC App(460-1), 제2 MEC App(460-2))에 접속하는 전자 장치(101)의 어플리케이션을 의미할 수 있다. 일 실시예에 따라, MEC 어플리케이션은 사용자에 인접한 MEC 호스트(447)에 설치 및 실행되어 클라이언트 어플리케이션(510)과 통신하는 어플리케이션을 의미할 수 있다. 일 실시예에 따르면, 클라이언트 어플리케이션(510)은 별도의 인증 클라이언트 역할을 하는 MSA(520)(예: 서비스 에이전트)를 통해 인증(authentication)을 받을 수 있다. 일 실시예에 따라, 클라이언트 어플리케이션(510)은, 네트워크 인터페이스(540)를 통해, 특정 PDU 세션(예: MEC 전용 PDU 세션(dedicated PDU session))에 기반하여 네트워크에 접속하거나, 또는 MSE(530)(예: 서비스 인에이블러)의 DNS 프록시(proxy) 기능을 통해 기존 PDU 세션(예: default PDU session)으로 MEC 어플리케이션에 접속할 수 있다.
일 실시예에 따라, 무과금 서비스를 위한 클라이언트 어플리케이션(510)은, 데이터 무과금 정책을 적용하는 전자 장치(101)의 어플리케이션을 의미할 수 있다. 일 실시예에 따라, 클라이언트 어플리케이션(510)은 무과금 인증 담당 MSA(520)를 통해 인증이 되면 CARP(client application routing policy) 또는 URSP(UE route selection policy)를 통해 해당 고유 식별자(UID, unique identifier)에 대한 라우팅 규칙(routing rule)이 등록되고, 해당 UID에서 발생하는 트래픽(traffic)은 무과금 전용 PDU 세션을 통하여 송수신 될 수 있다. 일 실시예에 따라, URSP는 3GPP 표준에 정의된 전자 장치(101)(예: 사용자 단말) 경로 선택(또는 설정) 정책을 나타내며, NAS(non-access stratum) 메시지에 포함되어 AMF로부터 전자 장치(101)의 모뎀(modem)(또는 커뮤니케이션 프로세서(CP, communication processor))을 통해 수신될 수 있다. 일 실시예에 따라, CARP는 다양한 실시예들에서 정의되는 전자 장치(101) 경로 선택(또는 설정) 정책으로서, 예를 들어, 3GPP의 URSP가 가용하지 않는 환경에서 전자 장치(101)의 어플리케이션 레이어(application layer)(예: MSA(520) 또는 MSE(530))를 통해 수신될 수 있다.
일 실시예에 따르면, MSA(520)(예: 서비스 에이전트)는 외부 서버(500)의 AA(Authentication/Authorization) 서버(580)(예: 인증 서버)와 MEC 서비스에 관련된 인증 절차(예: 인증 및 권한 부여(AA, Authentication/Authorization) 절차)를 처리할 수 있다. 예를 들어, MSA(520)는 AA의 결과로 수신한 URSP 규칙 및/또는 MEC 접속 토큰을 MSE(530)로 전달하는 역할을 포함할 수 있다. 일 실시예에 따르면, MSA(520)는 어플리케이션 이벤트(예: 실행(launch), 종료)를 감지하거나, 특정 이벤트를 어플리케이션으로 전달하는 역할을 포함할 수 있다. 다양한 실시예들에 따르면, 전자 장치(101)의 MSA(520)는 AA 클라이언트(525)를 포함할 수 있다. 일 실시예에 따르면, AA 클라이언트(525)는 전자 장치(101)를 생산하는 생산자(또는 제조사) 또는 오퍼레이터(operator)(예: 서비스 사업자)에 의해 제공될 수 있다. 일 실시예에 따르면, MSA(520)는, AA 클라이언트(525)에 기반하여, 전자 장치(101)의 가입자 식별 정보에 기반하여 AA(Authentication/Authorization)를 수행할 수 있다. 가입자 식별 정보는, 예를 들어, SIM(subscriber identity module), USIM(universal SIM), IMEI(international mobile equipment identity), 또는 GPSI(generic public subscription identifier)를 포함할 수 있다. 예를 들어, MSA(520)는 가입자 식별 정보에 기반하여 AA 서버(580)와 통신을 통해 MSE(530)에 의한 서비스(예: MSE 서비스)를 사용하기 위한 인증(Authentication) 및 권한(Authorization) 부여 기능을 제공하는 어플리케이션(또는 소프트웨어)일 수 있다. 일 실시예에 따라, MSE 서비스는, 예를 들어, MSE(530)를 통하여 서비스를 받는 MEC, FOC, MMS, 또는 URLLC(ultra-reliable and low latency communications)와 같은 서비스를 통칭할 수 있다.
일 실시예에 따르면, MSA(520)는 AA 서버(580)와 통신을 통해 MSE 서비스 인증 및 권한 부여를 받으면, 권한 부여된 서비스 타입에 대해 MSE API(application programming interface)를 사용하여 MSE(530)를 활성화/비활성화(enable/disable)(예: MSE 서비스를 활성화/비활성화) 할 수 있으며, 서비스 타입 별 사용 가능한 클라이언트 어플리케이션(510)의 UID 및 규칙(rule)(예: ApnSettings)을 등록하고, 라우팅(routing) 설정을 요청할 수 있다. 일 실시예에 따라, MSE API는 MSE 서비스 타입 별 활성화/비활성화 및 UID 별 라우팅 규칙 설정(routing rule setting)을 위해 전자 장치(101)에서 상위 어플리케이션 레이어로 제공하는 API를 포함할 수 있다. 일 실시예에 따르면, MSE API는 MEC 디스커버리 절차를 위한 정책 또는 컨텍스트(context) 모니터링 정책과 같은 적어도 하나의 정책을 설정하기 위한 API를 포함할 수 있다. 일 실시예에 따라, 클라이언트 어플리케이션(510)은 MSA(520)와 인증 및 권한 부여 절차를 통해 해당 서비스(예: MEC, FOC)에 접근할 수 있다.
일 실시예에 따라, MSA(520)가 오퍼레이터(예: 서비스 사업자)에 의해 구현되는 경우, 예를 들어, 오퍼레이터가 MSE 서비스를 사용하는 MSA(예: operator MSA)를 직접 개발할 경우, MSA(520)는 AA 서버(580)를 통해 MSE 서비스 사용을 위한 인증 및 권한 부여 절차를 직접 수행할 수 있다. 일 실시예에 따라, MSA(520)는 인증 및 권한 부여 절차에서 AA 서버(580)로부터 어플리케이션 별 라우팅 규칙(routing rule)(예: 전용 PDU 세션 사용시 DNN(data network name(=APN in LTE)) 정보)을 수신할 수 있다. 일 실시예에 따라, MSA(520)가 MSE API 사용을 위해서는 MSA(520)와 전자 장치(101) 간 인증 및 권한 부여 절차를 수행할 수 있다. 예를 들어, 사전에 MSA(520)를 전자 장치(101)에 탑재 시, MSA app APK의 서명(signing)을 통해 플랫폼 키(platform key)로 인증할 수 있다. 일 실시예에 따라, 전자 장치(101)가 인증 모듈을 포함(또는 지원)할 시, MSA(520)의 설치 후 전자 장치(101) 내 인증 모듈과 별도의 인증 절차를 거쳐 MSE API에 대한 사용 권한을 획득하도록 할 수도 있다. 일 실시예에 따라, MSE 서비스 인증 절차가 완료되면, MSA(520)는 수신된 정책을 기반으로 MSE API를 호출하여 PDU 세션의 생성/종료와 라우팅 규칙 설정을 수행할 수 있다.
일 실시예에 따르면, 전자 장치(101)는 MEC 용 어플리케이션의 데이터 경로(data path) 설정 시, MSE(530)의 다양한 엔티티(예: MEC 활성화 레이어(MEL, MEC enabling layer)(531), URSP 핸들링 레이어(UHL, URSP handling layer)(533), 또는 DNS(domain name system) 핸들링 레이어(DHL, DNS handling layer)(535)) 중 적어도 하나의 엔티티를 경유하도록 데이터 경로(예: 경로 ⓐ, 경로 ⓑ, 또는 경로 ⓒ)를 설정할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 MEC 용 어플리케이션의 데이터 경로 설정 시, 기본 PDU 세션(default PDU session)을 사용(예: 경로 ⓐ)하거나, 또는 별도의 전용 PDU 세션(dedicated PDU session)을 사용(예: 경로 ⓑ 또는 경로 ⓒ)하는 것에 기반하여 데이터 경로를 다르게 설정할 수 있다. 일 실시예에 따라, 별도의 전용 PDU 세션을 사용하는 경우, MSE(530)의 MEL(531)을 통해 MEC 디스커버리 절차를 수행하는지 여부에 따라 경로 ⓑ 또는 경로 ⓒ의 데이터 경로가 결정될 수 있다.
일 실시예에 따르면, MSA(520)는 MSE(530)의 MEL(531)을 경유하지 않고, MSE(530)의 UHL(533)에 직접 요청하여 전용 PDU 세션(dedicated PDU session)을 구성(예: 서비스의 경로를 경로 ⓒ로 설정)할 수 있다. 예를 들어, 전자 장치(101)에서 스폰서드(sponsored) 어플리케이션 실행 시, 미리 특정한 서버 또는 네트워크와 약속된 경우에, MSA(520)는 UHL(533)에 요청하여 해당하는 서비스를 전용 PDU 세션을 통하여 제공할 수 있다. 일 실시예에 따르면, MSA(520)는 UHL(533)로 서비스를 식별하기 위한 별도의 정보를 더 생성하거나. 또는 외부 서버로부터 수신하여 제공할 수 있다.
다양한 실시예들에 따르면, 전자 장치(101)는 MSA(520)의 하위 레이어에, MSE(530)(예: 서비스 인에이블러)를 포함할 수 있다.
일 실시예에 따르면, MSE(530)는 클라이언트 어플리케이션(510)이 MSA(520)를 통해 MEC 서비스(또는 MSE 서비스) 사용이 가능하도록, MSA(520)에 MSE API를 제공할 수 있으며, 이에 따라 어플리케이션 별 사용 PDU 세션에 대한 라우팅 테이블(routing table)이 설정될 수 있다. 일 실시예에 따르면, MSE(530)는 어플리케이션 ID 별 또는 URI 별 사용할 PDU 세션 경로에 대한 라우팅 테이블을 설정하여, 메모리(예: 도 1 또는 도 2의 메모리(130))에 저장할 수 있다. 일 실시예에 따르면, MSE(530)는 어플리케이션 ID 및 URI 중 적어도 하나에 대해 PDU 세션 경로의 설정 대상으로 설정할 수 있다. URI는 도메인 이름(domain name) 또는 IP 주소 형태를 포함할 수 있다. 일 예로, 어플리케이션 ID 별 PDU 세션 경로 설정은, 예를 들어, “AppID 1: PDU session 1, AppID 2: PDU session1, AppID 3: PDU session 2”와 같이 설정할 수 있다. 일 예로, URI 별 PDU 세션 경로 설정은, 예를 들어, “URI 1: PDU session 1, URI 2: PDU session2”와 같이 설정할 수 있다. 일 예로로, 어플리케이션 ID 별 URI 별 PDU 세션 경로 설정은, 예를 들어, “AppID 1 & URI 1: PDU session 3, AppID 2 & URI 1: PDUsession 1”과 같이 설정할 수 있다.
일 실시예에 따라, MEC 서비스는 MEC 어플리케이션(또는 ME(mobile edge) 어플리케이션)을 사용하기 위해 필요한 절차, MEC 어플리케이션을 통하여 제공받는 서비스, 및 MEC 어플리케이션에 제공하는 정보 관련 서비스를 통칭할 수 있다. 일 실시예에 따르면, MSE(530)는 MEC 서비스를 위해서, MEC 서비스 디스커버리(service discovery), 위치 확인(location verification), 라우트 선택(route selection), 성능 확인(performance verification), 또는 이동성 지원(mobility support)의 추가적인 기능을 지원할 수 있다.
다양한 실시예들에 따르면, MSE(530)는 적어도 하나의 MEC 호스트(예: 도 4의 MEC 호스트(447))(또는 MEC 어플리케이션)와 연결된 상태에서, 특정한 서비스를 제공하기 위해 전용 PDU 세션으로 구성하도록 하거나, 또는 기본 PDU 세션으로 구성하도록 할 수 있다. 일 실시예에 따르면, 전용 PDU 세션 또는 기본 PDU 세션의 구성에 필요한 정보는, 예를 들어, 전자 장치(101)의 모뎀(또는 CP, communication processor)에서, AMF/PCF 서버(590)로부터 NAS(non-access stratum) 정보(information)를 통해 수신할 수 있다.
일 실시예에 따르면, MSE(530)는 MEL(531), UHL(533), 및 DHL(535)를 포함할 수 있다.
일 실시예에 따라, MEL(531)은 MSE 서비스 중 MEC 서비스 사용을 위해 필요한 작업을 수행할 수 있다. 예를 들면, MEL(531)은 MEC 서비스 등록(MEC service registration), MEC 서비스 디스커버리(MEC service discovery), 라우트 선택(route selection)(예: DNN handling), 성능 사전 측정(performance pre-measurement), 위치 서비스(location services), 및/또는 이동성 핸들링(mobility handling)의 동작을 처리할 수 있다.
일 실시예에 따라, MEC 서비스 등록은, 전자 장치(101)의 USIM 또는 어카운트(Account)(예: 로그-인(log-in)) 정보에 기반하여 MMP 서버(430)(또는 LCM 프록시 서버) 또는 MEC 솔루션 제공 서버(solution provider server)로부터 MEC 서비스 가입 여부를 인증 받고, MEC 서비스 권한 레벨(level)에 맞는 토큰(token)(예: Cookie)을 수신하여 메모리(예: 도 1 또는 도 2의 메모리(130))에 저장할 수 있다. 이후의 MEC 서비스는 토큰이 유효한 시간 동안 해당 토큰을 사용하여 서비스 요청을 수행할 수 있다.
일 실시예에 따라, MEC 서비스 디스커버리는, 전자 장치(101)가 MEC 서비스가 가능한 영역에 들어왔을 때(예: 특정 셀(cell) ID 접속 또는 LADN 영역 진입), MEL(531)이 이를 감지하여, 해당 지역에서 사용 가능한 앱 리스트(예: MEC App (name) list) 또는 도메인 이름(domain name)(예: MEC 어플리케이션 별 도메인 이름) 중 적어도 하나를 수신하고, 사용자 설정에 따라 다양한 기능을 수행할 수 있다. 예를 들어, MEL(531)은, 사용자 설정에 따라 가용 MEC 어플리케이션 알림, DNS 프록싱(proxying), 및/또는 MEC 어플리케이션 활성화를 제공할 수 있다. 일 실시예에 따라, MEL(531)은 가용 MEC 어플리케이션에 대해 알림을 제공할 수 있다. 예를 들어, 현재 사용 가능한 MEC 어플리케이션을 알림 창 또는 어플리케이션 아이콘(예: 앱 아이콘)에 표시할 수 있다. 일 실시예에 따라, 전자 장치(101) 상에 해당 MEC 어플리케이션에 대응되는 클라이언트 어플리케이션의 설치를 알림할 수도 있다.
일 실시예에 따라, MEL(531)은 DNS 프록싱(proxying)을 제공할 수 있다. 예를 들어, 클라이언트 어플리케이션이 MEC 어플리케이션에 접속하기 위하여 해당 도메인 이름(domain name)에 대한 DNS 쿼리(query) 발생 시, 해당 어플리케이션 이름(application name) 또는 DNS 쿼리 중 적어도 하나가 MEC 앱 리스트에 매칭(matching)이 될 경우, MEL(531)은 해당 DNS 쿼리를 MEC 용 DNS 서버에 전송하여, 해당 MEC 어플리케이션에 대한 접속 IP 주소를 받아오고, 이를 클라이언트 어플리케이션(510)에 리턴(return)할 수 있다. 일 실시예에 따라, 해당 IP 주소는, 예를 들어, 유효 기간 동안 전자 장치(101) 내 MEC 용 DNS 캐시에 저장할 수 있다. MEC 앱 리스트 상의 도메인 이름에 대한 MEC DNS 리졸빙(resolving)은 클라이언트 어플리케이션의 DNS 쿼리와 별도로 MEL(531)이 자체적으로 수행하여 MEC 용 DNS 캐시에 저장할 수 있다.
일 실시예에 따라, MEL(531)은 MEC 어플리케이션 활성화를 제공할 수 있다. 예를 들어, 전자 장치(101)에 설치된 MEC 클라이언트 어플리케이션이 사용 중이거나 또는 사용이 예상될 경우, 이와 연동하는 MEC 어플리케이션 활성화(예: 인스턴스 생성(instantiation))을 요청할 수 있다. 일 실시예에 따르면, 해당 MEC 어플리케이션이 전자 장치(101)의 접속 지역 MEC 호스트에 설치되어 있지 않을 경우, 설치를 요청(예: 패키지(package) URI 포함)할 수 있다.
일 실시예에 따라, 라우트 선택(예: DNN handling)은, 기본 PDU 세션을 사용하지 않고, MEC 서비스 또는 MEC 어플리케이션을 위한 전용 PDU 세션의 사용을 원할 경우, 클라이언트 어플리케이션의 UID에 대한 라우팅 규칙(routing rule)을 설정할 수 있다. 일 실시예에 따르면, MSE(530)가 MEC 서비스 또는 MEC 어플리케이션을 위한 전용 DNN 정보를 미리 정의된 프로필(predefined profile) 또는 AA 서버(580)로부터 수신하고, UHL API(미도시)를 사용하여 MEC 전용 PDU 세션의 생성을 요청할 수 있다.
일 실시예에 따라, 성능 사전 측정은, 예를 들어, MEL(531)이 복수의 후보(candidate) MEC 호스트들에 대해 사전 성능 테스트하는 것을 포함할 수 있다. 예를 들어, MEL(531)은 사전 성능(예: ping probing, bandwidth estimation) 테스트를 통해 최적 MEC 호스트를 선택할 수 있다.
일 실시예에 따라, 위치 서비스는, 예를 들어, 전자 장치(101)가 위치된 지역에 기반하여 서비스를 제공하는 것을 포함할 수 있다. 일 실시예에 따르면, MEL(531)은 전자 장치(101)의 해당 위치에서의 서비스 가용성(service availability)(또는 location accuracy)에 관한 정보를 제공할 수 있다. 일 예로, 서비스 가용성에 관한 정보는, 예를 들면, 서비스 가능 지역(location confirmed), 해당 서비스 없음(location not found), 또는 서비스 불가 지역(location spoofed)과 같은 정보를 포함할 수 있다.
일 실시예에 따라, 이동성 핸들링은, 예를 들어, 핸드오버가 발생하는 영역에서의 서비스 연속성(service continuity)을 위한 핸들링을 제공할 수 있다. 예를 들어, MEL(531)은 MEC 호스트에서 다른 MEC 호스트로 핸드오버 또는 MEC 호스트에서 리모트 호스트(remote host)로 핸드오버를 처리할 수 있다.
일 실시예에 따르면, MEL(531)은 MMP 서버(예: 도 4의 MMP 서버(430))와의 통신을 통해 MEC 호스트(예: 도 4의 MEC 호스트(447))의 MEC 어플리케이션의 디스커버리(discovery)을 위한 제어 및 서비스의 종류를 식별할 수 있다. 예를 들어, MEL(531)은 미리 정의된 MSE API 호출에 의해 서비스를 식별할 수 있다. 다른 예를 들어, MEL(531)은 사업자 서버(예: AA 서버(580)) 또는 MMP 서버(430)로부터 수신한 정책에 따라 서비스를 식별할 수 있다.
일 실시예에 따르면, MEL(531)은 서비스의 식별 결과, 예를 들어, 기본 PDU 세션을 사용하는 서비스인 경우 DHL(535)를 경유하는 서비스의 경로(예: 경로 ⓐ)를 설정하고, 이에 따라 MEL(531) 및 DHL(535)에 의해 MEC 서비스를 제공할 수 있다. 일 실시예에 따르면, MEC 용 어플리케이션을 위한 데이터 경로 ⓐ의 경우, MEL(531)이 기본 PDU 세션을 통하여 서비스가 제공되도록 구성할 수 있다. 다른 실시예에 따르면, MEL(531)은 서비스의 식별 결과, 예를 들어, 전용 PDU 세션을 사용하는 서비스인 경우 MEL(531), UHL(533), 및 DHL(535)를 경유하는 서비스의 경로(예: 경로 ⓑ)를 설정하고, 해당 서비스를 MEL(531), UHL(533), 및 DHL(535)에 의해 제공할 수 있다. 일 실시예에 따르면, MEC 용 어플리케이션을 위한 데이터 경로 ⓑ의 경우 MEL(531)이 UHL(533)에 요청하여 전용 PDU 세션을 통하여 서비스가 제공되도록 구성할 수 있다. 일 실시예에 따르면, 전술한 다양한 서비스를 식별하기 위하여 MSA(520)가 MEL(531)로 별도의 정보를 더 제공하거나 MEL(531)이 MMP 서버(430)로부터 관련 정보를 수신(또는 획득)하도록 할 수 있다.
일 실시예에 따라, UHL(533)은 API 호출에 따라 서비스 타입 별 전용 PDU 세션을 요청하고, 해당 어플리케이션에 대해 설정된 전용 PDU 세션으로 바인딩(binding) 할 수 있다.
일 실시예에 따라, DHL(535)은 3rd 파티 어플리케이션에 DNS 사전 리졸빙(pre-resolving) 또는 DNS 프록시 기능을 지원할 수 있다. 예를 들어, 기존 기본 PDU 세션을 통해 데이터 연결이 된 상태에서 MEC 용 클라이언트 어플리케이션이 특정 서비스 접속을 위한 DNS 쿼리를 발생하면, DNS 프록시가 DNS 쿼리를 가로채서, MEC 용 도메인 이름으로 DNS 서버에 쿼리를 전달하거나, 또는 DNS 캐시에서 룩업(lookup)하여 해당 MEC 도메인 IP 주소를 반환할 수 있다. 이를 통해, 3rd 파티 어플리케이션이 별도의 소프트웨어 수정 없이, 그리고 오퍼레이터의 별도 트래픽 필터링(traffic filtering)(또는 steering) 작업 없이 MEC 서비스를 제공할 수 있다.
일 실시예에 따라, AA 서버(580)는 MSE 서비스 사용을 위한 인증 및 권한 부여를 제공할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSA(520)는 AA 서버(580)를 통해 인증 및 가입자 정보에 따라 서비스 타입 별 권한을 부여 받을 수 있다. 일 실시예에 따르면, MSA(520)는 MSE 서비스 사용 가능 클라이언트 어플리케이션을 인증할 수도 있다. 일 실시예에 따르면, AA 서버(580)와 전자 장치(101)의 MSA(520) 간의 인증 절차는 별도 PDU 세션을 통하지 않고, 예를 들어, LTE 또는 Wi-Fi와 같은 통신을 통해 현재 인터넷(internet)에 연결된 기본 PDU 세션을 사용할 수 있다.
일 실시예에 따라, MMP 서버(430)는 전자 장치(101)의 인증 또는 MEC 제어를 위해 전자 장치(101)와 통신하는 프록시 서버를 의미할 수 있다. 일 실시예에 따르면, MMP 서버(430)는, 예를 들어, HTTP(hypertext transfer protocol)에 기반하여 요청/응답(request/response) 메시지 교환을 수행할 수 있다. 일 실시예에 따라, 전자 장치(101)가 AA 서버(580) 또는 MEC 솔루션 제공 서버와 직접 통신 가능할 경우, LCM 프록시는 필요하지 않을 수 있다. 예를 들어, LCM 프록시가 제공하는 서버 API를 사용하는 경우, MSA(520)의 인증 요청 메시지는 AA 서버(580)로 포워딩(forwarding) 되어 인증을 수행하고, MEC 제어 메시지는 MEC 솔루션 제공 서버로 전달될 수 있다. 다양한 실시예들에서, MSA(520)와 MMP 서버(430) 또는 인타이틀먼트 서버(entitlement server) 간 연동 API는 생략할 수 있으며, AA 절차(예: 인증 및 권한 부여 절차)에서 필요한 정보는 미리 수신될 수 있다.
일 실시예에 따라, AMF(access and mobility function)/PCF(policy control function) 서버(590)는, 예를 들어, 5G NR(new radio) 표준에서 MEC 지원 시, PCF에 MMP 정보 및 URPS 규칙(rule)이 등록되고, NAS 시그널링(signaling)을 통해 AMF로부터 해당 정보를 수신할 수 있다.
이상에서와 같이, 다양한 실시예들에 따르면, MSA(520)는 AA 서버(580)와 통신하여 인증을 수행하고 원하는 정보(예: 인증 및 권한 부여)를 요청할 수 있고, 요청한 정보를 AA 서버(580)로부터 수신하여 획득할 수 있다. 다양한 실시예들에 따르면, MSE(530)는 MMP 서버(530)와 통신하여 원하는 정보를 요청할 수 있고, 요청한 정보를 MMP 서버(530)로부터 수신하여 획득할 수 있다. 예를 들어, MSE(530)는 MMP 서버(430)와 통신하여 MEC 앱 리스트를 획득하거나, 또는 MEC 서비스 디스커버리 절차를 수행하고, 특정한 적어도 하나의 MEC 호스트(또는 MEC 어플리케이션)과 연결을 설정할 수 있다.
다양한 실시예들에 따르면, 도 4 및 도 5를 참조한 설명 부분에서 설명한 바와 같이 MSA(520)와 MSE(530)를 포함하는 전자 장치(101)에 기반하여, MEC 용 어플리케이션의 데이터 경로 설정 시, 다음과 같이 다양한 서비스 시나리오를 제공할 수 있다.
1. 제1 데이터 경로(예: 경로 ⓐ)의 시나리오(예: MSE on Single PDU Session)
일 실시예에 따른 제1 데이터 경로(예: 경로 ⓐ)의 시나리오는, 클라이언트 어플리케이션이 기존 인터넷 데이터(internet data)를 위해 사용 중인 기본 PDU 세션(또는 PDN(public data network) 연결)을 사용하여 MEC 어플리케이션에 연결하는 시나리오를 나타낼 수 있다. 일 실시예에 따르면, MEL(531)에서 MEC 디스커버리 절차를 수행하여, 전자 장치(101)에 가까운 MEC 호스트에 MEC 어플리케이션 구동 및 연결을 요청하고, 해당 MEC 어플리케이션의 URI를 수신할 수 있다. 클라이언트 어플리케이션(510)이 해당 MEC 어플리케이션 접속 요청 시, 해당 URI에 대한 DNS 리졸빙(resolving)을 통해 획득한 MEC 어플리케이션 IP 주소로 접속을 수행할 수 있다. 일 실시예에 따라, 제1 데이터 경로의 시나리오(예: MSE on Single PDU Session)에서는 MEC 서비스를 위한 별도의 PDU 세션을 사용하지 않으므로, 동작 상에 URSP 규칙을 제어하는 UHL(533)은 개입하지 않을 수 있다.
2. 제2 데이터 경로(예: 경로 ⓑ)의 시나리오 B(예: MSE on Multiple PDU Sessions with MEL)
일 실시예에 따른 제2 데이터 경로(예: 경로 ⓑ)의 시나리오는, 클라이언트 어플리케이션이 기존 인터넷 용 기본 PDU 세션(또는 PDN 연결) 외에, 별도의 MEC 전용 PDU 세션을 생성하여 MEC 어플리케이션에 연결하는 시나리오를 나타낼 수 있다. 일 실시예에 따라, MEC 전용 PDU 세션 생성은 사업자(예: MNO(mobile network operator) 또는 MMP 서버(430)) 정책에 따르며, MSA(520) 또는 인증된 클라이언트 어플리케이션(510)이 MSE API를 사용하여 UHL(533)을 통해 생성할 수 있다. 일 실시예에 따라, MEC 전용 PDU 세션은 기본 PDU 세션 외에 하나 이상의 PDU 세션을 항상 열어둘 수도 있고, 특정 시점에 필요에 따라 MEL(531)의 요청에 의해 동적으로 생성하거나 해제할 수 있다. 일 실시예에 따르면, 사전에 정의된 규칙(rule)(예: CARP 또는 URSP 규칙) 또는 외부 서버(예: MMP 서버(430), AA 서버(580), 또는 AMF/PCF 서버(590))로부터 수신한 라우팅 규칙(routing rule)에 따라 해당 클라이언트 어플리케이션(또는 UID) 또는 접속 URI에 대한 트래픽(traffic)을 MEC 전용 PDU 세션으로 라우팅(routing) 되도록 MSE(530)의 UHL(533)에서 지원할 수 있다.
3. 제3 데이터 경로(예: 경로 ⓒ)의 시나리오(예: MSE on Multiple PDU Sessions without MEL)
일 실시예에 따른 제3 데이터 경로의 시나리오는, MEL(531)의 기능 없이, 특정 서비스에 대해 전용 PDU 세션만 생성하여 사용하는 시나리오를 나타낼 수 있다. 일 실시예에 따르면, MSA(520) 또는 인증된 클라이언트 어플리케이션(510)에 MSE API를 사용하여 별도의 전용 PDU 세션을 생성하고, 해당 PDU 세션을 사용하는 어플리케이션(예: UID) 규칙을 등록하고, 해당 어플리케이션의 트래픽을 해당 PDU Session으로 라우팅 되도록 할 수 있다. 일 실시예에 따르면, 제3 데이터 경로의 시나리오(예: MSE on Multiple PDU Sessions without MEL)와 같은 방식의 경우, MEC 뿐만 아니라 전용 PDU 세션이 필요한 다양한 타입의 서비스(예: FOC, MMS, 또는 URLLC)에서 활용될 수도 있다.
본 발명의 다양한 실시예들에 따른 전자 장치(101)는, 네트워크 인터페이스(420), 및 프로세서(120)를 포함하고, 상기 프로세서(120)는, 상기 네트워크 인터페이스를 이용하여, 기지국 내에 또는 상기 기지국을 통하여 연결 가능한 적어도 하나의 외부 서버로, 상기 적어도 하나의 외부 서버가 제공 가능한 어플리케이션들에 관한 정보를 획득하고, 상기 어플리케이션들에 관한 정보에 기반하여, 지정된 조건에 대응하는 어플리케이션을 포함하는 외부 서버를 선택하고, 상기 선택된 외부 서버와 데이터 전송을 수행할 수 있다.
다양한 실시예들에 따르면, 상기 프로세서(120)는, 상기 어플리케이션들에 관한 정보를 요청하는 요청 메시지를 상기 적어도 하나의 외부 서버로 전송하고, 상기 적어도 하나의 외부 서버로부터 상기 어플리케이션들에 관한 정보를 포함하는 응답 메시지를 수신하고, 상기 응답 메시지로부터 상기 어플리케이션들에 관한 정보를 획득할 수 있다.
다양한 실시예들에 따르면, 상기 프로세서(120)는, 상기 요청 메시지에 상기 어플리케이션들에 관한 정보의 조건을 지정하여 상기 적어도 하나의 외부 서버로 전송할 수 있다.
다양한 실시예들에 따르면, 상기 요청 메시지는, clientappName, locationInfo, deviceType, serviceType, contextType, 또는 URI Request 중 적어도 하나를 포함할 수 있다.
다양한 실시예들에 따르면, 상기 응답 메시지는, referenceURI, clientAppName, clientAppPackageURL, uriTTL, uriLOC, carpRule, DNN, S-NSSAI, accessType, sessionType, mptcp, 또는 fqdnList 중 적어도 하나를 포함할 수 있다.
본 발명의 다양한 실시예들에 따른 전자 장치(101)는, 네트워크 인터페이스(420), 및 프로세서(120)를 포함하고, 상기 프로세서(120)는, 디스커버리 정책에 기반하여, 지정된 외부 서버로부터 서비스 가능한 어플리케이션의 앱 리스트를 획득하고, 상기 앱 리스트에 기반하여 상기 전자 장치의 클라이언트 어플리케이션과 연관되고 접속하고자 하는 어플리케이션에 관련된 정보를 상기 지정된 외부 서버로부터 획득하고, 상기 획득된 정보에 기반하여, 데이터 전송을 위한 호스트를 결정하고, 상기 호스트와 데이터 전송을 수행할 수 있다.
다양한 실시예들에 따르면, 상기 프로세서(120)는, 상기 외부 서버와 통신하여 인증 및 권한 부여와 관련된 동작을 수행하는 서비스 에이전트(service agent), 상기 외부 서버와 통신하여 앱 리스트를 획득하고, 디스커버리(discovery)와 관련된 동작을 수행하는 서비스 인에이블러(service enabler)를 포함할 수 있다.
다양한 실시예들에 따르면, 상기 프로세서(120)는, 상기 서비스 에이전트와 상기 서비스 인에이블러 사이의 API를 통해 상기 서비스 인에이블러를 활성화 하고, 상기 서비스 인에이블러를 통해 상기 외부 서버와 디스커버리 절차를 수행할 수 있다.
다양한 실시예들에 따르면, 상기 프로세서(120)는, 상기 서비스 에이전트에서 상기 서비스 인에이블러로 상기 디스커버리 정책을 설정하는 것을 포함하고, 상기 디스커버리 정책은 클라이언트 어플리케이션 이름(clientAppName) 및 디스커버리 정책(discoveryPolicy)을 포함하고, 상기 디스커버리 정책(discoveryPolicy)은 동적 DNN(dynamicDnn)의 사용 여부, 위치 정보(locationInfo), 디바이스 타입(deviceType), 서비스 타입(serviceType), 또는 컨텍스트 타입(contextType) 중 적어도 하나를 포함할 수 있다.
다양한 실시예들에 따르면, 상기 프로세서(120)는, 상기 서비스 에이전트로부터 상기 디스커버리 정책 수신에 기반하여 상기 서비스 인에이블러를 활성화 하고, 상시 서비스 인에이블러를 통해 상기 디스커버리 정책에 따라 지정된 조건을 만족하는 앱 리스트를 프록시 서버로 요청하도록 할 수 있다.
다양한 실시예들에 따르면, 상기 프로세서(120)는, 상기 앱 리스트에 상기 클라이언트 어플리케이션과 연관되는 어플리케이션이 없는 경우, 상기 서비스 인에이블러를 통해 프록시 서버로 상기 어플리케이션의 URI를 요청하고, 상기 앱 리스트에 상기 클라이언트 어플리케이션과 연관되는 어플리케이션이 있는 경우, 상기 어플리케이션의 어플리케이션 이름을 포함하여 상기 프록시 서버로 전송할 수 있다.
다양한 실시예들에 따르면, 상기 프로세서(120)는, 상기 프록시 서버에 상기 어플리케이션이 없을 경우 상기 프록시 서버로부터 상기 어플리케이션의 다운로드 또는 설치를 위한 어플리케이션 패키지(package) URI을 획득할 수 있다.
다양한 실시예들에 따르면, 상기 프로세서(120)는, 상기 서비스 인에이블러를 통해 상기 어플리케이션에 대한 URI로 DNS 쿼리(query)를 수행하고, 상기 DNS 쿼리에 대응하는 DNS 응답으로 획득된 IP 주소를 로컬 DNS 캐시(cache)에 저장하도록 할 수 있다.
다양한 실시예들에 따르면, 상기 프로세서(120)는, 상기 외부 서버로부터 복수의 호스트에 대한 후보 IP 리스트(candidate IP list)가 수신되는 경우, 추가 정보에 기반하여 상기 호스트를 선택하도록 설정되고, 상기 추가 정보는, 호스트 위치, 사용자 현재 위치, 사용자 속도, 또는 호스트 성능(performance)에 관한 정보를 포함할 수 있다.
본 발명의 다양한 실시예들에 따른 전자 장치(101)는, 네트워크 인터페이스(420), 및 프로세서(120)를 포함하고, 상기 프로세서(120)는, 디스커버리 정책에 기반하여, 지정된 외부 서버로부터 서비스 가능한 어플리케이션의 앱 리스트를 획득하고, 클라이언트 어플리케이션에 의한 컨텍스트 생성과 관련된 이벤트에 기반하여, 상기 클라이언트 어플리케이션과 연관되고 접속하고자 하는 어플리케이션에 관련된 정보를 상기 지정된 외부 서버로부터 획득하고, 상기 획득된 정보에 기반하여, 데이터 전송을 위한 호스트를 선택하고, 상기 호스트와 데이터 전송을 수행할 수 있다.
다양한 실시예들에 따르면, 상기 컨텍스트 생성과 관련된 이벤트는, 상기 클라이언트 어플리케이션의 실행, 상기 클라이언트 어플리케이션에 의한 컨텍스트 생성 요청, 또는 상기 클라이언트 어플리케이션에 의한 DNS 쿼리 발생 중 적어도 하나를 포함할 수 있다.
다양한 실시예들에 따르면, 상기 디스커버리 정책은, 상기 디스커버리 정책은 클라이언트 어플리케이션 이름(clientAppName) 및 디스커버리 정책(discoveryPolicy)을 포함하고, 상기 디스커버리 정책(discoveryPolicy)은 동적 DNN(dynamicDnn)의 사용 여부, 위치 정보(locationInfo), 디바이스 타입(deviceType), 서비스 타입(serviceType), 또는 컨텍스트 타입(contextType) 중 적어도 하나를 포함할 수 있다.
다양한 실시예들에 따르면, 상기 프로세서(120)는, 상기 디스커버리 정책에 따라 지정된 조건을 만족하는 앱 리스트를 프록시 서버로 요청하도록 할 수 있다.
다양한 실시예들에 따르면, 상기 프로세서(120)는, 상기 앱 리스트에 상기 클라이언트 어플리케이션과 연관되는 어플리케이션이 없는 경우, 상기 프록시 서버로 상기 어플리케이션의 URI를 요청하고, 상기 앱 리스트에 상기 클라이언트 어플리케이션과 연관되는 어플리케이션이 있는 경우, 상기 어플리케이션의 어플리케이션 이름을 포함하여 상기 프록시 서버로 전송하고, 상기 프록시 서버에 상기 어플리케이션이 없을 경우 상기 프록시 서버로부터 상기 어플리케이션의 다운로드 또는 설치를 위한 어플리케이션 패키지(package) URI을 획득하도록 할 수 있다.
다양한 실시예들에 따르면, 상기 프로세서(120)는, 상기 어플리케이션에 대한 URI로 DNS 쿼리(query)를 수행하고, 상기 DNS 쿼리에 대응하는 DNS 응답으로 획득된 IP 주소를 로컬 DNS 캐시(cache)에 저장하도록 할 수 있다.
이하에서는 다양한 실시예들의 전자 장치(101)의 동작 방법에 대하여 설명한다. 예를 들어, 이하에서는 MSA(520)와 MSE(530)를 포함하는 전자 장치(101)에 기반하여 다양한 실시예들에 따른 인증 및 권한 부여(예: AA(authentication/authorization)) 및 정책(policy)(예: app routing policy, discovery policy, 또는 monitoring policy)을 수신하고, 수신된 정책에 기반한 라우트(route) 설정 및 MEC 디스커버리 절차를 수행하는 다양한 동작들에 대하여 설명한다.
이하에서 설명하는 전자 장치(101)에서 수행하는 동작들은, 전자 장치(101)의 적어도 하나의 프로세서(예: 프로세싱 회로를 포함하는 적어도 하나의 프로세서로서, 예를 들면, 도 1의 프로세서서(120))(이하, ‘프로세서(120)’라 한다)에 의해 실행될 수 있다. 일 실시예에 따라, 전자 장치(101)에서 수행하는 동작들은, 메모리(예: 도 1의 메모리(130))(이하, ‘메모리(130)’라 한다)에 저장되고, 실행 시에, 프로세서(120)가 동작하도록 하는 인스트럭션들(instructions)에 의해 실행될 수 있다.
도 6은 다양한 실시예들에 따른 MEC 서비스를 지원하기 위한 인증 및 디스커버리 절차를 설명하기 위해 도시하는 도면이다.
다양한 실시예들에 따라, 도 6에서는 MEC 서비스를 위한 어플리케이션들의 인증(예: authentication & authorization) 및 디스커버리(discovery) 절차를 수행하기 위한 신호 흐름도의 예를 도시한다. 일 실시예에 따라, 도 6에서는 전자 장치(101)가 MEC 시스템(405)과 신호(또는 데이터)를 교환하는 예를 도시하였지만, 전자 장치(101)는 AN(302)을 통해 MEC 시스템(405)에 포함되는 구성 요소(예: 도 5의 AA 서버(580), MMP 서버(430), 및/또는 AMF/PCF 서버(590))와 신호를 교환할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 도 4 및 도 5를 참조한 설명 부분에서 설명한 바와 같은 클라이언트 어플리케이션(510), MSA(520)(또는 서비스 에이전트), 및 MSE(530)(또는 서비스 인에이블러)를 포함할 수 있다. 일 실시예에 따르면, MEC 시스템(405)은 도 4 및 도 5를 참조한 설명 부분에서 설명한 바와 같은 MEC 시스템(405)에 대응할 수 있으며, AA 서버(580), MMP 서버(430), 및/또는 AMF/PCF 서버(590)를 포함할 수 있다.
도 6을 참조하면, 동작 610에서, 전자 장치(101)의 MSA(520)는 MEC 시스템(405)과 인증(예: MEC 인증) 절차를 수행할 수 있다. 일 실시예에 따라, 인증 절차는 AA 절차로, 예를 들면, 인증(authentication) 및/또는 권한(authorization) 부여 절차를 포함할 수 있다. 일 실시예에 따르면, 인증(authentication) 절차는 MEC 서비스가 이용 가능한지를 확인하기 위한(또는 사용자를 판별하기 위한) 일련의 동작을 포함할 수 있고, 권한(authorization) 부여 절차는 MEC 서비스 레벨(예: QoS 또는 자원량)을 확인하기 위한 일련의 동작을 포함할 수 있다. 다양한 실시예들에 따르면, MSA(520)는 MMP 서버(430) 또는 AA 서버(580)와 최초 접속을 하여 사용자(또는 가입자) 인증(authentication)을 수행하고, MMP 서버(430) 또는 AA 서버(580)로부터 MMP 정보(MMP Info(information))와 권한(authorization) 부여에 필요한 정보, 트래픽 경로, 또는 PDU 세션 설정을 위한 CARP 또는 URSP 규칙(rule)과 같은 제어 데이터를 수신할 수 있다. 일 실시예에 따르면, MSA(520)는 제어 데이터를 수신하는 것에 기반하여, 해당 MMP 서버(430)에 접속하여 인증 절차를 수행할 수 있다. 일 실시예에 따르면, MSA(520)는 인증 절차를 수행하는 결과에 따라, MEC 시스템(405)(예: MMP 서버(430))로부터 MEC 시스템(405)에 접속(access)하기 위한 인증 정보(예: 접속 토큰(MAT, MEC access token))를 획득(또는 수신)할 수 있다. 접속 토큰(MAT)은 어플리케이션이 MEC 시스템(405)으로부터 서비스를 제공받기 위하여 요구되는 키(key)를 포함할 수 있다. 다양한 실시예들에 따른, 인증 절차에 관한 설명은 후술하는 도면들을 참조하여 상세히 설명된다.
다양한 실시예들에 따르면, 인증과 권한 부여는, 예를 들어, 전자 장치(101) 및/또는 사용자에 대한 인증을 포함할 수 있다. 예를 들어, 전자 장치(101)는 MSA(520)를 통해 전자 장치(101)(예: 사용자 단말) 또는 가입자에 대한 인증을 수행하고, 인증이 완료되면 해당 전자 장치(101)의 클라이언트 어플리케이션(510)은 MEC 서비스를 위한 접속이 허용될 수 있다. 이러한 경우, 클라이언트 어플리케이션(510)은 내부적으로 MSA(520)로부터 인증(authentication) 받은(또는 인증된) 어플리케이션일 수 있고, 클라이언트 어플리케이션(510)에게 별도의 접속 토큰(예: MAT)을 제공하는 동작이 생략될 수 있다.
일 실시예에 따라, 도 6에서는 도시하지 않았으나, 전자 장치(101)(예: MSA(520)는 전자 장치(101)에 설치된 복수의 어플리케이션들 중 MEC에 기반한 데이터 전송을 수행할 수 있는 클라이언트 어플리케이션(510)에 대한 인증 절차를 수행할 수 있다. 일 실시예에 따르면, 인증 절차는 OAuth 표준에 기반하여 수행할 수 있다. 다른 실시예에 따르면, 전자 장치(101)는 MEC 시스템(405)과 협약된 화이트 리스트 또는 별도의 외부 서버(또는 제3 서버)(미도시)에서 수신한 화이트 리스트와 전자 장치(101)에 설치된 클라이언트 어플리케이션(510)의 정보(예: 어플리케이션 패키지 이름)를 비교하는 방식을 통해 인증 절차를 수행할 수도 있다. 일 실시예에 따라, 전자 장치(101)는 인증 절차가 완료되면, 인증된 클라이언트 어플리케이션(510)에게 접속 토큰을 제공할 수 있다. 일 실시예에 따라, 접속 토큰은 인증을 통해 해당 접속 토큰을 사용하는 접속 요청에 대해 허용하기 위해 사용되는 토큰일 수 있다. 예를 들어, 해당 토큰을 사용하지 않는 미인증 요청은 서비스 제공을 제한할 수 있다. 일 실시예에 따르면, 클라이언트 어플리케이션에 대한 인증 절차는 생략할 수도 있고, 동작 610 보다 먼저 수행할 수도 있다.
동작 620에서, 전자 장치(101)의 MSE(530)는 MEC 시스템(405)과 디스커버리(예: MEC service discovery) 절차를 수행할 수 있다. 다양한 실시예들에 따르면, MSE(530)는 수신된 인증 정보(예: MAT)를 사용하여, 전자 장치(101)에 가장 가까이 위치하거나, 또는 최적의 MEC 어플리케이션에 접속하기 위한 디스커버리 절차를 수행할 수 있다. 일 실시예에 따르면, 디스커버리 절차는 MEC 시스템(405)에서 제공 가능한 어플리케이션(들)(예: 도 4의 MEC 어플리케이션(들)( 460-1, 460-2))을 확인(또는 발견(discovery))하는 일련의 절차를 포함할 수 있다. 다양한 실시예들에 따른, 디스커버리 절차에 관한 설명은 후술하는 도면들을 참조하여 상세히 설명된다. 일 실시예에 따르면, 전자 장치(101)는 다양한 실시예들에 따른 인증 절차(예: 동작 610)를 수행하고, 상기 인증 절차에 이어서, 후술하는 바와 같은 다양한 실시예들에 따른 디스커버리 절차를 수행할 수 있다. 다른 실시예에 따르면, 전자 장치(101)는, 예를 들면, ETSI(European telecommunication standards institute)의 MEC 규격에 정의되어 있는 동작(예: application lookup, context create/delete)을 위한 메시지 교환 방식을 참조하여 수행할 수도 있다.
동작 630에서, 전자 장치(101)는 디스커버리 절차 이후 MEC 시스템(405)과 데이터 전송을 수행할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 클라이언트 어플리케이션(510)은 접속하고자 하는 MEC 호스트(예: 엣지 서버 또는 MEC 서버)의 URI로부터 DNS 리졸빙(resolving)을 수행하여, 전자 장치(101)에 가장 가까운 MEC 호스트의 IP 주소를 획득(또는 수신)하여 최적 MEC 어플리케이션에 접속할 수 있다. 다양한 실시예들에 따르면, 클라이언트 어플리케이션(510)은 제공된 접속 토큰에 기반하여 MEC 시스템(405)과 추가적인 인증 절차를 수행하지 않고, 데이터 전송을 수행할 수 있다. 도 6에서는 하나의 클라이언트 어플리케이션(510)이 데이터 전송을 수행하는 실시예를 도시하였지만, 복수의 어플리케이션들이 데이터 전송을 수행하는 경우, 복수의 어플리케이션들은 개별적으로 MEC 시스템(405)과 인증 절차를 수행할 필요 없이, MSA(520)를 통해 획득된 접속 토큰(MAT)을 통해 데이터 전송을 수행할 수 있으므로 네트워크 부하가 감소할 수 있다.
MEC 인증 절차
도 7은 다양한 실시예들에 따른 전자 장치(101)의 동작 방법을 도시하는 흐름도이다.
다양한 실시예들에서, 도 7에 도시된 동작들은, 예를 들어, 전자 장치(101) 또는 전자 장치(101)에 포함된 구성 요소(예: 도 1의 프로세서(120), 도 4의 MEC 서비스 모듈(410))에 의하여 수행될 수 있다.
도 7을 참조하면, 동작 701에서, 전자 장치(101)는 전자 장치(101)의 이동성과 관련된 이벤트를 감지할 수 있다. 예를 들어, 전자 장치(101)는 컨텍스트 정보(예: 어플리케이션에 관한 정보, 이동성과 관련된 정보, 어플리케이션의 라이프 사이클 정보, 전자 장치(101)의 상태에 관한 정보, 센서 정보, 또는 네트워크 성능 정보)를 모니터링 할 수 있고, 모니터링 하는 결과에 기반하여 이동성과 관련된 정보(예: 전자 장치(101)의 움직임을 나타내는 정보, 전자 장치(101)와 연결된 기지국의 변경과 관련된 정보, 또는 전자 장치(101)가 지정된 영역에 진입하는 지와 관련된 정보)를 획득(또는 확인)하는 것에 기반하여 이동성과 관련된 이벤트를 식별할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 동작 701을 수행할 수도 있고, 생략할 수도 있다.
동작 703에서, 전자 장치(101)는 MEC 서비스 모듈(410)(예: MSA(520))을 이용하여 MEC 시스템(405)과 인증 절차를 수행할 수 있다. 예를 들어, 전자 장치(101)는 전자 장치(101)가 지정된 지역에 진입함을 감지한 것에 응답하여 인증 절차를 수행할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 후술하는 다양한 실시예들에 따른 인증 절차에 따라서 인증 절차를 수행할 수 있고, MEC 시스템(405)(예: AA 서버(580), MMP 서버(430))로부터 접근 토큰(예: MAT)을 획득할 수 있다.
동작 705에서, 전자 장치(101)는 MEC 서비스 모듈(410)과 MEC 시스템(405) 간 수행된 인증 절차에 기반하여 적어도 하나의 어플리케이션에 대한 데이터 전송을 수행할 수 있다.
이하, 다양한 실시예들에 따른 MEC 인증 절차에 대하여 살펴보기로 한다. 다양한 실시예들에 따르면, 서비스 제공 형태(또는 모델)에 기반하여 다양한 인증 시나리오(scenario)(예: 시나리오 A, 시나리오 B, 시나리오 C)를 제공할 수 있다.
다양한 실시예들에서는 3가지의 인증 시나리오를 개시하지만, 이는 다양한 실시예들의 기술 내용을 쉽게 설명하고 본 개시의 이해를 돕기 위해 특정 예를 제시한 것일 뿐이며, 본 개시의 범위를 한정하고자 하는 것은 아니다. 따라서 다양한 실시예들의 범위는 여기에 개시된 실시예들 이외에도 본 개시의 기술적 사상을 바탕으로 도출되는 모든 변경 또는 변형된 형태가 본 개시의 범위에 포함되는 것으로 해석되어야 한다.
도 8은 다양한 실시예들에 따른 전자 장치(101)에서 인증 절차를 위한 동작 방법을 도시하는 흐름도이다.
도 8을 참조하면, 동작 801에서, 전자 장치(101)의 프로세서(120)(또는 도 5의 MSA(520))는 인증 서버(예: 도 5의 AA 서버(580))에 제1 인증(예: authentication)을 위한 제1 요청 메시지를 전송할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSA(520)는 지정된 적어도 하나의 인증 방식에 기반하여 인증 요청(authentication request)을 위한 메시지를 AA 서버(580)로 전송할 수 있다. 일 실시예에 따르면, MSA(520)는 AA 서버(580)와 GPSI(generic public subscription identifier) 기반 Application-layer AKA 방식, ID/password 기반 Login 방식, 또는 GBA 방식을 이용하여 인증을 요청할 수 있다.
동작 803에서, 프로세서(120)는 인증 서버로부터 인증 결과에 따른 제1 인증 정보를 획득할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSA(520)는 AA 서버(580)와 인증을 수행할 수 있고, 인증 결과에 따른 인증 정보를 AA 서버(580)로부터 획득(또는 수신)할 수 있다. 인증 정보는, 예를 들어, MMP 관련 정보(이하, ‘MMP Info’라 한다) 및 권한 부여 코드(Authorization code)(이하, ‘Auth Code’라 한다)를 포함할 수 있다. 일 실시예에 따라, 인증 정보는 상기의 정보 외에, 추가적으로(또는 선택적으로) 필요한 정보, 예를 들어, 인증을 위한 식별 토큰(예: ID_token) 또는 MEC 데이터 서비스를 위한 CARP 또는 URSP 규칙(rules) 중 적어도 하나를 더 포함할 수 있다. 일 실시예에 따라, MMP Info는, 예를 들어, MMP 서버(430) 접속에 관련된 정보(예: MMP 접속 주소)를 포함할 수 있다. 예를 들어, MMP Info는 접속할 새로운 MMP 서버(430)의 주소 정보(예: URI(uniform resource identifier) 또는 IP 주소)와 해당 주소 정보의 유효 시간 및/또는 장소에 관련된 정보를 포함할 수 있다. 일 실시예에 따라, Auth Code는, 예를 들어, MMP 서버(430)로부터 접속 토큰(예: MAT)을 요청하는 데 필요한 코드(예: OAuth2.0 기반)를 포함할 수 있다. 일 실시예에 따라, CARP 또는 URSP 규칙은, 예를 들어, DNN 구성(configuration) 관련 정보, DNN 별 사용 가능한 어플리케이션(또는 어플리케이션 그룹)에 관련된 정보, 또는 이후 설정 가능한 DNN 리스트(list) 또는 설정 가능한 DNN 최대 개수에 관련된 정보를 포함할 수 있다.
동작 805에서, 프로세서(120)는 클라이언트 어플리케이션을 위한 PDU 세션(예: MEC 용 전용 PDU 세션)을 설정(setup)(예: 정책 업데이트)할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSA(520)는 CARP 규칙 또는 URSP 규칙(예: DNN)에 따라 MSE(530)를 통해 PDU 세션을 설정할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSA(520)는 인증 절차가 완료되면, MSE(530)와 정책 업데이트(policy update)를 수행(예: PDU 세션 설정)할 수 있다. 일 실시예에 따르면, MSA(520)는 기본 PDU 세션을 변경하거나, 새로운 전용 PDU 세션을 추가로 설정할 수 있다. 일 실시예에 따르면, 동작 807의 정책 업데이트를 위한 PDU 세션 설정 동작은, 예를 들어, MSA(520)가 AA 서버(580)로부터 CARP 또는 URSP 규칙이 제공되는 경우 수행할 수 있다. 일 실시예에 따라, MSA(520)는 CARP 또는 URSP 규칙(예: DNN)에 따라 초기 PDU 세션 설정을 수행할 수 있다. 일 실시예에 따르면, MSA(520)는 MMP 서버(430)로부터 수신 정보에 URSP 규칙이 있는 경우, MSE API를 이용하여 URSP 규칙을 업데이트 할 수 있다.
동작 807에서, 프로세서(120)는 제1 인증 정보에 기반하여, MMP 서버(430)로 제2 인증(예: authorization, 권한 부여)을 위한 제2 요청 메시지를 전송할 수 있다. 일 실시예에 따라, 제2 인증(예: authorization)은 서비스 사용에 대한 권한 요청 및 권한 요청에 따른 권한 부여(예: 접속 토큰(access token) 발행)를 획득하기 위한 절차를 포함할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSA(520)는 인증 완료 후(또는 MSE(530)와 정책 업데이트 수행 또는 생략한 이후), 권한 부여(authorization) 요청(authorization request)을 위한 메시지를 MMP 서버(430)로 전송할 수 있다. 일 실시예에 따르면, MSA(520)는 AA 서버(580)로부터 획득된 인증 정보(예: Auth Code 또는 추가적으로 식별 토큰(ID_token) 포함)에 기반하여, MMP 서버(430)에 인증을 요청할 수 있다.
동작 809에서, 프로세서(120)는 MMP 서버(430)로부터 인증 결과에 따른 제2 인증 정보를 획득할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSA(520)는 MMP 서버(430)를 통해 AA 서버(580)와 권한 부여 절차를 수행할 수 있고, 인증 결과에 따른 인증 정보를 MMP 서버(430)로부터 획득(또는 수신)할 수 있다. 인증 정보는, 예를 들어, 접속 토큰(예: MAT)과 MMP Info를 포함할 수 있다.
동작 811에서, 프로세서(120)는 제2 인증 정보에 기반하여 해당 MMP 서버(430)에 접속하여 디스커버리 절차를 수행할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSA(520)는 MMP 서버(430)로부터, 인증 결과에 따른 인증 정보(예: MAT)를 수신하는 경우, 수신된 인증 정보를 전자 장치(101)의 MSE(530)에 전달하고, MSE(530)를 활성화 할 수 있다. 일 실시예에 따르면, MSA(520)는 인증 정보와 함께, MEC 디스커버리 절차를 수행하기 위해 접속할 새로운 MMP 서버(430)의 접속 주소(예: URI 또는 IP 주소), DNS 서버 주소, 또는 사용할 DNN과 같은 적어도 하나의 부가 정보를 MSE API를 통해 MSE(530)로 전달할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSE(530)는 인증 정보(예: MAT) 및/또는 그 외의 다른 부가 정보(예: MMP Info, DNS 서버 주소, 또는 사용할 DNN)에 적어도 기반하여 MEC 디스커버리 절차를 수행할 수 있다. 일 실시예에 따르면, MSE(530)는 MMP Info 및 MAT를 사용하여 해당 MMP 서버(430)에 접속 후 MEC 디스커버리 절차를 수행할 수 있다. 일 실시예에 따르면, 프로세서(120)는 제2 인증 정보에 새로운 MMP 서버(430)에 관련된 MMP Info가 포함되어 있지 않은 경우, 제1 인증 정보에 포함된 MMP Info에 기반하여 MEC 디스커버리 절차를 수행할 수도 있다.
다양한 실시예들에 따르면, 도 8에 도시된 인증 절차는, 예를 들어, 클라이언트 어플리케이션(510)이 기본 PDU 세션(또는 PDN)을 사용하여 MEC 어플리케이션에 연결하는 시나리오를 포함할 수 있다. 예를 들어, MSE(530)(예: MEL(531))에서 MEC 디스커버리 절차를 수행하여, 전자 장치(101)에 가까운 MEC 호스트에 MEC 어플리케이션 구동 및 연결을 요청하고, 해당 MEC 어플리케이션의 URI를 수신할 수 있다. 이후, 클라이언트 어플리케이션(510)이 해당 MEC 어플리케이션 접속 요청 시, 해당 URI에 대한 DNS 리졸빙을 통해 획득한 MEC 어플리케이션 IP 주소로 접속할 수 있다.
다양한 실시예들에 따르면, 도 8에 도시된 인증 절차는, 예를 들어, 클라이언트 어플리케이션이 기본 PDU 세션(또는 PDN) 외에, 별도의 MEC 전용 PDU 세션을 생성하여 MEC 어플리케이션에 연결하는 시나리오를 포함할 수 있다. 예를 들어, MEC 전용 PDU 세션 생성은 사업자(예: MNO 또는 MMP 서버(430)) 정책에 따르며, MSA(520) 또는 인증된 클라이언트 어플리케이션이 MSE API를 사용하여 UHL(533)을 통해 생성 할 수 있다. 일 실시예에 따라, MEC 전용 PDU 세션은 기본 PDU 세션 외에, 하나 이상의 PDU 세션을 항상 열어둘 수도 있고, 특정 시점에 필요에 따라 MEL(531)의 요청에 의해 동적으로 생성하거나 해제할 수 있다. 일 실시예에 따르면, 사전에 정의된 규칙(rule)(예: CARP 또는 URSP 규칙) 또는 외부 서버(예: MMP 서버(430), AA 서버(580), 또는 AMF/PCF 서버(590))로부터 수신한 라우팅 규칙에 따라 해당 클라이언트 어플리케이션(또는 UID) 또는 접속 URI에 대한 트래픽을 MEC 전용 PDU 세션으로 라우팅 되도록 MSE(530)의 UHL(533)에서 지원할 수 있다.
다양한 실시예들에 따르면, 도 8에 도시된 인증 절차는, 예를 들어, 특정 서비스에 대해 전용 PDU 세션만 생성하여 사용하는 시나리오를 포함할 수 있다. 일 실시예에 따르면, MSA(520) 또는 인증된 클라이언트 어플리케이션(510)에 MSE API를 사용하여 별도의 전용 PDU 세션을 생성하고, 해당 PDU 세션을 사용하는 어플리케이션(예: UID) 규칙을 등록하고, 해당 어플리케이션의 트래픽을 해당 PDU 세션으로 라우팅 되도록 할 수 있다.
도 9는 다양한 실시예들에 따른 인증 절차의 예를 도시하는 도면이다.
도 9에 도시한 바와 같이, 전자 장치(101)는 MSA(또는 서비스 에이전트)(520)(예: AA 클라이언트(525) 포함)와 MSE(또는 서비스 인에이블러)(530)(예: MEL(531), UHL(533) 포함)를 포함할 수 있다.
도 9을 참조하면, 동작 901에서, 전자 장치(101)의 MSA(520)는 지정된 적어도 하나의 인증 방식(예: 제1 인증)에 기반하여 인증(예: 제1 인증) 요청(authentication request)을 위한 메시지(예: 제1 요청 메시지)를 AA 서버(580)에 전송할 수 있다. 일 실시예에 따르면, MSA(520)는 AA 서버(580)와 GPSI(generic public subscription identifier) 기반 Application-layer AKA 방식, ID/password 기반 Login 방식, 또는 GBA 방식을 이용하여 인증을 요청할 수 있다.
동작 903에서, MSA(520)는 AA 서버(580)와 인증을 수행할 수 있다. 일 실시예에 따라, MSA(520)는 AA 서버(580)와 GPSI 기반 사용자 인증(user authentication)을 수행할 수 있다.
동작 905에서, AA 서버(580)는 전자 장치(101)로부터 인증 요청을 수신하는 경우, 전자 장치(101)와 인증을 수행하고, 인증을 완료(예: 인증 절차 완료)하는 경우, 인증 결과에 따른 인증 정보(예: 제1 인증 정보)를 전자 장치(101)(예: MSA(520))에 제공(또는 전송)할 수 있다. 일 실시예에 따르면, 인증 정보는, 예를 들어, MMP 관련 정보(이하, ‘MMP Info’라 한다) 및 권한 부여 코드(Authorization code)(이하, ‘Auth Code’라 한다)를 포함할 수 있다. 일 실시예에 따라, MMP 서버(430)는 상기의 정보 외에, 추가적으로(또는 선택적으로) 필요한 정보, 예를 들어, 인증을 위한 ID_token 또는 MEC 데이터 서비스를 위한 CARP 또는 URSP 규칙(rules) 중 적어도 하나를 인증 정보에 더 포함하여 제공할 수 있다.
일 실시예에 따라, MMP Info는, 예를 들어, MMP 서버(430) 접속에 관련된 정보(예: MMP 접속 주소)를 포함할 수 있다. 예를 들어, MMP Info는 접속할 새로운 MMP 서버(430)의 주소 정보(예: URI(uniform resource identifier) 또는 IP 주소)와 해당 주소 정보의 유효 시간 및/또는 장소에 관련된 정보를 포함할 수 있다. 일 실시예에 따라, Auth Code는, 예를 들어, MMP 서버(430)로부터 접속 토큰(예: MAT, MEC access token))을 요청하는 데 필요한 코드(예: OAuth2.0 기반)를 포함할 수 있다. 일 실시예에 따라, CARP 또는 URSP 규칙은, 예를 들어, PDU 세션 설정(PDU session setup)을 위한 관련 정보(예: DNN), DNN 별 사용 가능한 어플리케이션(또는 어플리케이션 그룹)에 관련된 정보, 또는 이후 설정 가능한 DNN 리스트(list) 또는 설정 가능한 DNN 최대 개수에 관련된 정보를 포함할 수 있다.
동작 907에서, MSA(520)는 AA 서버(580)와 인증 절차가 완료되면, MSE(530)와 정책 업데이트(policy update)를 수행(예: PDU 세션 설정(PDU session setup))할 수 있다. 일 실시예에 따라, MSA(520)는 CARP 규칙 또는 URSP 규칙(예: DNN)에 따라 PDU 세션 설정을 수행할 수 있다. 예를 들어, MSA(520)는 CARP 규칙 또는 URSP 규칙에 따라 PDU 세션 설정 수행 여부에 대한 정책을 식별할 수 있고, CARP 규칙 또는 URSP 규칙에 따라 MSE API를 통해 PDU 세션 설정 요청을 MSE(530)로 전달할 수 있다. MSE(530)는 MSA(520)의 PDU 세션 설정 요청에 대응하여, PDU 세션 설정을 수행할 수 있다. 일 실시예에 따르면, MSA(520)는 기본 PDU 세션을 변경하거나, 새로운 전용 PDU 세션을 추가로 형성(establishment)할 수 있다.
일 실시예에 따르면, 동작 907의 MSA(520)와 MSE(530)의 정책 업데이트 동작은, 예를 들어, MSA(520)가 AA 서버(580)로부터 CARP 또는 URSP 규칙(rule)이 제공되는 경우 수행할 수 있다. 일 실시예에 따르면, MSA(520)는 AA 서버(580)로부터 CARP 또는 URSP 규칙이 제공되지 않는 경우 MSE(530)와 정책 업데이트를 수행하지 않을 수도 있다. 다른 실시예에 따르면, MSA(520)는 AA 서버(580)로부터 CARP 또는 URSP 규칙이 제공되더라도 MSA(520)의 자체적인 판단 또는 MSE(530)와의 정보 교환을 통해 정책 업데이트를 수행하지 않을 수도 있다.
동작 909에서, MSA(520)는 인증 완료 후(또는 MSE(530)와 정책 업데이트 수행 또는 생략한 이후), 권한 부여(authorization)(예: 제2 인증) 요청(authorization request)을 위한 메시지(예: 제2 요청 메시지)를 MMP 서버(430)에 전송할 수 있다. 일 실시예에 따르면, MSA(520)는 AA 서버(580)로부터 획득된 인증 정보(예: Auth Code 또는 추가적으로 ID_token 포함)에 기반하여, MMP 서버(430)에 인증을 요청할 수 있다.
동작 911에서, MSA(520)는 MMP 서버(430)를 통해 AA 서버(580)와 인증(예: 권한 부여 절차)을 수행할 수 있다. 일 실시예에 따라, MSA(520)는 AA 서버(580)와 Auth Code에 기반하여 서비스 사용에 대한 권한 부여(service authorization)을 수행할 수 있다.
동작 913에서, MMP 서버(430)는 MSA(520)의 인증 요청(예: 제2 요청 메시지)에 대응하여, 인증 결과에 따른 인증 정보(예: 제2 인증 정보)를 전자 장치(101)(예: MSA(520))에 제공(또는 전송)할 수 있다. 일 실시예에 따르면, 인증 정보는, 예를 들어, 접속 토큰(예: MAT, MEC access Token)과 MMP Info를 포함할 수 있다. 일 실시예에 따르면, MMP 서버(430)는 MSA(520)의 인증 수행 중 또는 수행 이후에 접속 토큰을 포함하는 응답을 MSA(520)에 전송할 수 있다.
동작 915에서, MSA(520)는 MSE(530)를 활성화 할 수 있다. 일 실시예에 따르면, MSA(520)는 AA 서버(580)와 인증 수행 중 또는 수행 후에, MMP 서버(430)로부터, 인증 결과에 따른 인증 정보(예: 접속 토큰(MAT))를 수신하는 경우, 수신된 인증 정보(예: 접속 토큰(MAT))를 MSE(530)에 전달하여 MSE(530)를 활성화 할 수 있다. 일 실시예에 따르면, MSA(520)는 인증 정보(예: 접속 토큰(MAT))와 함께, MEC 디스커버리 절차를 수행하기 위해 접속할 새로운 MMP 서버(430)의 접속 주소(예: URI 또는 IP 주소), DNS 서버 주소, 또는 사용할 DNN과 같은 적어도 하나의 부가 정보를 MSE(530)에 전달할 수 있다. 일 실시예에 따르면, MSA(520)는 수신된 접속 토큰(MAT) 및/또는 그 외의 다른 부가 정보에 기반하여 MSE(530)를 활성화(enable MEC)할 수 있다. 일 실시예에 따르면, MSA(520)가 MMP 서버(430)와 인증(예: 권한 부여)을 수행하는 경우, MSA(520)는 MMP 서버(430)로부터, 인증 결과로 접속 토큰(예: MAT)을 수신할 수 있으며, 예를 들어, MSE API의 enableMecEnablingLayer(true, MMP Info, MAT)를 호출함으로써, MSE(530)에 MMP 접속 정보(MMP Info) 및 접속 토큰(MAT)을 전달할 수 있다.
동작 917에서, MSE(530)는 인증 정보(예: MAT) 및/또는 그 외의 다른 부가 정보(예: MMP Info, DNS 서버 주소, 또는 사용할 DNN)을 수신하고, 인증 정보 및/또는 부가 정보에 적어도 기반하여 MEC 디스커버리 절차를 수행할 수 있다. 일 실시예에 따르면, MSE(530)는 MMP Info 및 MAT를 사용하여 해당 MMP 서버(430)에 접속 후 MEC 디스커버리 절차를 수행할 수 있다.
도 9에서는 도시하지 않았으나, 다른 실시예에 따르면, MSE(530)가 MMP 서버(430)와 인증(예: 동작 911의 service authorization)을 수행할 수 있다. 일 실시예에 따르면, MSE(530)가 MMP 서버(580)와 인증(예: 권한 부여)을 수행하는 경우, 우선 인증을 완료한 MSA(520)가 MMP 서버(430)로부터, 인증 결과로 MMP Info와 Auth Code 및/또는 그 외의 다른 부가 정보(예: 식별 토큰(ID_token))을 수신할 수 있으며, 예를 들어, MSE(530) 활성화를 위해, MSE API의 enableMecEnablingLayer(true, MMP Info, Auth Code, [ID-Token])를 호출함으로써, MSE(530)에 전달할 수 있다. MSE(530)는 MSA(520)로부터 전달받은 정보로부터 MMP 서버(430)와 직접 권한 부여(Authorization)을 수행하고, 그 결과로 MAT를 수신(또는 획득)할 수 있다. 예를 들면, 도 9의 동작과 대비할 때, 전자 장치(101)의 내부 구성 중 권한 부여를 위한 서비스 인증 절차를 수행하는 주체가 MSA(520)인 경우와 MSE(530)인 경우로 구분될 수 있다.
도 10은 다양한 실시예들에 따른 인증 절차의 예를 도시하는 도면이다.
도 10에 도시한 바와 같이, 도 10은 다양한 실시예들에 따른 인증 절차(예: AA(authentication/authorization) 및 정책 업데이트(policy update)에 관한 시나리오 A)를 위한 신호 흐름의 예를 나타낼 수 있다. 예를 들어, 도 10은 다양한 실시예들에 따른 인증 절차 중 시나리오 A를 위한 MEC 서비스 인증 플로우의 예를 나타낸 것으로, 도 9에 따른 동작 901, 동작 903, 및 동작 905에 대응하는 “User Authentication(또는 Subscriber Authentication)”의 상세 실시예에 따른 동작(예: 동작 1010)과 도 9에 따른 동작 909, 동작 911, 및 동작 913에 대응하는 “MEC Service Authorization”의 상세 실시예에 따른 동작(예: 동작 1020)을 포함할 수 있다. 일 실시예에 따르면, MEC AA 및 정책 업데이트를 위한 시나리오 A는, 도 10에 도시한 바와 같이, User Authentication(예: 동작 1010) 이후에 MEC Service Authorization(예: 동작 1020)를 수행하는 시나리오 예를 나타낼 수 있다.
도 10을 참조하면, 동작 1001에서, 전자 장치(101)의 MSA(520)는 인증 요청을 위한 메시지를 인타이틀먼트(entitlement) 서버(1000)로 전송할 수 있다.
동작 1003에서, 인타이틀먼트 서버(1000)는 인증 방식(authentication method)을 결정할 수 있다. 일 실시예에 따르면, 인타이틀먼트 서버(1000)는 지정된 적어도 하나의 인증 방식에서 전자 장치(101)의 인증 요청에 대응하는 인증 방식을 결정할 수 있다. 일 실시예에 따라, 적어도 하나의 인증 방식은, 예를 들어, GPSI를 이용한 Application-layer AKA 또는 Login(예: ID/password) 방식의 인증(authentication)을 포함할 수 있다. 일 실시예에 따르면, MSA(520)가 가입자 식별 정보(또는 단말 식별 정보)(예: GPSI 또는 IMSI)를 인타이틀먼트 서버(1000)에 전달하면서 권한 코드를 요청할 수 있다. 일 실시예에 따라, MSA(520)와 인타이틀먼트 서버(1000)는, 동작 1010에서와 같이, Application-layer AKA 또는 Loging 방식으로 사용자 인증(user authentication)을 수행할 수 있다.
일 실시예에 따르면, 동작 1005에서, MSA(520)는 인타이틀먼트 서버(1000)를 통해 AA 서버(580) 간에 Application-layer AKA 방식에 기반하여 인증(authentication)(예: MEC 가입자 인증) 절차를 수행하고, AA 서버(580)로부터 인증 결과에 따른 인증 정보를 포함하는 인증 응답(authentication response)을 획득할 수 있다. 다른 실시예에 따르면, 동작 1007에서, MSA(520)는 인타이틀먼트 서버(1000)와 ID/password 기반 Login 방식에 기반하여 인증(authentication) 절차를 수행하고, 동작 1009에서, 인타이틀먼트 서버(1000)에 로그인 성공(Login Success)에 기반하여 인타이틀먼트 서버(1000)로부터 인증 결과에 따른 인증 정보를 포함하는 인증 응답을 획득할 수 있다.
동작 1011에서, MSA(520)는 인증 요청에 대응하는 인증 응답(authentication response)을 수신할 수 있다. 예를 들어, 동작 1011에서, MSA(520)는 인타이틀먼트 서버(1000) 또는 인타이틀먼트 서버(1000)를 통해 AA 서버(580)로부터 인증 결과에 따른 인증 정보(예: MMP Info, Auth Code, ID_token, CARP 규칙, 또는 URSP 규칙)를 획득할 수 있다. 예를 들어, MSA(520)는 인증 결과로 MEC 디스커버리 절차를 수행할 MMP 관련 정보(예: MMP 접속 주소)와 권한 부여(authorization)를 위한 권한 코드(예: Auth code) 및 ID_token을 수신할 수 있다. 일 실시예에 따르면, MSA(520)는, AA 서버(580)의 지원 여부에 기반하여, MEC 데이터 서비스를 위한 CARP 또는 URSP 규칙에 관련된 정보를 수신할 수도 있다.
일 실시예에 따르면, MSA(520)는, 동작 1010에서와 같은 “User Authentication” 이후, 동작 1020에서와 같이 “MEC Service Authorization”을 수행할 수 있다.
일 실시예에 따르면, 동작 1013에서, MSA(520)는 인증 완료 후, 권한 부여(authorization) 요청(authorization request)을 위한 메시지를 MMP 서버(430)로 전송할 수 있다. 예를 들어, MSA(520)는 획득된 인증 정보(예: Auth Code 또는 추가적으로 ID_token 포함)를 MMP 서버(430)로 전달하여 MMP 서버(430)에 권한 부여를 요청할 수 있다. 예를 들어, MSA(520)는 인증 완료 후, MMP 접속 주소를 이용하여 MMP 서버(430)에 접속하여 권한 부여(authorization) 절차를 수행할 수 있다.
동작 1015에서, MMP 서버(430)는 인타이틀먼트 서버(1000)에 접속 토큰(access token)을 요청할 수 있고, 동작 1017에서, 인타이틀먼트 서버(1000)로부터 접속 토큰을 획득할 수 있다. 일 실시예에 따르면, MMP 서버(430)는 인타이틀먼트 서버(1000)와 통신 또는 인타이틀먼트 서버(1000)를 통해 AA 서버(580)와 통신하여, 전자 장치(101)가 MEC 서비스 가입자인지 여부를 확인할 수 있다. 일 실시예에 따르면, MMP 서버(430)는 AA 서버(580)를 통해 MEC 서비스 가입자임을 확인하면, MSA(520)에 접속 토큰(예: MAT)을 발행(예: 권한 부여(authorization))할 수 있다.
동작 1019에서, MMP 서버(430)는 MMP 정보와 권한 코드를 인타이틀먼트 서버(1000)(또는 AA 서버(580))에 전달하며, 사용자 프로필(user profile) 정보 접근을 위한 접속 토큰을 요청하여 획득할 수 있다.
동작 1021에서, MMP 서버(430)는 권한 부여 요청에 대응하는 권한 부여 응답(authorization response)을 MSA(520)로 전송할 수 있다. 일 실시예에 따르면, MMP 서버(430)는 해당 접속 토큰을 이용하여 사용자 프로필을 확인하고, 사용자 프로필에 기반하여 MEC 서비스가 가용하다는 것이 확인된 경우 MSA(520)에 MMP Info, MAT, 또는 CARP 규칙을 포함하여 Authorization response를 전달할 수 있다.
일 실시예에 따르면, 동작 1021에서, MSA(520)는 권한 부여 절차의 결과로 접속 토큰(예: MAT)을 획득할 수 있다. 일 실시예에 따라, MSA(520)가 MMP 서버(430)와 권한 부여 절차를 수행하는 경우, MSA(520)는 권한 부여 절차의 결과로 접속 토큰을 수신하며, MSE API를 통해 MSE(530)로 MMP 정보 및 접속 토큰을 전달할 수 있다. 다른 실시예에 따라, MSE(530)가 MMP 서버(430)와 권한 부여 절차를 수행하는 경우, 우선 인증을 완료한 MSA(520)가 인타이틀먼트 서버(1000)로부터 수신한 MMP 정보 및 권한 코드(Auth code)와, 선택적으로 ID_token을 MSE API를 통해 MSE(530)로 전달할 수 있다. MSE(530)는 MSA(520)로부터 전달된 정보에 기반하여 MMP 서버(430)와 직접 권한 부여 절차를 수행하고 그 결과로 접속 토큰을 수신할 수 있다.
동작 1023에서, MSA(520)는 MSE(530)를 통해, MMP Info 및 접속 토큰을 이용하여 MEC 디스커버리 절차를 수행할 수 있다.
도 11은 다양한 실시예들에 따른 전자 장치(101)에서 인증 절차를 위한 동작 방법을 도시하는 흐름도이다.
도 11을 참조하면, 동작 1101에서, 전자 장치(101)의 프로세서(120)(또는 도 5의 MSA(520))는 MMP 서버(430)로 인증을 위한 요청 메시지를 전송할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSA(520)는 지정된 적어도 하나의 인증 방식에 기반하여 서비스 사용을 위한 권한 부여 요청(authorization request)을 위한 메시지(예: 권한 요청 메시지)를 MMP 서버(430)로 전송할 수 있다. 일 실시예에 따르면, MSA(520)는 MMP 서버(430)에 서비스 사용에 대한 권한 부여를 요청할 때, MNO 정보와 장치 식별자(Device ID)(예: IMSI, IMEI, GPSI, 또는 별도 할당된 고유 식별자) 중 적어도 하나 또는 모두를 MMP 서버(430)로 전송할 수 있다. 일 실시예에 따라, Device ID는 MMP 서버(430)가 전자 장치(101)를 고유하게(unique)하게 식별 가능한 식별자(예: UID)를 포함할 수 있다.
동작 1103에서, 프로세서(120)는 MMP 서버(430)로부터 인증 결과에 따른 인증 정보를 획득할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSA(520)는 MMP 서버(430)와 인증(예: AA, authentication & authorization)을 수행할 수 있고, 인증 결과에 따른 인증 정보를 MMP 서버(430)로부터 획득할 수 있다. 인증 정보는, 예를 들어, MMP Info와 접속 토큰(예: MAT)을 포함할 수 있다. 일 실시예에 따라, 인증 정보는 상기의 정보 외에, 추가적으로(또는 선택적으로) 필요한 정보, 예를 들어, MEC 데이터 서비스를 위한 CARP 또는 URSP 규칙(rules) 중 적어도 하나를 더 포함할 수 있다. 일 실시예에 따라, MMP Info는, 예를 들어, MMP 서버(430) 접속에 관련된 정보(예: MMP 접속 주소)를 포함할 수 있다. 예를 들어, MMP Info는 접속할 새로운 MMP 서버(430)의 주소 정보(예: URI 또는 IP 주소)와 해당 주소 정보의 유효 시간 및/또는 장소에 관련된 정보를 포함할 수 있다. 일 실시예에 따라, 접속 토큰(예: MAT)은, 예를 들어, MEC 디스커버리 권한 확인용 접속 토큰을 포함할 수 있다. 일 실시예에 따라, CARP 또는 URSP 규칙은, 예를 들어, DNN 구성(configuration) 관련 정보, DNN 별 사용 가능한 어플리케이션(또는 어플리케이션 그룹)에 관련된 정보, 또는 이후 설정 가능한 DNN 리스트(list) 또는 설정 가능한 DNN 최대 개수에 관련된 정보를 포함할 수 있다.
동작 1105에서, 프로세서(120)는 클라이언트 어플리케이션을 위한 PDU 세션(예: MEC 용 전용 PDU 세션)을 설정(setup)할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSA(520)는 인증 절차가 완료되면, MSE(530)와 정책 업데이트(policy update)를 수행(예: PDU 세션 설정)할 수 있다. 일 실시예에 따라, MSA(520)는 CARP 또는 URSP 규칙(예: DNN)에 따라 초기 PDU 세션 설정을 수행할 수 있다. 일 실시예에 따르면, MSA(520)는 MMP 서버(430)로부터 수신 정보에 URSP 규칙이 있는 경우, MSE API를 이용하여 URSP 규칙을 업데이트 할 수 있다.
동작 1107에서, 프로세서(120)는 인증 정보에 기반하여 해당 MMP 서버(430)에 접속하여 디스커버리 절차를 수행할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSA(520)는 MMP 서버(430)로부터, 인증 결과에 따른 인증 정보(예: MAT)를 수신하는 경우, 수신된 인증 정보를 전자 장치(101)의 MSE(530)에 전달하고, MSE(530)를 활성화 할 수 있다. 일 실시예에 따르면, MSA(520)는 인증 정보와 함께, MEC 디스커버리 절차를 수행하기 위해 접속할 새로운 MMP 서버(430)의 접속 주소(예: URI 또는 IP 주소), DNS 서버 주소, 또는 사용할 DNN과 같은 적어도 하나의 부가 정보를 MSE API를 통해 MSE(530)로 전달할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSE(530)는 인증 정보(예: MAT) 및/또는 그 외의 다른 부가 정보(예: MMP Info, DNS 서버 주소, 또는 사용할 DNN)에 적어도 기반하여 MEC 디스커버리 절차를 수행할 수 있다. 일 실시예에 따르면, MSE(530)는 MMP Info 및 MAT를 사용하여 해당 MMP 서버(430)에 접속 후 MEC 디스커버리 절차를 수행할 수 있다.
다양한 실시예들에 따르면, 도 11에 도시된 인증 절차는, 예를 들어, 클라이언트 어플리케이션(510)이 기본 PDU 세션(또는 PDN)을 사용하여 MEC 어플리케이션에 연결하는 시나리오를 포함할 수 있다. 예를 들어, MSE(530)(예: MEL(531))에서 MEC 디스커버리 절차를 수행하여, 전자 장치(101)에 가까운 MEC 호스트에 MEC 어플리케이션 구동 및 연결을 요청하고, 해당 MEC 어플리케이션의 URI를 수신할 수 있다. 이후, 클라이언트 어플리케이션(510)이 해당 MEC 어플리케이션 접속 요청 시, 해당 URI에 대한 DNS 리졸빙을 통해 획득한 MEC 어플리케이션 IP 주소로 접속할 수 있다.
다양한 실시예들에 따르면, 도 11에 도시된 인증 절차는, 예를 들어, 클라이언트 어플리케이션이 기본 PDU 세션(또는 PDN) 외에, 별도의 MEC 전용 PDU 세션을 생성하여 MEC 어플리케이션에 연결하는 시나리오를 포함할 수 있다. 예를 들어, MEC 전용 PDU 세션 생성은 사업자(예: MNO 또는 MMP 서버(430)) 정책에 따르며, MSA(520) 또는 인증된 클라이언트 어플리케이션이 MSE API를 사용하여 UHL(533)을 통해 생성 할 수 있다. 일 실시예에 따라, MEC 전용 PDU 세션은 기본 PDU 세션 외에, 하나 이상의 PDU 세션을 항상 열어둘 수도 있고, 특정 시점에 필요에 따라 MEL(531)의 요청에 의해 동적으로 생성하거나 해제할 수 있다. 일 실시예에 따르면, 사전에 정의된 규칙(rule)(예: CARP 또는 URSP 규칙) 또는 외부 서버(예: MMP 서버(430), AA 서버(580), 또는 AMF/PCF 서버(590))로부터 수신한 라우팅 규칙에 따라 해당 클라이언트 어플리케이션(또는 UID) 또는 접속 URI에 대한 트래픽을 MEC 전용 PDU 세션으로 라우팅 되도록 MSE(530)의 UHL(533)에서 지원할 수 있다.
다양한 실시예들에 따르면, 도 11에 도시된 인증 절차는, 예를 들어, MEL(531)의 기능 없이, 특정 서비스에 대해 전용 PDU 세션만 생성하여 사용하는 시나리오를 포함할 수 있다. 일 실시예에 따르면, MSA(520) 또는 인증된 클라이언트 어플리케이션(510)에 MSE API를 사용하여 별도의 전용 PDU 세션을 생성하고, 해당 PDU 세션을 사용하는 어플리케이션(예: UID) 규칙을 등록하고, 해당 어플리케이션의 트래픽을 해당 PDU 세션으로 라우팅 되도록 할 수 있다.
도 12는 다양한 실시예들에 따른 인증 절차의 예를 도시하는 도면이다.
도 12에 도시한 바와 같이, 전자 장치(101)는 MSA(또는 서비스 에이전트)(520)(예: AA 클라이언트(525) 포함)와 MSE(또는 서비스 인에이블러)(530)(예: MEL(531), UHL(533) 포함)를 포함할 수 있다.
도 12를 참조하면, 동작 1201에서, 전자 장치(101)의 MSA(520)는 지정된 적어도 하나의 인증 방식에 기반하여 서비스 사용을 위한 권한 부여 요청(authorization request)을 위한 메시지(예: 권한 요청 메시지)를 MMP 서버(430)로 전송할 수 있다. 일 실시예에 따르면, MSA(520)는 MMP 서버(430)에 서비스 사용에 대한 권한 부여를 요청할 때, MNO(mobile network operator)(예: 인타이틀먼트 서버(1000)) 정보와 Device ID(예: IMSI, IMEI, GPSI, 또는 별도 할당된 고유 식별자) 중 적어도 하나 또는 모두를 MMP 서버(430)로 제공(또는 전송)할 수 있다. 일 실시예에 따라, Device ID는 MMP 서버(430)가 전자 장치(101)를 고유하게(unique)하게 식별 가능한 식별자를 포함할 수 있다.
동작 1203에서, MSA(520)는 MMP 서버(430) 또는 MMP 서버(430)를 통해 AA 서버(580)와 인증 및 권한 부여(예: AA, authentication & authorization) 절차를 수행할 수 있다. 예를 들어, MSA(520)는 MMP 서버(430)로 권한 부여 요청(authorization request)을 전달하면, MSA(520), MMP 서버(430), 및 AA 서버(580)의 3자 간 메시지 교환(예: 후술하는 도 13 참조)을 수행할 수 있다. 일 실시예에 따라, MSA(520)는 MMP 서버(430)와 사용자 인증(user authentication)과 서비스 인증(service authorization)(또는 권한 부여)을 수행할 수 있다. 예를 들어, MSA(520)는 전자 장치(101)가 등록되어 있는 사용자인지를 식별하는 절차를 수행하고, 해당하는 서비스를 제공받을 수 있는지를 식별하는 절차를 수행할 수 있다. 일 실시예에 따르면, MMP 서버(430)는 MNO 정보에 따라 AA 방식이 다를 수 있으므로, MNO 정보에 따라 그에 맞는 방식을 사용하여 AA를 수행할 수 있다.
동작 1205에서, MMP 서버(430)는 전자 장치(101)로부터 인증 요청을 수신하는 경우, 전자 장치(101)와 인증을 수행하고, 인증을 완료(예: 인증 절차 완료)하는 경우, 인증 결과에 따른 인증 정보를 전자 장치(101)(예: MSA(520))에 제공(또는 전송)할 수 있다. 일 실시예에 따르면, 인증 정보는, 예를 들어, MMP Info와 접속 토큰(예: MAT)을 포함할 수 있다. 일 실시예에 따라, MMP 서버(430)는 상기의 정보 외에, 추가적으로(또는 선택적으로) 필요한 정보, 예를 들어, MEC 데이터 서비스를 위한 CARP 또는 URSP 규칙(rules) 중 적어도 하나를 인증 정보에 더 포함하여 제공할 수 있다. 일 실시예에 따르면, 동작 1205에서, MSA(520)는 인증 결과에 따른 인증 정보(예: MMP Info, MAT, 및 CARP 또는 URSP 규칙) 모두를 MMP 서버(430)로부터 수신할 수 있다. 다른 실시예에 따르면, 동작 1205에서, MSA(520)는 인증 정보의 일부(예: 디스커버리를 위한 MMP Info, MAT)는 MMP 서버(430)로부터 수신하고, CARP 규칙(또는 URSP 규칙)은 후술하는 도 13의 예시와 같이 사용자 인증(user authentication) 결과로서 AA 서버(580)로부터 수신할 수도 있다.
일 실시예에 따라, MMP Info는, 예를 들어, MMP 서버(430) 접속에 관련된 정보(예: MMP 접속 주소)를 포함할 수 있다. 예를 들어, MMP Info는 접속할 새로운 MMP 서버(430)의 주소 정보(예: URI(uniform resource identifier) 또는 IP 주소)와 해당 주소 정보의 유효 시간 및/또는 장소에 관련된 정보를 포함할 수 있다. 일 실시예에 따라, 접속 토큰(예: MAT)은, 예를 들어, MEC 디스커버리 권한 확인용 접속 토큰을 포함할 수 있다. 일 실시예에 따라, CARP 또는 URSP 규칙은, 예를 들어, DNN 구성(configuration) 관련 정보, DNN 별 사용 가능한 어플리케이션(또는 어플리케이션 그룹)에 관련된 정보, 또는 이후 설정 가능한 DNN 리스트(list) 또는 설정 가능한 DNN 최대 개수에 관련된 정보를 포함할 수 있다.
동작 1207에서, MSA(520)는 인증 절차가 완료되면, MSE(530)와 정책 업데이트(policy update)를 수행(예: PDU 세션 설정(setup))할 수 있다. 일 실시예에 따라, MSA(520)는 CARP 또는 URSP 규칙(예: DNN)에 따라 초기 PDU 세션 설정을 수행할 수 있다. 예를 들어, MSA(520)는 MMP 서버(430)로부터 수신 정보에 URSP 규칙이 있는 경우, MSE API를 이용하여 URSP 규칙을 업데이트 할 수 있다.
일 실시예에 따르면, 동작 1207의 MSA(520)와 MSE(530)의 정책 업데이트 동작은, 예를 들어, MSA(520)가 AA 서버(580)로부터 CARP 또는 URSP 규칙이 제공되는 경우 수행할 수 있다. 일 실시예에 따르면, MSA(520)는 AA 서버(580)로부터 CARP 또는 URSP 규칙이 제공되지 않는 경우 MSE(530)와 정책 업데이트를 수행하지 않을 수도 있다. 다른 실시예에 따르면, MSA(520)는 AA 서버(580)로부터 CARP 또는 URSP 규칙이 제공되더라도 MSA(520)의 자체적인 판단 또는 MSE(530)와의 정보 교환을 통해 정책 업데이트를 수행하지 않을 수도 있다.
동작 1209에서, MSA(520)는 MSE(530)를 활성화 할 수 있다. 일 실시예에 따르면, MSA(520)는 AA 서버(580)와 인증 수행 중 또는 수행 후에, MMP 서버(430)로부터, 인증 결과에 따른 인증 정보(예: 접속 토큰(MAT))를 수신하는 경우, 수신된 인증 정보(예: 접속 토큰(MAT))를 MSE(530)에 전달하여 MES(530)를 활성화 할 수 있다. 일 실시예에 따르면, MSA(520)는 인증 정보(예: 접속 토큰(MAT))와 함께, MEC 디스커버리 절차를 수행하기 위해 접속할 새로운 MMP 서버(430)의 접속 주소(예: URI 또는 IP 주소), DNS 서버 주소, 또는 사용할 DNN과 같은 적어도 하나의 부가 정보를 MSE(530)에 전달할 수 있다. 일 실시예에 따르면, MSA(520)는 수신된 접속 토큰(MAT) 및/또는 그 외의 다른 부가 정보에 기반하여 MSE(530)를 활성화(enable MEC)할 수 있다. 일 실시예에 따르면, MSA(520)가 MMP 서버(430)와 인증을 수행하는 경우, MSA(520)는 MMP 서버(430)로부터, 인증 결과로 접속 토큰(예: MAT)을 수신할 수 있으며, 예를 들어, MSE API의 enableMecEnablingLayer(true, MMP Info, MAT)를 호출함으로써, MSE(530)에 MMP 접속 정보(MMP Info) 및 접속 토큰(MAT)을 전달할 수 있다.
동작 1211에서, MSE(530)는 인증 정보(예: MAT) 및/또는 그 외의 다른 부가 정보(예: MMP Info, DNS 서버 주소, 또는 사용할 DNN)을 수신하고, 인증 정보 및/또는 부가 정보에 적어도 기반하여 MEC 디스커버리 절차를 수행할 수 있다. 일 실시예에 따르면, MSE(530)는 MMP Info 및 MAT를 사용하여 해당 MMP 서버(430)에 접속 후 MEC 디스커버리 절차를 수행할 수 있다.
도 13은 다양한 실시예들에 따른 인증 절차의 예를 도시하는 도면이다.
도 13에 도시한 바와 같이, 도 13은 다양한 실시예들에 따른 인증 절차(예: AA 및 정책 업데이트에 관한 시나리오 B)를 위한 신호 흐름의 예를 나타낼 수 있다. 예를 들어, 도 13은 다양한 실시예들에 따른 인증 절차 중 시나리오 B를 위한 MEC 서비스 인증 플로우의 예를 나타낸 것으로, 도 12에 따른 동작 1201, 동작 1203, 및 동작 1205에 대응하는 상세 실시예를 포함할 수 있다. 일 실시예에 따르면, 도 13에 도시된 실시예에서는, “User Authentication(또는 Subscriber Authentication)” 동작(예: 동작 1320)이 “MEC Service Authorization” 동작(예: 동작 1310)의 일부로 포함될 수 있다. 일 실시예에 따르면, MEC AA 및 정책 업데이트를 위한 시나리오 B는, 도 13에 도시한 바와 같이, User Authentication(예: 동작 1320) 이전에 MEC Service Authorization(예: 동작 1310)을 수행하는 시나리오 예를 나타낼 수 있다.
도 13을 참조하면, 동작 1301에서, 전자 장치(101)의 MSA(520)는 권한 부여 요청(authorization request)을 위한 권한 요청 메시지를 MMP 서버(430)로 전송할 수 있다. 일 실시예에 따라, 권한 요청 메시지는 MNO 정보와 Device ID(예: IMSI, IMEI, GPSI, 또는 별도 할당된 고유 식별자) 중 적어도 하나 또는 모두를 포함할 수 있다.
동작 1303에서, MMP 서버(430)는 인증 방식(authentication method)을 결정할 수 있다. 일 실시예에 따르면, MMP 서버(430)는 지정된 적어도 하나의 인증 방식에서 전자 장치(101)의 권한 부여 요청에 대응하는 인증 방식을 결정할 수 있다. 일 실시예에 따르면, 적어도 하나의 인증 방식은, 예를 들어, Application-layer AKA 또는 Login(예: ID/password) 방식을 포함할 수 있다.
동작 1305에서, MSA(520)는 인타이틀먼트 서버(1000)의 URI를 MMP 서버(430)로 전달할 수 있다.
동작 1307에서, MMP 서버(430)는 인타이틀먼트 서버(1000)로 권한 코드(authorization code)를 요청할 수 있다. 일 실시예에 따르면, MSA(520)가 가입자 식별 정보(또는 단말 식별 정보)(예: GPSI 또는 IMSI)를 MMP 서버(430)에 전달하면, MMP 서버(430)는 해당 정보를 MNO 측의 인타이틀먼트 서버(1000) 또는 AA 서버(580)에 전달하면서 권한 코드(authorization code)를 요청할 수 있다. 일 실시예에 따르면, MSA(520)가 가입자 식별 정보에 대해 AA 서버(580)와 인증이 되어 있지 않은 경우, 동작 1320에 예시한 바와 같이, Application-layer AKA 또는 Login방식으로 사용자 인증(user authentication)을 수행할 수 있다. 일 실시예에 따르면, MNO 정보에 따라 인증 방식이 상이할 수 있으며, AA 서버(580)는 MNO 정보에 대응하는 방식을 이용하여 인증을 수행할 수 있다. 예를 들면, MSA(520)는 AA 서버(580)와 지정된 적어도 하나의 인증 방식에 기반하여 인증을 수행할 수 있다.
일 실시예에 따르면, 동작 1309에서, MSA(520)는 인타이틀먼트 서버(1000)를 통해 AA 서버(580) 간에 Application-layer AKA 방식에 기반하여 인증(authentication) 절차를 수행할 수 있다. 다른 실시예에 따르면, 동작 1311에서, MSA(520)는 인타이틀먼트 서버(1000)와 ID/password 기반 Login 방식에 기반하여 인증(authentication) 절차를 수행하고, 동작 1313에서, 인타이틀먼트 서버(1000)에 로그인 성공(Login Success)하는 것으로 인증 절차를 수행할 수 있다.
동작 1315에서, MMP 서버(430)는 인타이틀먼트 서버(1000)로부터 권한 코드 요청에 대응하는 권한 코드 응답을 수신하면, 동작 1317에서, AA 서버(580)에 가입자 프로필(user profile)을 확인하기 위한 접속 토큰을 인타이틀먼트 서버(1000)에 요청하고, 인타이틀먼트 서버(1000)로부터 접속 토큰을 수신할 수 있다. 일 실시예에 따르면, AA 서버(580)는 해당 전자 장치(101)에 대한 인증이 완료된 경우, 필요에 따라, MSA(520)에 CARP 또는 URSP 규칙을 전달할 수 있고, MMP 서버(430)가 요청한 권한 코드를 MMP 서버(430)에 전달할 수 있다. 일 실시예에 따르면, MMP 서버(430)는 MMP 정보와 권한 코드를 인타이틀먼트 서버(1000) 또는 AA 서버(580)에 전달하며, 사용자 프로필 정보 접근을 위한 접속 토큰을 요청하고 수신할 수 있다.
일 실시예에 따라, 동작 1321에서, MMP 서버(430)는 접속 토큰을 이용하여 사용자 프로필(user profile)을 획득할 수 있다. 예를 들어, MSA(520)는 AA 서버(580)를 통해 MMP 서버(430)로 전자 장치(101)의 MEC 서비스 가입자 인증 및 권한 코드를 전달할 수 있다. 일 실시예에 따르면, MMP 서버(430)와 AA 서버(580)는 권한 코드를 사용하여 발급 받은 접속 토큰에 기반하여 가입자 프로필을 확인할 수 있다.
동작 1323에서, MMP 서버(430)는 권한 부여 요청에 대응하는 권한 부여 응답(authorization response)을 MSA(520)로 전송할 수 있다. 일 실시예에 따르면, MMP 서버(430)는 해당 접속 토큰을 이용하여 사용자 프로필을 확인하고, 사용자 프로필에 기반하여 MEC 서비스가 가용하다는 것이 확인된 경우, 권한 부여 절차의 결과로 접속 토큰(예: MAT), MMP Info(예: URI), 및/또는 라우트 정책(예: CARP 또는 URSP 규칙(예: 전용 DNN))을 포함하여 Authorization response을 MSA(520)로 전달할 수 있다.
일 실시예에 따르면, 동작 1323에서, MSA(520)는 권한 부여 절차의 결과로 접속 토큰(예: MAT)을 획득할 수 있다. 일 실시예에 따라, MSA(520)가 MMP 서버(430)와 권한 부여 절차를 수행하는 경우, MSA(520)는 권한 부여 절차의 결과로 접속 토큰을 수신하며, MSE API를 통해 MSE(530)로 MMP 정보 및 접속 토큰을 전달할 수 있다. 다른 실시예에 따라, MSE(530)가 MMP 서버(430)와 권한 부여 절차를 수행하는 경우, 우선 인증을 완료한 MSA(520)가 MMP 서버(430)로부터 수신한 MMP 정보 및 권한 코드(Auth code)와, 선택적으로 ID_token을 MSE API를 통해 MSE(530)로 전달할 수 있다. MSE(530)는 MSA(520)로부터 전달된 정보에 기반하여 MMP 서버(430)와 직접 권한 부여 절차를 수행하고 그 결과로 접속 토큰을 수신할 수 있다.
동작 1325에서, MSA(520)는 MSE(530)를 통해 MMP Info 및 접속 토큰을 이용하여 MEC 디스커버리 절차를 수행할 수 있다.
도 14는 다양한 실시예들에 따른 전자 장치(101)에서 인증 절차를 위한 동작 방법을 도시하는 흐름도이다.
동작 1401에서, 전자 장치(101)의 프로세서(120)(또는 도 5의 MSE(530))는 액세스 통신(access communication)에 기반하여 AMF/PCF 서버(590)로부터 MMP 서버(430)접속에 필요한 제1 인증 정보를 획득할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSE(530)는 AMF/PCF 서버(590)(예: AMF)와 NAS 시그널링(signaling) 절차를 수행할 수 있다. 일 실시예에 따라, AMF/PCF 서버(590)는 NAS 시그널링에 기반하여 전자 장치(101)로 제1 인증 정보를 제공할 수 있다. 일 실시예에 따라, 제1 인증 정보는, MMP Info, Auth Code를 포함할 수 있고, 추가적으로 ID_token 및/또는 CARP 또는 URSP 규칙을 포함할 수 있다. 일 실시예에 따르면, MSE(530)는 전자 장치(101)의 모뎀(또는 커뮤니케이션 프로세서(CP))이 AMF로부터 수신하는 NAS 시그널링 메시지를 MSE(530)의 UHL(533)을 통해 수신할 수 있다. 예를 들어, 전자 장치(101)의 모뎀은 MSA(520)는 NAS 시그널링 메시지로부터 MMP Info 및 Auth Code, ID_token, 또는 CARP 또는 URSP 규칙 중 적어도 하나의 정보를 획득하고, 획득된 정보를 UHL(533)을 통해 MSA(520)에 전달할 수 있다.
동작 1403에서, 프로세서(120)(또는 도 5의 MSE(530)))는 클라이언트 어플리케이션을 위한 PDU 세션을 설정(setup)할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSE(530)는 NAS 시그널링 메시지로부터 제1 인증 정보(예: MMP Info, Auth Code 및/또는 ID_token의 적어도 하나의 정보)를 획득할 수 있고, 획득된 제1 인증 정보를 MSA(520)에 전달할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSA(520)는 획득된 중보 중에 CARP 또는 URSP 규칙이 포함되어 있는 경우 MSE API를 이용하여 MSE(530)와 정책 업데이트를 수행할 수 있다. 일 실시예에 따르면, MSA(520)는 NAS 시그널링 메시지를 통해 획득한 정보 중에 CARP 또는 URSP 규칙이 제공되지 않는 경우 MSE(530)와 정책 업데이트를 수행하지 않을 수도 있다. 다른 실시예에 따르면, MSA(520)는 CARP 또는 URSP 규칙이 제공되더라도 MSA(520)의 자체적인 판단 또는 MSE(530)와의 정보 교환을 통해 정책 업데이트를 수행하지 않을 수도 있다.
동작 1405에서, 프로세서(120)(또는 도 5의 MSA(520))는 제1 인증 정보에 기반하여, MMP 서버(430)로 권한 부여 요청을 위한 제2 요청 메시지를 전송할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSA(520)는 인증 완료 후(또는 MSE(530)와 정책 업데이트 수행 또는 생략한 이후), 권한 부여(authorization) 요청(authorization request)을 위한 메시지를 MMP 서버(430)로 전송할 수 있다. 일 실시예에 따르면, MSA(520)는 NAS 시그널링 메시지로부터 획득된 제1 인증 정보(예: Auth Code 또는 추가적으로 ID_token 포함)에 기반하여, MMP 서버(430)에 권한 부여를 요청할 수 있다.
동작 1407에서, 프로세서(120)(또는 도 5의 MSA(520))는 MMP 서버(430)로부터 인증 결과에 따른 제2 인증 정보를 획득할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSA(520)는 MMP 서버(430)를 통해 AA 서버(580)와 인증(예: 권한 부여 절차)을 수행할 수 있고, 인증 결과에 따른 제2 인증 정보를 MMP 서버(430)로부터 획득(또는 수신)할 수 있다. 제2 인증 정보는, 예를 들어, 접속 토큰(예: MAT)과 MMP Info를 포함할 수 있다.
동작 1409에서, 프로세서(120)(또는 도 5의 MSA(520))는 제2 인증 정보에 기반하여 MMP 서버(430)에 접속하여 디스커버리 절차를 수행할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSA(520)는 MMP 서버(430)로부터, 인증 결과에 따른 제2 인증 정보(예: MAT)를 수신하는 경우, 수신된 제2 인증 정보를 전자 장치(101)의 MSE(530)에 전달하고, MSE(530)를 활성화 할 수 있다. 일 실시예에 따르면, MSA(520)는 MAT와 함께, MEC 디스커버리 절차를 수행하기 위해 접속할 새로운 MMP 서버(430)의 접속 주소(예: URI 또는 IP 주소), DNS 서버 주소, 또는 사용할 DNN과 같은 적어도 하나의 부가 정보를 MSE API를 통해 MSE(530)로 전달할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSE(530)는 MAT 및/또는 그 외의 다른 부가 정보(예: MMP Info, DNS 서버 주소, 또는 사용할 DNN)에 적어도 기반하여 MEC 디스커버리 절차를 수행할 수 있다. 일 실시예에 따르면, MSE(530)는 MMP Info 및 MAT를 사용하여 해당 MMP 서버(430)에 접속 후 MEC 디스커버리 절차를 수행할 수 있다.
다양한 실시예들에 따르면, 도 14에 도시된 인증 절차는, 예를 들어, 클라이언트 어플리케이션(510)이 기본 PDU 세션(또는 PDN)을 사용하여 MEC 어플리케이션에 연결하는 시나리오를 포함할 수 있다. 예를 들어, MSE(530)(예: MEL(531))에서 MEC 디스커버리 절차를 수행하여, 전자 장치(101)에 가까운 MEC 호스트에 MEC 어플리케이션 구동 및 연결을 요청하고, 해당 MEC 어플리케이션의 URI를 수신할 수 있다. 이후, 클라이언트 어플리케이션(510)이 해당 MEC 어플리케이션 접속 요청 시, 해당 URI에 대한 DNS 리졸빙을 통해 획득한 MEC 어플리케이션 IP 주소로 접속할 수 있다.
다양한 실시예들에 따르면, 도 14에 도시된 인증 절차는, 예를 들어, 클라이언트 어플리케이션이 기본 PDU 세션(또는 PDN) 외에, 별도의 MEC 전용 PDU 세션을 생성하여 MEC 어플리케이션에 연결하는 시나리오를 포함할 수 있다. 예를 들어, MEC 전용 PDU 세션 생성은 사업자(예: MNO 또는 MMP 서버(430)) 정책에 따르며, MSA(520) 또는 인증된 클라이언트 어플리케이션이 MSE API를 사용하여 UHL(533)을 통해 생성 할 수 있다. 일 실시예에 따라, MEC 전용 PDU 세션은 기본 PDU 세션 외에, 하나 이상의 PDU 세션을 항상 열어둘 수도 있고, 특정 시점에 필요에 따라 MEL(531)의 요청에 의해 동적으로 생성하거나 해제할 수 있다. 일 실시예에 따르면, 사전에 정의된 규칙(rule)(예: CARP 또는 URSP 규칙) 또는 외부 서버(예: MMP 서버(430), AA 서버(580), 또는 AMF/PCF 서버(590))로부터 수신한 라우팅 규칙에 따라 해당 클라이언트 어플리케이션(또는 UID) 또는 접속 URI에 대한 트래픽을 MEC 전용 PDU 세션으로 라우팅 되도록 MSE(530)의 UHL(533)에서 지원할 수 있다.
다양한 실시예들에 따르면, 도 14에 도시된 인증 절차는, 예를 들어, MEL(531)의 기능 없이, 특정 서비스에 대해 전용 PDU 세션만 생성하여 사용하는 시나리오를 포함할 수 있다. 일 실시예에 따르면, MSA(520) 또는 인증된 클라이언트 어플리케이션(510)에 MSE API를 사용하여 별도의 전용 PDU 세션을 생성하고, 해당 PDU 세션을 사용하는 어플리케이션(예: UID) 규칙을 등록하고, 해당 어플리케이션의 트래픽을 해당 PDU 세션으로 라우팅 되도록 할 수 있다.
도 15A는 다양한 실시예들에 따른 인증 절차의 예를 도시하는 도면이다.
도 15A에 도시한 바와 같이, 전자 장치(101)는 MSA(또는 서비스 에이전트)(520)(예: AA 클라이언트(525) 포함)와 MSE(또는 서비스 인에이블러)(530)(예: MEL(531), UHL(533) 포함)를 포함할 수 있다. 일 실시예에 따르면, AMF/PCF 서버(590)의 PCF에서 URSP를 추가하여 MMP 접속에 필요한 정보(예: MMP Info, Auth Code, 또는 ID_token)를 관리할 수 있다.
도 15A를 참조하면, 동작 1501에서, 전자 장치(101)의 MSE(530)는 AMF/PCF 서버(590)(예: AMF)와 NAS 시그널링(signaling) 절차를 수행할 수 있다. 일 실시예에 따라, AMF/PCF 서버(590)는 전자 장치(101)로 MMP Info, Auth Code를 제공할 수 있고, 추가적으로 ID_token 및/또는 CARP 또는 URSP 규칙을 제공할 수 있다. 일 실시예에 따르면, MSE(530)는 전자 장치(101)의 모뎀(또는 커뮤니케이션 프로세서)이 AMF(590)로부터 수신하는 NAS 시그널링 메시지를 MSE(530)의 UHL(533)을 통해 수신할 수 있다. 예를 들어, 전자 장치(101)의 모뎀은 AMF로부터 수신하는 NAS 시그널링 메시지로부터 MMP Info 및 Auth Code, ID_token, 또는 CARP 또는 URSP 규칙 중 적어도 하나의 정보를 획득하고, 획득된 정보를 UHL(533)을 통해 MSA(520)에 전달할 수 있다.
동작 1503에서, MSE(530)는 NAS 시그널링 메시지로부터 MMP Info, Auth Code 및/또는 ID_token의 적어도 하나의 정보를 획득할 수 있고, 획득된 정보를 MSA(520)에 전달할 수 있다. 일 실시예에 따라, MMP Info는, 예를 들어, MMP 서버(430) 접속에 관련된 정보(예: MMP 접속 주소)를 포함할 수 있다. 예를 들어, MMP Info는 접속할 새로운 MMP 서버(430)의 주소 정보(예: URI(uniform resource identifier) 또는 IP 주소)와 해당 주소 정보의 유효 시간 및/또는 장소에 관련된 정보를 포함할 수 있다. 일 실시예에 따라, CARP 또는 URSP 규칙은, 예를 들어, DNN 구성(configuration) 관련 정보, DNN 별 사용 가능한 어플리케이션(또는 어플리케이션 그룹)에 관련된 정보, 또는 이후 설정 가능한 DNN 리스트(list) 또는 설정 가능한 DNN 최대 개수에 관련된 정보를 포함할 수 있다.
일 실시예에 따르면, AMF/PCF 서버(590)로부터 제공된 MMP Info, Auth Code, ID_token, 또는 CARP 또는 URSP 규칙 중 적어도 하나의 정보는 MSE(530)를 통해 MSA(520)에서 획득할 수도 있다.
동작 1505에서, MSA(520)는 MSE(530)와 정책 업데이트(policy update)를 수행(예: PDU 세션 설정)할 수 있다. 일 실시예에 따라, MSA(520)는 CARP 또는 URSP 규칙(예: DNN)에 따라 PDU 세션 설정을 수행할 수 있다. 예를 들어, MSA(520)는 MMP 서버(430)로부터 수신 정보에 URSP 규칙이 있는 경우, MSE API를 이용하여 URSP 규칙을 업데이트 할 수 있다. 일 실시예에 따르면, MSA(520)는 NAS 시그널링 메시지를 통해 획득한 정보 중에 CARP 또는 URSP 규칙이 포함되어 있는 경우 MSE(530)와 정책 업데이트를 수행할 수 있다. 일 실시예에 따르면, MSA(520)는 NAS 시그널링 메시지를 통해 획득한 정보 중에 CARP 또는 URSP 규칙이 제공되지 않는 경우 MSE(530)와 정책 업데이트를 수행하지 않을 수도 있다. 다른 실시예에 따르면, MSA(520)는 CARP 또는 URSP 규칙이 제공되더라도 MSA(520)의 자체적인 판단 또는 MSE(530)와의 정보 교환을 통해 정책 업데이트를 수행하지 않을 수도 있다. 일 실시예에 따르면, MSA(520)와 MSE(530) 간 정책 업데이트 시에 PDU 세션 설정을 수행할 수 있다.
동작 1507에서, MSA(520)는 NAS 시그널링 메시지를 수신한 후(또는 MSE(530)와 정책 업데이트 수행 또는 생략한 이후), 권한 부여(authorization) 요청(authorization request)(예: 서비스 사용 권한 요청)을 위한 메시지(예: 권한 요청 메시지)를 MMP 서버(430)에 전송할 수 있다. 일 실시예에 따르면, MSA(520)는 NAS 시그널링 메시지로부터 획득된 인증 정보(예: Auth Code 또는 추가적으로 ID_token 포함)에 기반하여, MMP 서버(430)에 서비스 사용에 대한 권한 부여를 요청할 수 있다.
동작 1509에서, MSA(520)는 MMP 서버(430)를 통해 AA 서버(580)와 인증(예: 권한 부여 절차)을 수행할 수 있다. 일 실시예에 따라, MSA(520)는 AA 서버(580)와 Auth Code 또는 ID_token 중 적어도 하나 또는 모두를 MMP 서버(430)로 제공(또는 전송)하여, 서비스 사용에 대한 권한 부여(service Authorization)를 요청할 수 있다.
동작 1511에서, MMP 서버(430)는 MSA(520)의 권한 부여 요청(예: 권한 요청 메시지)에 대응하여, 인증 정보를 전자 장치(101)(예: MSA(520))에 제공(또는 전송)할 수 있다. 일 실시예에 따르면, 인증 정보는, 예를 들어, 접속 토큰(예: MAT) 및 MMP Info를 포함할 수 있다. 일 실시예에 따르면, MMP 서버(430)는 MSA(520)의 인증 수행 중 또는 수행 이후에 접속 토큰 및 MMP Info을 포함하는 응답을 MSA(520)에 전송할 수 있다.
동작 1513에서, MSA(520)는 MSE(530)를 활성화 할 수 있다. 일 실시예에 따르면, MSA(520)는 MMP 서버(430)로부터, 인증 정보(예: 접속 토큰(MAT), MMP Info)를 수신하는 경우, 수신된 인증 정보(예: 접속 토큰(MAT), MMP Info)를 MSE(530)에 전달하여 MSE(530)를 활성화 할 수 있다. 일 실시예에 따르면, MSA(520)는 접속 토큰(MAT)과 함께, MEC 디스커버리 절차를 수행하기 위해 접속할 새로운 MMP 서버(430)의 접속 주소(예: URI 또는 IP 주소), DNS 서버 주소, 또는 사용할 DNN과 같은 적어도 하나의 부가 정보를 MSE(530)에 전달할 수 있다. 일 실시예에 따르면, MSA(520)는 수신된 접속 토큰(MAT) 및/또는 그 외의 다른 부가 정보에 기반하여 MSE(530)를 활성화(enable MEC)할 수 있다. 일 실시예에 따르면, MSA(520)가 MMP 서버(430)와 권한 부여 절차를 수행하는 경우, MSA(520)는 MMP 서버(430)로부터, 접속 토큰(예: MAT)을 수신할 수 있으며, 예를 들어, MSE API의 enableMecEnablingLayer(true, MMP Info, MAT)를 호출함으로써, MSE(530)에 MMP 접속 정보(MMP Info) 및 접속 토큰(MAT)을 전달할 수 있다.
동작 1515에서, MSE(530)는 인증 정보(예: MAT) 및/또는 그 외의 다른 부가 정보(예: MMP Info, DNS 서버 주소, 또는 사용할 DNN)을 수신하고, 인증 정보 및/또는 부가 정보에 적어도 기반하여 MEC 디스커버리 절차를 수행할 수 있다. 일 실시예에 따르면, MSE(530)는 MMP Info 및 MAT를 사용하여 해당 MMP 서버(430)에 접속 후 MEC 디스커버리 절차를 수행할 수 있다.
도 15B는 다양한 실시예들에 따른 인증 절차의 예를 도시하는 도면이다.
도 15B에 도시한 바와 같이, 도 15B는 다양한 실시예들에 따른 인증 절차(예: AA 및 정책 업데이트에 관한 시나리오 C)를 위한 신호 흐름의 예를 나타낼 수 있다. 예를 들어, 도 15B는 다양한 실시예들에 따른 인증 절차 중 시나리오 C(예: 도 15A에 따른 인증 절차)를 위한 MEC 서비스 인증 플로우의 예를 나타낸 것으로, 5G NAS 기반 모델(5G NAS-based Mode)에서 수행하는 시나리오 에를 나타낼 수 있다.
도 15B를 참조하면, 동작 1531에서, 전자 장치(101)의 MSA(520)는 AMF/PCF 서버(590)와 NAS 시그널링을 통해 수신하는 NAS 메시지로부터, MMP Info(예: URI, DNN), Auth Code, 및 CARP 또는 URSP 규칙과 같은 정보를 획득할 수 있다. 일 실시예에 따르면, NAS 메시지는 ID-token을 더 포함할 수도 있다.
동작 1533에서,, MSA(520)는 NAS 시그널링의 결과로 획득한 정보를 이용하여 MMP 서버(430)로 권한 부여(authorization) 요청(예: 서비스 사용 권한 요청)을 위한 메시지(예: 권한 요청 메시지)를 전송할 수 있다. 예를 들어, MSA(520)는 획득된 정보(예: MMP Info, Auth Code, CARP 또는 URSP 규칙)를 MMP 서버(430)로 전달하여 MMP 서버(430)에 권한 부여를 요청할 수 있다.
동작 1535에서, MMP 서버(430)는 AA 서버(580)에 사용자 프로필(user profile) 정보 접근을 위한 접속 토큰(access token)을 요청할 수 있고, 동작 1537에서, AA 서버(580)로부터 접속 토큰을 획득할 수 있다.
동작 1539에서, MMP 서버(430)는 접속 토큰을 이용하여 사용자 프로필을 획득할 수 있다. 예를 들어, MMP 서버(430)는 MMP 정보와 권한 코드를 AA 서버(580)에 전달하며, 사용자 프로필(user profile) 정보 접근을 위한 접속 토큰을 요청하여 획득할 수 있다.
동작 1541에서, MMP 서버(430)는 권한 부여 요청에 대응하는 권한 부여 응답(quthorization response)을 MSA(520)로 전송할 수 있다. 일 실시예에 따르면, MMP 서버(430)는 해당 접속 토큰을 이용하여 사용자 프로필을 확인하고, 사용자 프로필에 기반하여 MEC 서비스가 가용하다는 것이 확인된 경우, 권한 부여 절차의 결과로 MEC 디스커버리를 위한 MMP Info, 접속 토큰(예: MAT), 및/또는 MEC 데이터 서비스를 위한 라우트 정책(예: CARP 또는 URSP 규칙)을 포함하여 Authorization response을 MSA(520)로 전달할 수 있다.
일 실시예에 따르면, 동작 1541에서, MSA(520)는 권한 부여 절차의 결과로 접속 토큰(예: MAT)을 획득할 수 있다. 일 실시예에 따라, MSA(520)가 MMP 서버(430)와 권한 부여 절차를 수행하는 경우, MSA(520)는 권한 부여 절차의 결과로 접속 토큰을 수신하며, MSE API를 통해 MSE(530)로 MMP 정보 및 접속 토큰을 전달할 수 있다. 다른 실시예에 따라, MSE(530)가 MMP 서버(430)와 권한 부여 절차를 수행하는 경우, 우선 인증을 완료한 MSA(520)가 MMP 서버(430)로부터 수신한 MMP 정보 및 권한 코드(Auth code)와, 선택적으로 ID_token을 MSE API를 통해 MSE(530)로 전달할 수 있다. MSE(530)는 MSA(520)로부터 전달된 정보에 기반하여 MMP 서버(430)와 직접 권한 부여 절차를 수행하고 그 결과로 접속 토큰을 수신할 수 있다.
동작 1543에서, MSA(520)는 MSE(530)를 통해 MMP Info 및 접속 토큰을 이용하여 MEC 디스커버리 절차를 수행할 수 있다.
도 16은 다양한 실시예들에 따른 전자 장치(101)의 동작 방법을 도시하는 흐름도이다.
도 16을 참조하면, 동작 1601에서, 전자 장치(101)의 프로세서(120)(또는 도 4의 MEC 서비스 모듈(410))는 MSA(520)(또는 서비스 에이전트)를 통해, 네트워크의 지정된 외부 서버(예: 인증 서버 또는 MMP 서버)와 MEC 서비스를 위한 인증(예: 사용자 인증 또는 서비스 인증)을 수행할 수 있다
동작 1603에서, 프로세서(120)(또는 도 4의 MEC 서비스 모듈(410))는 외부 서버로부터 인증 결과에 따른 인증 정보를 수신할 수 있다.
동작 1605에서, 프로세서(120)(또는 도 4의 MEC 서비스 모듈(410))는 인증 정보를 수신하는 것에 기반하여, MSE(530)(또는 서비스 인에이블러)와 정책 업데이트(policy update)를 선택적으로 수행할 수 있다.
동작 1607에서, 프로세서(120)(또는 도 4의 MEC 서비스 모듈(410))는 인증 정보에 기반하여 MMP Info와 MMP 서버(430)에 접속을 위한 토큰을 획득할 수 있다.
동작 1609에서, 프로세서(120)는 MMP Info와 토큰을 MSE API를 통해 MSE(530)에 전달하여 MSE(530)를 활성화 할 수 있다.
동작 1611에서, 프로세서(120)(또는 도 4의 MEC 서비스 모듈(410))는 MSE(530)를 통해 해당 MMP 서버(430)에 접속하여 MEC 디스커버리 절차를 수행할 수 있다.
PDU 세션 설정(session setup)
이하에서는, MEC 서비스를 위한 인증 절차에 대응하여 전자 장치(101)의 내부에서 이루어지는 동작들을 설명한다.
도 17은 다양한 실시예들에 따른 전자 장치(101)에서 정책 업데이트 동작 예를 도시하는 도면이다.
도 17에 도시한 바와 같이, 도 17은, 정책 업데이트(예: PDU 세션 설정) 중 PDU 세션 생성(establishment)의 일 예를 나타낼 수 있으며, PDU 세션 설정(또는 PDN 연결 생성(PDN connection establishment))에서 전용 DNN 활성화(dedicated DNN activation)을 위한 동작 예를 나타낼 수 있다. 일 실시예에 따르면, PDU 세션 설정(session setup)은 새로운 PDU 세션 생성(session establishment), 기존 PDU 세션 해제(session release), 및 기존 PDU 세션 업데이트(session update)(예: PDU 세션 별 특성에 대한 설정(예: bandwidth 또는 latency와 같은 QoS 정보) 변경)를 포함할 수 있으며, 도 17에서는 PDU 세션 생성 예를 나타낼 수 있다. 일 실시예에 따라, 전자 장치(101)는 MSA(또는 서비스 에이전트)(520), MSE(또는 서비스 인에이블러)(530), 및 모뎀(또는 CP, communication processor)(1700)을 포함할 수 있다.
도 17을 참조하면, 동작 1701에서, MSA(520)는 DNN 설정에 대한 정보를 획득(또는 수신)하는 경우 DNN을 설정하도록 지시하는 제1 메시지(예: setUrspDNN)를 MSE(530)로 제공(또는 전달)할 수 있다.
동작 1703에서, MSE(530)는 MSA(520)로부터 제공된 제1 메시지(예: setUrspDNN)에 기반하여 DNN 정보를 업데이트(예: update DNN Info)할 수 있다.
동작 1705에서, MSA(520)는 PDU 세션(또는 PDN 연결)을 생성하도록 지시하는 제2 메시지(예: requestPduSession)를 MSE(530)로 제공할 수 있다.
동작 1707에서, MSE(530)는 제2 메시지(예: requestPduSession)를 수신하는 경우, 데이터 호(data call)를 설정하도록 지시하는 제3 메시지(예: setup data call)를 모뎀(1700)으로 제공할 수 있다.
동작 1709에서, 모뎀(1700)은 MSE(530)로부터 제3 메시지(예: setup data call)를 수신하면, 서비스(예: MEC 서비스)의 처리를 위한 미리 구성된 정보에 기반하여 데이터 호를 설정하거나, 또는 지시된 정보에 기반하여 데이터 호를 설정하고, MSE(520)로 제3 메시지에 대응하는 제4 메시지(예: 응답(Response) 메시지)를 제공할 수 있다. 일 실시예에 따르면, 모뎀(1700)이 제3 메시지(예: setup data call)에 의해 코어 망(예: SMF)에 PDU 세션 생성을 요청하는 것에 기반하여 PDU 세션이 생성될 수 있다.
동작 1711에서, MSE(530)는 모뎀(1700)으로부터 제4 메시지(예: 데이터 호 설정 요청에 대응하는 응답)을 수신하는 경우, PDU 세션이 생성(establishment) 되었음을 통지하는 제5 메시지(예: onAvaible)를 MSA(520)로 제공할 수 있다.
동작 1713에서, MSA(520)는 URSP 규칙이 앞서 설명한 방식들 중 어느 하나의 방식을 이용하여 수신되거나, 또는 그 밖의 다른 방식을 통해 수신되는 경우, URSP 규칙의 설정을 지시하는 제6 메시지(예: setUrspRules)를 MSE(530)로 제공할 수 있다. 일 실시예에 따르면, 동작 1715에서, MSA(520)는 MEC 서비스 활성화 모드(예: MSE 활성화)를 실행(true)하도록 지시하는 제7 메시지(예: setMaServiceEnableMode(true))를 MSE(530)로 제공할 수 있다.
동작 1717에서, MSE(530)는 MSA(520)로부터 수신된 제6 메시지(예: setUrspRules)와 제7 메시지(예: setMaServiceEnableMode(true))에 기반하여 라우팅 테이블(routing table)을 생성(또는 추가(add))할 수 있다. 일 실시예에 따르면, URSP 규칙에는 어플리케이션 별 또는 URI 별 사용 PDU 세션 정보를 포함할 수 있으며, 전자 장치(101)(예: MSE(530))는 URSP 규칙 상의 PDU 세션이 생성되어 있지 않은 경우, setUrspDNN API를 통해 PDU 세션을 생성할 수 있다. 일 실시예에 따라, 전자 장치(101)(예: MSE(530))는 PDU 세션 생성 시에, 해당 어플리케이션 ID(AppID) 또는 URI에 대한 데이터 경로를 URSP 규칙 상의 PDU 세션으로 설정되도록 setUrspRules API를 통해 라우팅 테이블을 설정할 수 있다.
도 18은 다양한 실시예들에 따른 전자 장치(101)에서 PDU 세션 설정 동작 예를 도시하는 도면이다.
도 18에 도시한 바와 같이, 도 18은, 정책 업데이트(예: PDU 세션 설정) 중 PDU 세션 해제(release)의 일 예를 나타낼 수 있으며, PDU 세션(또는 PDN 연결(PDN connection))을 해제(release)하기 위한 동작 예를 나타낼 수 있다. 일 실시예에 따르면, PDU 세션 설정(session setup)은 새로운 PDU 세션 생성(session establishment), 기존 PDU 세션 해제(session release), 및 기존 PDU 세션 업데이트(session update)(예: PDU 세션 별 특성에 대한 설정(예: bandwidth 또는 latency와 같은 QoS 정보) 변경)를 포함할 수 있으며, 도 17에서는 PDU 세션 해제 예를 나타낼 수 있다. 일 실시예에 따라, 전자 장치(101)는 MSA(또는 서비스 에이전트)(520), MSE(또는 서비스 인에이블러)(530), 및 모뎀(또는 CP, communication processor)(1700)을 포함할 수 있다.
도 18을 참조하면, 동작 1801에서, MSA(520)는 DNN 설정에 대한 정보의 설정을 해제해야 하는 경우, 해당하는 DNN을 해제하도록 지시하는 제1 메시지(예: setUrspDNN)를 MSE(530)로 제공(또는 전달)할 수 있다.
동작 1803에서, MSE(530)는 MSA(520)로부터 제공된 제1 메시지(예: setUrspDNN)에 기반하여 데이터 호(data call)를 해제(release)하도록 지시하는 제2 메시지(예: Release data call)를 모뎀(1500)으로 제공할 수 있다.
동작 1805에서, 모뎀(1700)은 MSE(530)로부터 제3 메시지(예: Release data call)를 수신하면, 해당하는 서비스(예: MEC 서비스)의 처리를 위해 설정된 구성을 해제하고, MSE(530)로 제3 메시지에 대응하는 제4 메시지(예: 응답(Response) 메시지)를 제공할 수 있다. 일 실시예에 따르면, 모뎀(1700)이 제3 메시지(예: Release data call)에 의해 코어 망(예: SMF)에 PDU 세션 해제를 요청하는 것에 기반하여 PDU 세션이 해제될 수 있다.
동작 1807에서, MSA(520)는 MEC 서비스 비활성화 모드(예: MSE 비활성화)를 실행(false)하도록 지시하는 제5 메시지(예: setMaServiceEnableMode(false))를 MSE(530)로 제공할 수 있다.
동작 1809에서, MSE(530)는 MSA(520)로부터 수신된 제5 메시지(예: setMaServiceEnableMode(false))에 기반하여 메모리(예: 도 1 또는 도 2의 메모리(130))에 저장(또는 생성)된 라우팅 테이블을 메모리에서 삭제(delete)할 수 있다.
도 19는 다양한 실시 예들에 따른 전자 장치(101)에서 MEC 기반 데이터 전송 가능 여부를 확인하는 방법을 도시하는 흐름도이다.
다양한 실시예들에서, 도 19에 도시된 동작들은, 예를 들어, 전자 장치(101)가 사업자 네트워크에 어태치(attach)할 때, 사업자 네트워크가 변경될 때(예: 해외 로밍(roaming)), 지정된 주기에 따라서, 또는 가입자 정보가 변경될 때 중 적어도 하나의 경우에 수행될 수 있다.
도 19를 참조하면, 동작 1901에서, 전자 장치(101)는 전자 장치(101)가 접속된 네트워크가 MEC 기반 데이터 전송이 가능한 네트워크인지 확인할 수 있다. 일 실시예에 따르면, MEC 서비스 모듈(410)(예: MSE(530))는 전자 장치(101)가 접속된 네트워크의 셀 ID, PLMN(public land mobile network), 또는 DNN(data network name(=APN(access point name)) 중 적어도 하나에 기반하여 MEC 기반 데이터 전송이 가능한지를 확인할 수 있다. 일 실시예에 따르면, 셀 ID, PLMN, 또는 DNN 중 적어도 하나는 전자 장치(101)에 미리 등록된 정보일 수 있고, 전자 장치(101)가 MEC 시스템(405)에 요청함으로써 획득될 수 있다.
동작 1903에서, 전자 장치(101)는 전자 장치(101)가 접속된 네트워크의 MEC 서비스 레벨을 확인할 수 있다. 일 실시예에 따르면, MEC 서비스 레벨은, 예를 들어, MEC 사용 권한 또는 MEC QoS(quality of service) 중 적어도 하나를 포함할 수 있다. MEC QoS는, 예를 들어, 사용자 별 가입 정보에 따라 서비스 품질 등급이 차등 적용 되어 있을 경우 이에 대한 정보를 의미할 수 있다. 예를 들어, 프리미엄 가입자의 경우 MEC 서비스 어플리케이션 종류 및/또는 MEC 호스트 자원(예: bandwidth, memory, cpu, 또는 gpu와 같은 자원)을 더 많이 제공할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 SIM(또는 USIM)과 관련된 정보 또는 전자 장치(101)의 사용자 가입 정보(예: IMEI) 중 적어도 하나를 이용하여 MEC 서비스 레벨을 확인할 수 있다.
일 실시예에 따르면, 전자 장치(101)가 접속된 네트워크가 MEC 데이터 전송이 가능하며 전자 장치(101)의 MEC 사용 권한이 있는 경우, 전자 장치(101)는 디스커버리 절차를 수행할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 디스커버리 절차를 수행하기 이전에 MEC 데이터 전송 가능 여부 또는 MEC 서비스 레벨을 확인함으로써 불필요한 디스커버리가 발생하는 것을 방지할 수 있다.
MEC 디스커버리(Discovery)
이하에서는, 다양한 실시예들에 따른 MEC 디스커버리 절차에 대하여 살펴보기로 한다. 일 실시예에 따르면, MEC 디스커버리 절차는, 앱 리스트 획득(예: MEC Application Look-up), 어플리케이션 컨텍스트 생성(Application Context Create), MEC 호스트 선택(MEC host selection), 및/또는 DNS 리졸빙(resolving) 동작을 포함할 수 있다.
도 20은 다양한 실시 예들에 따른 디스커버리 절차의 예를 도시하는 도면이다.
도 20을 참조하면, 동작 2001에서, MEC 서비스 모듈(410)(예: MSE(530))은 전자 장치(101)의 이동성과 관련된 이벤트(예: 디스커버리 트리거(discovery trigger))를 감지할 수 있다. 일 실시예에 따르면, 이동성과 관련된 이벤트는, 예를 들어, 전자 장치(101)의 움직임을 감지하는 동작, 전자 장치(101)와 연결된 기지국이 변경됨을 감지하는 동작, 또는 전자 장치(101)가 지정된 지역에 진입함을 감지하는 동작을 포함할 수 있다. 지정된 지역은, 예를 들어, LADN, TA, 기지국의 셀, 기지국 간 핸드오버가 발생하는 영역, 또는 위치 기반 서비스에 의하여 결정된 영역 중 적어도 하나를 의미할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 이동성과 관련된 이벤트를 감지하도록 구성되는 모듈(예: 도 1의 센서 모듈(176) 중 적어도 하나의 센서, 커뮤니케이션 프로세서(예: 도 1의 보조 프로세서(123)), LADN 감지 모듈, 또는 GPS 감지 모듈)을 포함할 수 있다. 일 실시예에 따르면, MEC 서비스 모듈(410)은 해당 모듈로부터 전자 장치(101)의 이동성과 관련된 이벤트에 대한 알림을 받거나, 해당 모듈을 모니터링 하는 방식으로 전자 장치(101)의 이동성과 관련된 이벤트를 감지할 수 있다.
일 실시예에 따르면, 전자 장치(101)의 이동성과 관련된 이벤트가 감지되면, MEC 서비스 모듈(410)은 MEC 디스커버리 절차를 수행할 수 있다. MEC 디스커버리 절차는, 예를 들어, 전자 장치(101)가 MEC 시스템(405)에서 제공 가능한 어플리케이션(들)(예: MEC 어플리케이션(들))을 확인(또는 발견(discovery))하는 일련의 동작을 의미할 수 있다. 예를 들어, MEC 디스커버리 절차는 동작 2003 내지 2005를 포함할 수 있다. 도 20에서는 도시되지 않았으나, MEC 서비스 모듈(410)는 전자 장치(101)의 이동성과 관련된 이벤트가 감지됨을 나타내는 정보를 클라이언트 어플리케이션(510)에 제공할 수도 있다.
일 실시예에 따르면, 동작 2003에서, MEC 서비스 모듈(410)은 MEC 시스템(405)(예: MMP 서버(430) 또는 LCM 프록시 서버)에게 MEC 시스템(405)이 제공 가능한 어플리케이션들에 관한 정보를 요청할 수 있다. 예를 들어, MEC 서비스 모듈(410)은 어플리케이션 룩업 요청(application lookup request) 메시지를 MEC 시스템(405)에 전송할 수 있다. 일 실시예에 따라, MEC 시스템(405)이 제공 가능한 어플리케이션들에 관한 정보는 앱 리스트(list)로 지칭될 수 있다. 일 실시 예에 따르면, 동작 2003에서 전송되는 데이터 패킷은 제어 데이터를 포함하는 제1 데이터 패킷으로서, MEC 서비스 모듈(410)과 관련된 제1 주소를 포함할 수 있다.
일 실시예에 따르면, MEC 서비스 모듈(410)은 MEC 시스템(405)과 별도의 제3 서버(미도시)에게 MEC 시스템(405)이 제공 가능한 어플리케이션들에 관한 정보를 요청할 수도 있다. 제3 서버는, 예를 들어, 전자 장치(101)가 접속된 사업자 네트워크의 내부 또는 외부에 배치될 수 있다. 이러한 경우, 전자 장치(101)는 네트워크 정보로부터 사업자 네트워크에 관한 정보를 획득하고, 획득된 정보에 기반하여 제3 서버에게 MEC 시스템(405)이 제공 가능한 어플리케이션들에 관한 정보를 요청할 수도 있다.
일 실시예에 따르면, 동작 2005에서, MEC 서비스 모듈(410)은 MEC 시스템(405)으로부터 MEC 시스템(405)이 제공 가능한 어플리케이션들에 관한 정보(예: 가용 어플리케이션의 앱 리스트)를 수신할 수 있다. 일 실시예에 따라, MEC 서비스 모듈(410)은 어플리케이션 룩업 요청(application lookup request) 메시지를 MEC 시스템(405)에 전송(예: 동작 2003)하고, MEC 시스템(405)으로부터 그에 대응하는 어플리케이션 룩업 응답(application lookup response) 메시지를 수신하여, 가용 어플리케이션의 앱 리스트를 획득할 수 있다.
일 실시예에 따라, 어플리케이션 룩업 요청 메시지에 포함될 수 있는 파라미터(parameter)(예: 앱 리스트 요청 파라미터)의 예는 아래 <표 1>과 같이 나타낼 수 있다.
Name
|
Type
|
Cardinal
|
Description
|
ETSI MEC
compatible
|
appName |
String |
0...N |
Name to identify the user app |
Y |
appProvider |
String |
0...N |
Provider of the MEC app |
Y |
appSoftVersion |
String |
0...N |
Software version of the MEC app |
Y |
serviceCont |
Enum(inlined) |
0...1 |
Required service continuity mode for this application:0 = SERVICE_CONTINUITY_NOT_REQUIRED1 = SERVICE_CONTINUITY_REQUIRED |
Y |
vendorId |
String |
0...N |
Vendor Identifier |
Y |
clientappName |
String |
0...N |
Name to identify the client App |
N |
locationInfo |
String |
0...1 |
(Longitude, Latitude) or gNB ID or TAI or SSID or Predefined Location ID |
N |
deviceType |
Enum(inlined) |
0...N |
Predefined device typeExample:0 = Default1 = Smartphone2 = Car3 = Drone ... |
N |
serviceCategory |
Enum(inlined) |
0...N |
Predefined service categoryExample:0 = Default1 = Video streaming2 = Game3 = V2X4 = AR/VR5 = Enterprise ... |
N |
contextType |
Enum(inlined) |
0...1 |
Required context type for this application:0 = APP_CONTEXT_NOT_REQUIRED1 = APP_CONTEXT_REQUIRED |
N |
URI Request |
Boolean |
0...1 |
Request for URI of MEC applications from App Look-up response if available |
N |
NOTE: The value of the attribute of the type String shall not exceed the length of 32 characters. |
<표 1>에 예시한 바와 같이, 다양한 실시예들에 따른 앱 리스트 요청 파라미터는, ETSI MEC 규격에서 정의되어 있는 파라미터 외에, 예를 들어, clientappName, locationInfo, deviceType, serviceType, contextType, 또는 URI Request 중 적어도 하나를 포함할 수 있다. 일 실시예에 따라, “clientappName”은 MSA(520)로부터 전달받은 어플리케이션 이름(예: AppNames)을 나타낼 수 있다. 일 실시예에 따라, “Location Info”은 접속 Cell ID, TA(tracking area) ID, 지역 정보(예: 시, 구, 동, 건물, …), 또는 사용자가 지정한 우선 위치(preferred location) 정보를 나타낼 수 있다. 일 실시예에 따라, “Device Type”은 Smartphone, Tablet, Wearable, IoT, Car, 또는 Drone과 같은 전자 장치(101)의 종류를 나타낼 수 있다. 일 실시예에 따라, “Service Type”은 Game, V2X, AR/VR, LBO, Enterprise, 또는 Web과 같은 서비스의 종류를 나타낼 수 있다. 일 실시예에 따라, “Context Type”은 MEC 어플리케이션 구동에 사용자 또는 어플리케이션의 컨텍스트(context) 정보가 필요한지 여부를 나타낼 수 있다. 일 실시예에 따라, “URI Request Flag”는 MEC 어플리케이션의 URI가 가용(available)한 경우 해당 URI를 응답에 포함하도록 요청하는 플래그(flag)를 나타낼 수 있다.
일 실시예에 따라, 어플리케이션 룩업 응답 메시지에 포함될 수 있는 파라미터(예: 앱 리스트 응답 파라미터)의 예는 아래 <표 2>와 같이 나타낼 수 있다. 예를 들어, 아래 <표 2>는 MEC 서비스 모듈(410)이 MEC 시스템(405)으로부터 수신하는 가용 어플리케이션의 앱 리스트의 예를 나타낼 수 있다.
Name |
Type |
Cardinal |
Description |
ETSI MEC Compatible |
appList |
StructureArray |
0...N |
List of MEC applications available to the client application. As defined below. |
Y |
>appInfo |
Structure |
1 |
|
Y |
>>appDId |
String |
1 |
Identifier of this MEC application descriptor. It is equivalent to the appDId defined in clause 6.2.1.2 of ETSI GS MEC 010-2 [1]. This attribute shall be globally unique. |
Y |
>>appName |
String |
1 |
Name of the MEC application.The length of the value shall not exceed 32 characters. |
Y |
>>appProvider |
String |
1 |
Provider of the MEC application.The length of the value shall not exceed 32 characters. |
Y |
>>appSoftVersion |
String |
1 |
Software version of the MEC application.The length of the value shall not exceed 32 characters. |
Y |
>>appDVersion |
String |
1 |
Identifies the version of the application descriptor. It is equivalent to the appDVersion defined in clause 6.2.1.2 of ETSI GS MEC 010-2 [1]. |
Y |
>>appDescription |
String |
1 |
Human readable description of the MEC application (see note 2). |
Y |
>>referenceURI |
URI |
0...1 |
Address of the MEC application.This can be provided if the address of the MEC application is currently available. |
N |
>>clientAppName |
String |
0...N |
Client app name that is allowed to connect to the mec application. |
N |
>>clientAppPackageURL |
String |
0...1 |
Address for downloading the corresponding client application package to connect with the MEC application |
N |
>>uriTTL |
uint32 |
0...1 |
Time-to-live of the reference URI |
N |
>>uriLOC |
String |
0...1 |
Location (range) where the reference URI is available |
N |
>>carpRule |
Structure |
0...1 |
Client App Routing Policy Rules |
N |
>>>DNN |
String |
0...1 |
DNN selection for this application |
N |
>>>S-NSSAI |
String |
0...1 |
Network slice selection for this application |
N |
>>>accessType |
String |
0...1 |
Preferrend access type for this application (e.g., 4G, 5G, WiFi, etc.) |
N |
>>>sessionType |
String |
0...1 |
Ipv4, ipv6, etc. |
N |
>>>mptcp |
Boolean |
0...1 |
Indicates whether to use MPTCP for the matching application |
N |
>>fqdnList |
StringArray |
0...1 |
FQDN list that can be routed to MEC applications by the DNS proxy |
N |
>>appCharcs |
Structure |
0...1 |
Characteristics of the application as defined below.The application characteristics relate to the system resources consumed by the application. Device application can use this information e.g. for estimating the cost of use of the application or for the expected user experience. |
Y |
>>>memory |
String |
0...1 |
The maximum size in Mbytes of the memory resource expected to be used by the MEC application instance in the MEC system. |
Y |
>>>storage |
String |
0...1 |
The maximum size in Mbytes of the storage resource expected to be used by the MEC application instance in the MEC system. |
Y |
>>>latency |
String |
0...1 |
The target round trip time in milliseconds supported by the MEC system for the MEC application instance |
Y |
>>>bandwidth |
String |
0...1 |
The required connection bandwidth in kbit/s for the use of the MEC application instance |
Y |
>>>serviceCont |
String |
0...1 |
Required service continuity mode for this application.Permitted values:0 = SERVICE_CONTINUITY_NOT_REQUIRED.1 = SERVICE_CONTINUITY_REQUIRED |
Y |
>vendorSpecificExt |
String |
0...1 |
Extension for vendor specific information (see note 1). |
Y |
>>vendorId |
String |
1 |
Vendor identifier.The length of the value shall not exceed 32 characters.The rest of the structure of vendor specific extension is not defined. |
Y |
NOTE 1: The vendor specific extension allows submitting information on the application lists that have been made available to the device application of the corresponding vendor.NOTE 2: The language support may be limited. The length of the value shall not exceed 128 characters. |
<표 2>에 예시한 바와 같이, 다양한 실시예들에 따른 앱 리스트 응답 파라미터는, ETSI MEC 규격에서 정의되어 있는 파라미터 외에, 예를 들어, referenceURI, clientAppName, clientAppPackageURL, uriTTL, uriLOC, carpRule, DNN, S-NSSAI, accessType, sessionType, mptcp, 또는 fqdnList 중 적어도 하나를 포함할 수 있다.
일 실시 예에 따르면, <표 1> 및 <표 2>에 개시된 정보 이외에도, MEC 시스템(405)이 제공 가능한 어플리케이션들에 관한 정보는, 전자 장치(101)가 현재 접속된 기지국의 ID(identifier), 주변 기지국의 ID, GPS 정보, TA(tracking area) 정보, 또는 Wi-Fi ID 중 적어도 하나의 위치 정보에 대응하여 이용 가능한 적어도 하나의 정보를 포함할 수 있다. 일 실시예에 따르면, MEC 시스템(405)이 제공 가능한 어플리케이션들에 관한 정보는 어플리케이션이 요구하는 전자 장치(101)의 상태에 관한 정보(예: 전자 장치(101)의 이동(또는 움직임) 속도, 스크린 ON/OFF, 배터리 레벨, 기지국 수신 신호 세기, 타임 아웃 정보, 또는 전자 장치(101)와 MEC 호스트 간의 거리 정보 중 적어도 하나 이상의 조합)에 대응하여 이용 가능한 적어도 하나의 정보를 포함할 수 있다.
일 실시예에 따르면, MEC 시스템(405)이 제공 가능한 어플리케이션들에 관한 정보는 MEC 시스템(405)이 제공 가능한 어플리케이션의 도메인 이름(domain name)을 포함할 수 있다. 전자 장치(101)는 도메인 이름을 이용하여 MEC 어플리케이션에 접근(access)할 수 있다. 일 실시예에 따라, 전자 장치(101)가 도메인 이름을 이용하는 실시 예에 대하여 후술하는 도면(예: 도 36 내지 40)을 참조하여 설명된다.
일 실시예에 따르면, MEC 시스템(405)이 제공 가능한 어플리케이션들에 관한 정보는 MEC 시스템(405)(또는 MEC 호스트(447) 또는 MEC 어플리케이션(예: 460-1, 460-2)의 IP 주소를 더 포함할 수 있다.
일 실시예에 따르면, MEC 서비스 모듈(410)은 LADN 전용(dedicated) PDU 세션의 설정(establishment)에 연계하여 MEC 디스커버리 절차를 수행할 수 있다. 예를 들어, MEC 서비스 모듈(410)은 PDU 세션(예: LADN 전용 세션)이 설정된 경우에 MEC 디스커버리 절차를 수행할 수도 있고, MEC 디스커버리 절차를 수행하여 적합한 결과(예: 지정된 어플리케이션의 이름 또는 앱 리스트)를 수신한 경우에 PDU 세션(예: LADN 전용 세션)을 설정할 수 있다.
일 실시예에 따르면, MEC 서비스 모듈(410)은 디스커버리 절차를 수행하지 않고 동작 2007을 바로 수행할 수도 있다. 예를 들어, MEC 서비스 모듈(410)은 가용 어플리케이션의 앱 리스트가 전자 장치(101)에 이미 저장되어 있고, 앱 리스트를 업데이트 하는 지정된 주기가 지나지 않았거나 업데이트 요청이 없는 경우, 디스커버리 절차를 수행하지 않을 수 있다.
일 실시예에 따르면, MEC 서비스 모듈(410)은 디스커버리 절차를 수행하기 이전에 전자 장치(101)가 접속된 네트워크에서 MEC 기반 데이터 전송이 가능한지 여부를 확인하는 동작을 더 포함할 수 있다. 일 실시예에 따르면, 도 20에서는 도시되지 않았지만, MEC 서비스 모듈(410)은 전자 장치(101)의 이동성과 관련된 이벤트가 감지되기 이전 또는 감지된 이후에 전자 장치(101)의 컨텍스트 정보를 모니터링 할 수도 있다. 예를 들어, MEC 서비스 모듈(410)은 동작 2001 이전, 동작 2001 이후, 동작 2003 이후, 또는 동작 2005 이후에 컨텍스트 정보를 모니터링 할 수 있다. 일 실시예에 따르면, 컨텍스트 정보는 전자 장치(101)의 어플리케이션 프로세서(AP)(예: 도 1의 프로세서(120))가 지속적으로 활성화된 상태에서 모니터링 될 수 도 있고, 동작 2001 또는 동작 620과 같은 조건이 만족됨을 감지하는 별도의 모듈(예: 도 1 의 통신 모듈(190) 또는 센서 모듈(176) 중 적어도 하나)이 MEC 서비스 모듈(410)에게 메시지를 전달할 수 있다.
일 실시예에 따르면, 동작 2007에서, MEC 서비스 모듈(410)은 앱 리스트 또는 모니터링된 컨텍스트 정보 중 적어도 하나에 기반하여 전자 장치(101)에 설치된 어플리케이션들 중에서 적어도 하나의 어플리케이션(예: 클라이언트 어플리케이션(510))이 MEC에 기반한 데이터 전송을 이용할 수 있는 조건(예: 제1 조건)을 만족함을 결정할 수 있다. 예를 들어, MEC 서비스 모듈(410)은 (1) 수신된 앱 리스트 중 MEC에 기반한 데이터 전송이 이용 가능한 어플리케이션에 대응하는 어플리케이션이 전자 장치(101)에 있거나, (2) 전자 장치(101)가 현재 접속된 기지국의 ID, 주변 기지국의 ID, GPS 정보, TA 정보, Wi-Fi ID 중 적어도 하나의 위치 정보에 대응하여 이용 가능한 적어도 하나의 어플리케이션이 있거나, 또는 (3) 전자 장치(101)의 상태에 관한 정보에 대응하여 이용 가능한 적어도 하나의 어플리케이션이 있는 경우 제1 조건이 만족되는 것으로 결정할 수 있다. (3) 조건과 관련하여, MEC 서비스 모듈(410)은 동작 2005에서 수신한 ‘어플리케이션이 사용 가능한 전자 장치(101)의 상태에 관한 정보’(예: 전자 장치(101)의 이동 속도, 스크린 ON/OFF, 배터리 레벨, 기지국 수신 신호 세기, 타임 아웃 정보 중 적어도 하나 이상의 조합)에 대응하는 이용 가능한 적어도 하나의 어플리케이션이 있는 경우 제1 조건이 만족되는 것으로 결정할 수 있다. 예를 들어, 제1 어플리케이션(예: 도 3의 제1 App(310-1))은 ‘전자 장치(101)의 이동성 없는 상태의 약 1분 이상 지속, 스크린 ON, 기지국 신호 세기가 임계값 이상(예: 양호)이라고 판단될 때’와 같은 전자 장치(101)의 상태 정보를 요구할 수 있다. 예를 들어, 제2 어플리케이션(예: 도 3의 제2 App(310-2))은 ‘스크린 ON, 배터리 레벨 임계값(예: 30%) 이상’과 같은 전자 장치(101)의 상태 정보를 요구할 수 있다. MEC 서비스 모듈(410)은 전자 장치(101)의 상태가 각 어플리케이션들이 요구하는 상태 정보에 부합할 때 제1 조건이 만족되는 것으로 결정할 수 있다.
일 실시예에 따르면, MEC 서비스 모듈(410)은 동작 2007을 수행하지 않고 바로 동작 2009를 수행할 수도 있다.
일 실시예에 따르면, 동작 2009에서, MEC 서비스 모듈(410)은 클라이언트 어플리케이션(510)에게 MEC 기반 데이터 전송이 이용 가능 함을 나타내는 알림 메시지를 전송할 수 있다. 일 실시예에 따르면, MEC 기반 데이터 전송이 이용 가능 한 어플리케이션(예: 클라이언트 어플리케이션(510))이 전자 장치(101)에 설치되지 않은 경우, MEC 서비스 모듈(410)은 어플리케이션 레이어(446)에게 어플리케이션의 설치(또는 저장)를 가이드 하는 메시지를 전송할 수 있다.
일 실시예에 따르면, MEC 서비스 모듈(410)은 동작 2009를 수행하지 않을 수 있다. 일 실시예에 따르면, MEC 서비스 모듈(410)은 전자 장치(101)의 디스플레이(예: 도 1의 표시 장치(160)) 상에서 특정 어플리케이션의 MEC 기반 데이터 전송이 이용 가능함을 나타내는 GUI(graphic user interface)를 해당 어플리케이션의 아이콘 상에 표시할 수 있다. 다른 실시예에 따르면, MEC 서비스 모듈(410)은 MEC 기반 데이터 전송이 이용 가능한 어플리케이션의 MEC 성능(예: 신호 세기)을 표시할 수 있다. 신호 세기는, 예를 들어, ‘good’, ‘normal’, 또는 ‘bad’로 표시될 수 있다.
동작 2011에서, MEC 서비스 모듈(410)은 MEC 시스템(405)에 포함되는 MEC 어플리케이션을 실행하기 위한 요청(예: 컨텍스트 생성(context create))을 할 수 있다. 일 실시예에 따르면, 도 20에서는 도시되지 않았지만, MEC 서비스 모듈(410)뿐만 아니라 클라이언트 어플리케이션(510)에서도 컨텍스트 생성(context creation)을 수행할 수 있다.
일 실시예에 따르면, 클라이언트 어플리케이션(510)이 전자 장치(101)에서 실행되거나, 또는 클라이언트 어플리케이션(510)이 MEC 어플리케이션의 도메인 이름(예: URI(uniform resource identifier))에 대한 접근을 요청하면, MEC 서비스 모듈(410)은 컨텍스트 생성을 수행할 수 있다. 다른 예를 들어, MEC 서비스 모듈(410)은 지정된 주기에 따라 컨텍스트 생성을 수행할 수 있다. 다른 예를 들어, MEC 서비스 모듈(410)은 전자 장치(101)의 이동성과 관련된 이벤트가 감지되면 컨텍스트 생성을 수행할 수 있다.
일 실시예에 따르면, MEC 서비스 모듈(410)은 MEC 제어 평면 상에서 MEC 시스템(405)(예: MMP 서버(430)와 컨텍스트 생성을 수행할 수 있다. MEC 서비스 모듈(410)이 컨텍스트 생성을 통해 MEC 어플리케이션의 실행을 요청하면, MEC 시스템(405)(예: MEP 매니저(445))은 MEC 어플리케이션을 실행할 수 있다. 일 실시예에 따라, MEC 시스템(405)(예: MEC 호스트(447))에 MEC 어플리케이션이 설치되지 않은 경우, MEC 시스템(405)(예: MEP 매니저(445))은 MEC 어플리케이션을 설치한 후 실행할 수 있다.
일 실시예에 따르면, 동작 2013에서, 클라이언트 어플리케이션(410)은 MEC 시스템(405)과 데이터 전송을 수행할 수 있다. 예를 들어, 클라이언트 어플리케이션(410)은 사용자 평면 상에서 MEC 시스템(405)의 MEC 어플리케이션(예: 460-1 또는 460-2)와 데이터 통신을 수행할 수 있다. 일 실시예에 따르면, 동작 2013에서 송수신되는 데이터 패킷은 사용자 데이터를 포함하는 제2 데이터 패킷으로서, 클라이언트 어플리케이션(410)(또는 MEC 어플리케이션)과 관련된 제2 주소를 포함할 수 있다. 일 실시예에 따르면, MEC 서비스 모듈(410)이 동작 2013 이전에 MEC 호스트(447)(또는 MEC 어플리케이션)의 IP 주소를 획득하는 경우, 클라이언트 어플리케이션(410)은 획득된 IP 주소를 이용하여 데이터 전송을 수행할 수 있다. MEC 호스트(447) 또는 MEC 어플리케이션의 IP 주소를 획득하는 실시예는 도 37 내지 도 39에서 후술된다. 일 실시예에 따르면, 클라이언트 어플리케이션(410)은 어플리케이션 레이어(예: 도 3의 사용자 평면) 상에서 HTTP(hypertext transfer protocol)에 기반한 데이터 전송을 수행할 수 있다. 다른 실시예에 따르면, 전자 장치(101)는 HTTP 이외에도 다른 프로토콜에 기반하여 데이터 전송을 수행할 수 있다. 예를 들어, 전자 장치(101)는 RPC(remote procedure call) 프로토콜에 기반하거나, 어플리케이션 레이어(446)의 하위 레이어(예: TCP/IP(transmission control protocol/internet protocol) 또는 UDP/IP(user datagram protocol/internet protocol))에 기반하여 데이터 전송을 수행할 수 있다.
도 20에서는 도시되지 않았지만, MEC 서비스(410)은 전자 장치(101)가 지정된 지역을 벗어남을 감지한 것에 응답하여 MEC 어플리케이션의 종료(예: 컨텍스트 삭제(context delete))를 요청할 수 있다.
다양한 실시예들에 따르면, 전자 장치(101)는 상술한 다양한 방법을 통해 MEC 서비스 모듈(410)이 복수의 어플리케이션들의 MEC 기반 데이터 전송을 지정된 조건에 따라 통합적으로 트리거링 하도록 함으로써, 개별적인 데이터 전송으로 인한 전자 장치(101)의 부하를 줄일 수 있다.
일 실시예에 따르면, 전자 장치(101)는 기업(enterprise) 또는 학교로부터 MEC 기반 서비스를 제공받을 수 있다. 전자 장치(101)가 전자 장치(101)의 이동성과 관련된 이벤트를 감지하면(예: 동작 2001), 전자 장치(101)는 MEC 디스커버리 절차(예: 동작 2003 내지 동작 2005)를 통해 기업 또는 학교에서 제공되는 MEC 기반 서비스(또는 MEC 기반 데이터 전송을 지원하는 어플리케이션)을 식별(identify)할 수 있다. 전자 장치(101)는 위치 측정 기술(예: 셀룰러, 위성, 또는 Wi-Fi에 기반한 위치 측정 기술) 또는 센서 모듈(176) 중 적어도 하나를 이용하여 결정된 전자 장치(101)의 위치(예: 기업 또는 학교 내부)에서 이용 가능한 MEC 어플리케이션이 존재함을 감지할 수 있다(예: 동작 2007). 다른 예를 들어, 전자 장치(101)는 기업(또는 학교) 내부에 설치된 비콘(beacon) 장치로부터 비콘 신호를 수신하거나, NFC(near field communication) 태깅(tagging)을 통해 전자 장치(101)가 이용 가능한 MEC 어플리케이션이 존재함을 감지할 수 있다. MEC 서비스 모듈(410)은 기업 또는 학교에서 MEC 기반 데이터 전송을 수행할 수 있는 어플리케이션에게 알림 메시지를 전송할 수 있다(예: 동작 2009). 알림 메시지를 수신한 어플리케이션은 전자 장치(101)에서 자동적으로 실행되거나, 해당 어플리케이션이 이용 가능함을 나타내는 사용자 인터페이스를 디스플레이(예: 도 1의 표시 장치(160))를 통해 표시할 수 있다. 어플리케이션이 실행되면, 전자 장치(101)는 MEC에 기반한 데이터 전송을 통해 기업 또는 학교로부터 서비스를 제공받을 수 있다(예: 동작 2013).
다른 실시예에 따르면, 전자 장치(101)는 광고 또는 쿠폰을 제공하는 장소(예: 백화점 또는 쇼핑몰)로부터 MEC 기반 서비스를 제공받을 수 있다. 전자 장치(101)가 지정된 지역에 진입하면(예: 동작 2001), 전자 장치(101)는 MEC 디스커버리 절차(예: 동작 2003 내지 동작 2005)를 통해 백화점 또는 쇼핑몰에서 제공되는 MEC 기반 서비스를 식별할 수 있다. 전자 장치(101)는 위치 측정 기술 또는 센서 모듈(176) 중 적어도 하나를 이용하여 결정된 전자 장치(101) 위치(예: 백화점(또는 쇼핑몰)의 특정 구역)에서 이용 가능한 MEC 어플리케이션이 존재함을 감지할 수 있다(예: 동작 2007). MEC 서비스 모듈(410)은 백화점 또는 쇼핑몰에서 MEC 기반 데이터 전송을 수행할 수 있는 어플리케이션에게 알림 메시지를 전송하고(예: 동작 2009), 알림 메시지를 수신한 어플리케이션은 광고 또는 쿠폰을 팝업 형태로 표시할 수 있다.
다른 실시예에 따르면, 전자 장치(101)는 게임 서비스를 제공받을 수 있다. 전자 장치(101)가 지정된 지역에 진입하면(예: 동작 2001), 전자 장치(101)는 MEC 디스커버리 절차(예: 동작 2003 내지 동작 2005)를 통해 게임 어플리케이션들에 관한 정보를 획득할 수 있다. 전자 장치(101)는 <표 1>에 개시된 정보에 적어도 기반하여 MEC 시스템(405)(예: MEC 서버)에서 제공되는 게임 어플리케이션 중 전자 장치(101)에 설치된 게임 어플리케이션이 요구하는 기준(예: 메모리, 지연 시간, 또는 주파수 대역)을 만족하는 게임 어플리케이션을 결정할 수 있다(예: 동작 2007). 다른 예를 들어, 전자 장치(101)에 설치된 게임 어플리케이션이 전자 장치(101)의 움직임을 요구하면, 전자 장치(101)는 전자 장치(101)의 움직임을 감지할 수 있다. MEC 서비스 모듈(410)은 게임 어플리케이션에게 알림 메시지를 전송하고(예: 동작 2009), 게임 어플리케이션이 실행되면, 전자 장치(101)는 MEC에 기반한 데이터 전송을 통해 서비스를 제공받을 수 있다(예: 동작 2013).
도 21은 다양한 실시 예들에 따른 전자 장치(101)에서 디스커버리 절차를 위한 동작 방법을 도시하는 흐름도이다.
다양한 실시예들에서, 도 21에 도시된 동작들은, 예를 들어, 전자 장치(101) 또는 전자 장치(101)에 포함된 구성 요소(예: 도 1의 프로세서(120) 또는 도 4의 MEC 서비스 모듈(410))에 의하여 수행될 수 있다.
도 21을 참조하면, 동작 2101에서, 전자 장치(101)는 전자 장치(101)의 이동성과 관련된 이벤트를 감지할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 전자 장치(101)가 연결된 기지국(예: 도 3의 AN(302))로부터 수신된 위치 정보(예: LADN ID, TA ID, 기지국 ID, 또는 cell ID 중 적어도 하나)에 기반하거나, 위치 측정 기술에 기반하거나, 또는 전자 장치(101)에 실장된 별도의 센서 모듈(176)을 통해 이동성과 관련된 이벤트를 감지할 수 있다.
동작 2103에서, 전자 장치(101)는 MEC 시스템(405)이 제공 가능한 어플리케이션들에 관한 정보(예: 앱 리스트)를 요청할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 MMP 서버(430)에게 앱 리스트를 요청할 수 있다.
동작 2105에서, 전자 장치(101)는 MEC 시스템(405)이 제공 가능한 어플리케이션들에 관한 정보를 수신할 수 있다. MEC 시스템(405)이 제공 가능한 어플리케이션들에 관한 정보는, 예를 들어, <표 1>에 개시된 정보, 전자 장치(101)가 현재 접속된 기지국의 ID(identifier), 주변 기지국의 ID, GPS 정보, TA 정보, 또는 Wi-Fi ID 중 적어도 하나의 위치 정보에 대응하여 이용 가능한 적어도 하나의 어플리케이션, 전자 장치(101)의 상태에 관한 정보에 대응하여 이용 가능한 적어도 하나의 어플리케이션, 또는 도메인 이름에 대한 MEC 호스트(447)의 IP 주소 중 적어도 하나를 포함할 수 있다.
동작 2107에서, 전자 장치(101)는 MEC 시스템(405)이 제공 가능한 어플리케이션들에 관한 정보 또는 컨텍스트 정보 중 적어도 하나에 기반하여 전자 장치(101)에 설치된 어플리케이션(예: 클라이언트 어플리케이션(510))이 MEC에 기반한 데이터 전송을 수행할 수 있는 제1 조건을 만족하는지 결정할 수 있다.
동작 2109에서, 전자 장치(101)는 제1 조건을 만족하는 어플리케이션을 통해 데이터 전송을 수행할 수 있다. 예를 들어, 제1 조건을 만족하는 어플리케이션은 MEC 시스템(405)(예: MEC 서버)에 설치된 MEC 어플리케이션과 어플리케이션 레이어 상에서 데이터 전송을 수행할 수 있다.
도 22는 다양한 실시예들에 따른 전자 장치(101)에서 디스커버리 절차를 위한 동작 방법을 도시하는 흐름도이다.
도 22를 참조하면, 동작 2201에서, 전자 장치(101)의 프로세서(120)(또는 도 4의 MEC 서비스 모듈(410))는 MEC 디스커버리 정책(discovery policy)을 MEC 시스템(405)으로부터 획득(또는 수신)할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSA(520)는 MEC 시스템(405)으로부터 MEC 디스커버리 정책을 수신하고, MSE(530)로 MEC 디스커버리 정책을 전달할 수 있다. 일 실시예에 따르면, MEC 서비스 모듈(410)은 MSA(520)를 이용하여 MEC 디스커버리 정책을 획득하고, MSE(530)를 이용하여 수신된 MEC 디스커버리 정책에 기반한 디스커버리 절차를 수행할 수 있다. 예를 들어, 전자 장치(101)의 MSE(530)는 MSA(520)로부터 MSE API를 통해 MEC 디스커버리 정책을 수신할 수 있다. 일 실시예에 따르면, MEC 디스커버리 정책은 <표 1>에 예시한 바와 같은 파라미터를 포함할 수 있다. 예를 들어, MEC 디스커버리 정책은 클라이언트 어플리케이션 이름(예: clientAppNames), 위치(예: locationInfo), 디바이스 타입(예: deviceType), 서비스 타입(예: serviceType), 컨텍스트 타입(contextType), 어플리케이션 URI 요청(예: URI Request), 또는 동적(dynamic) DNN(예: dynamicDnn) 중 적어도 하나를 포함할 수 있다. 일 실시예에 따라, 클라이언트 어플리케이션 이름은 MEC 사용 가능 여부를 확인하기 위한 앱 리스트를 요청하기 위한 정보일 수 있고, 위치는 전자 장치(101)의 현재 위치에 따른 위치 기반 앱 리스트를 요청하기 위한 정보일 수 있고, 동적 DNN은 동적 DNN 업데이트(dynamic DNN update) 사용 여부를 확인하기 위한 정보일 수 있다. 일 실시예에 따르면, 전자 장치(101)는 MEC 디스커버리 정책에 디바이스 타입과 서비스 타입을 포함하여, 각 타입에 대응하는 앱 리스트를 요청할 수 있고, 또한 컨텍스트 타입을 포함하여 어플리케이션의 컨텍스트 필요 여부를 전달할 수도 있다. 일 실시예에 따르면, 전자 장치(101)는 MEC 디스커버리 정책에 어플리케이션 URI 요청을 포함하여 MEC 어플리케이션의 URI가 가용할 경우 앱 리스트에 URI를 포함하도록 요청할 수도 있다.
동작 2203에서, 프로세서(120)는 MEC 디스커버리 정책에 기반하여, 지정된 외부 서버(예: MMP 서버(430))로부터 서비스 가능한 MEC 어플리케이션의 앱 리스트를 획득할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSE(530)는 MSA(520)로부터 수신된 MEC 디스커버리 정책에 기반하여 앱 리스트를 획득하기 위한 획득 절차(예: MEC Application Look-up)를 수행할 수 있다. 일 실시예에 따르면, MSE(530)는 MEC 디스커버리 정책에 따라 서비스 가능한 MEC 어플리케이션에 관련된 앱 리스트를 MMP 서버(430)로 요청하여 수신할 수 있다.
동작 2205에서, 프로세서(120)는 클라이언트 어플리케이션(510)의 어플리케이션 컨텍스트를 생성(예: Appliction Context Create)할 수 있다. 일 실시예에 따르면, MEC 서비스 모듈(410)은 MEC 시스템(405)에 포함되는 MEC 어플리케이션을 실행하기 위한 요청(예: 컨텍스트 생성(context create))을 할 수 있다. 일 실시예에 따르면, 도 22에서는 도시되지 않았지만, MEC 서비스 모듈(410)뿐만 아니라 클라이언트 어플리케이션(510)에서도 컨텍스트 생성(context creation)을 수행할 수 있다. 일 실시예에 따르면, MEC 서비스 모듈(410)은 MSA(520)에 의해 자체적으로 클라이언트 어플리케이션(510)의 실행을 감지할 수 있고, MSA(520) 또는 MSE(530)가 제공하는 Context Create API를 통해 클라이언트 어플리케이션(510)이 해당 API를 호출(call)할 수 있다. 일 실시예에 따르면, 클라이언트 어플리케이션(510)은 MSA(520)로 App Launch Detected 또는 API(예: Context Create API) call을 제공(또는 전달)할 수 있다. App Launch Detected는, 예를 들어, 클라이언트 어플리케이션(510)이 실행되는 경우를 나타낼 수 있다. API(Context Create) call은, 예를 들어, 접속하고자 하는 MEC 어플리케이션 이름(예: MEC App Name)에 대한 URI를 요청하는 경우를 나타낼 수 있다. 일 실시예에 따르면, MSA(520)는 App Launch Detected 또는 API(Context Create) call를 수신하면, 클라이언트 어플리케이션(510)의 상태(state)를 통지(notify)하는 상태 통지 메시지(예: notifyClientAppState)를 MSE(530)로 제공할 수 있다. 일 실시예에 따라, 상태 통지 메시지는, 예를 들어, 클라이언트 어플리케이션의 상태(예: START)와 클라이언트 어플리케이션의 이름(예: clientAppName)(및/또는 UID)을 포함(예: notifyClientAppState(START, clientAppName))하여 제공할 수 있다. 일 실시예에 따르면, MSA(520)는 클라이언트 어플리케이션(510) 실행을 감지하는 경우 MSE API 호출에 의하여, 클라이언트 어플리케이션)510)의 실행 상태를 MSE(530)에 통지할 수 있다.
동작 2207에서, 프로세서(120)는 클라이언트 어플리케이션(510)의 실행을 감지하면, 앱 리스트에 기반하여, 클라이언트 어플리케이션(510)과 연관되고 접속하고자 하는 MEC 어플리케이션에 관련된 정보를 지정된 외부 서버(예: MMP 서버(430))로부터 획득할 수 있다. MEC 어플리케이션에 관련된 정보는, 예를 들어, MEC 어플리케이션 이름(MEC App Name)에 대한 URI, 전용 DNN(dedicated DNN) 정보, 또는 MEC 어플리케이션 패키지(package) URI(예: MEC 어플리케이션이 없는 경우) 중 적어도 하나를 포함할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSE(530)는 MSA(520)로부터 상태 통지 메시지를 수신하고, 수신된 상태 통지 메시지에 기반하여 MEC 어플리케이션(또는 해당 MEC 어플리케이션을 포함하는 MEC 호스트(예: 엣지 서버 또는 MEC 서버))을 발견(또는 탐색, 확인)하기 위한 절차(예: 어플리케이션 컨텍스트 생성(application context create))를 수행할 수 있다. 일 실시예에 따르면, 어플리케이션 컨텍스트 생성은 MSA(520)가 클라이언트 어플리케이션(510) 실행을 감지하는 경우 MSE API 호출에 의하여 활성화 될 수 있다. 일 실시예에 따르면, 어플리케이션 컨텍스트 생성은, 클라이언트 어플리케이션(510)이 컨텍스트 생성(context create) API 호출 시에 활성화 될 수 있다.
동작 2209에서, 프로세서(120)는 획득된 정보에 기반하여, MEC 호스트(Host)를 선택할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSE(530)는 DNS 서버와 MEC 호스트를 선택하기 위한 호스트 선택 절차(예: MEC Host Selection)를 수행할 수 있다. 일 실시예에 따르면, 호스트 선택 절차는 미리 설정된 정보 및/또는 DNS 서버로 문의한 정보를 이용하여 결정하거나, 또는 DNS 서버로 문의한 정보 및/또는 사용자에게 문의하여 특정한 MEC 호스트를 선택(또는 설정)하도록 할 수 있다.
동작 2211에서, 프로세서(120)는 선택된 MEC 호스트와 데이터 전송을 수행할 수 있다. 예를 들어, 클라이언트 어플리케이션(510)은 MEC 시스템(405)(예: MEC 서버)에 설치된 MEC 어플리케이션과 어플리케이션 레이어 상에서 데이터 전송을 수행할 수 있다.
도 23은 다양한 실시예들에 따른 디스커버리 절차의 예를 도시하는 도면이다.
도 23에 도시한 바와 같이, 도 23은 어플리케이션 상태 기반(App state-based)의 MEC 디스커버리 절차의 예를 나타낼 수 있다. 일 실시예에 따르면, 전자 장치(101)는 클라이언트 어플리케이션(또는 Client App)(510), MSA(또는 서비스 에이전트)(520), MSE(또는 서비스 인에이블러)(530)(예: MEL(531), UHL(533) 포함), 및 DNS 캐시(cache)(2310)를 포함할 수 있다.
도 23을 참조하면, 동작 2301에서, 전자 장치(101)의 MSA(520)는 MSE(530)로 MEC 디스커버리 정책(discovery policy)을 설정할 수 있다. 일 실시예에 따르면, MEC 디스커버리 정책은 클라이언트 어플리케이션 이름(예: clientAppNames)과 디스커버리 정책(예: discoveryPolicy)을 포함하여 제공할 수 있다. 일 실시예에 따라, discoveryPolicy에는 동적 DNN(예: dynamicDnn)의 사용 여부가 포함될 수 있고, 위치(예: locationInfo), 디바이스 타입(예: deviceType), 서비스 타입(예: serviceType), 또는 컨텍스트 타입(예: contextType)과 같은 <표 1>의 정보 중 적어도 하나를 포함하여 제공할 수 있다. 일 실시예에 따르면, MSA(520)는 위치(예: locationInfo), 디바이스 타입(예: deviceType), 서비스 타입(예: serviceType)을 discoveryPolicy에 포함하여 앱 리스트를 해당 조건에 맞는 리스트만 한정하여 수신하도록 할 수도 있다. 일 실시예에 따르면, MSA(520)는 컨텍스트 타입(예: contextType)을 discoveryPolicy에 포함하여 어플리케이션 컨텍스트(application context)가 필요한지 여부에 대한 정보를 포함할 수 있다. 일 실시예에 따르면, MSA(520)는 URI Request Flag를 discoveryPolicy에 포함하여 MEC 어플리케이션의 URI가 가용한 경우 앱 리스트에 URI 포함하도록 요청할 수도 있다. 일 실시예에 따라, 클라이언트 어플리케이션 이름(clientAppNames)은 MEC 사용 가능 여부를 확인하기 위한 앱 리스트를 요청하기 위한 정보일 수 있고, 위치(locationInfo)는 전자 장치(101)의 현재 위치에 따른 위치 기반 앱 리스트를 요청하기 위한 정보일 수 있고, 동적 DNN(dynamicDnn)은 동적 DNN 업데이트(dynamic DNN update) 사용 여부를 확인하기 위한 정보일 수 있다.
동작 2303에서, MSE(530)는 MSA(520)로부터 수신된 정보(예: MEC 디스커버리 정책)에 기반하여 앱 리스트(예: AppList)를 획득하기 위한 획득 절차(예: MEC Application Look-up)를 수행할 수 있다. 일 실시예에 따르면, MSA(520)와 MSE(530) 간에 MEC 디스커버리 정책 설정에 따라 앱 리스트를 획득하기 위한 획득 절차(예: MEC Application Look-up)가 시작될 수 있다. 일 실시예에 따르면, MSE(530)는 MSA(520)로부터 MSE API를 통해 MEC 디스커버리 정책을 수신하는 경우 MEC Application Look-up을 활성화 할 수 있고, 전자 장치(101)의 특정 조건(예: 전자 장치(101)가 움직이는 중 접속 기지국 Cell ID 변경) 만족 시 수행(또는 시작)할 수 있다. 일 실시예에 따르면, MSE(530)는 MEC 디스커버리 정책에 따라 서비스 가능한 MEC 어플리케이션(예: MEP App)에 관련된 앱 리스트(예: MEC AppList)를 MMP 서버(430)로 요청하여 수신할 수 있다. 일 실시예에 따르면, MSE(530)는 MEC 디스커버리 정책을 <표 1>에 예시한 바와 같은 MEC AppList request message Parameter에 기입하여 MMP 서버(430)에 요청할 수 있고, MMP 서버(430)는 그에 맞는 서비스 가능 앱 리스트(예: <표 2>의 MEC AppList)를 MSE(530)로 제공하여, MSE(530)의 요청에 응답할 수 있다. 다양한 실시예들에 따른 앱 리스트 획득 절차(예: MEC Application Look-up)에 대하여 후술하는 도면을 참조하여 상세히 설명된다.
동작 2305에서, 클라이언트 어플리케이션(510)은 MSA(520)로 App Launch Detected 또는 API(Context Create) call을 제공(또는 전달)할 수 있다. 일 실시예에 따르면, App Launch Detected의 경우는 클라이언트 어플리케이션(510)이 실행되는 경우를 나타낼 수 있다. 일 실시예에 따르면, API(Context Create) call은 접속하고자 하는 MEC 어플리케이션 이름(예: MEC App Name)에 대한 URI를 요청하는 경우를 나타낼 수 있다.
동작 2307에서, MSA(520)는 App Launch Detected 또는 API(Context Create) call를 수신하면, 클라이언트 어플리케이션(510)의 상태(state)를 통지(notify)하는 통지 메시지(예: notifyClientAppState)를 MSE(530)로 제공할 수 있다. 일 실시예에 따라, 통지 메시지(예: notifyClientAppState)는, 예를 들어, 클라이언트 어플리케이션의 상태(예: START)와 클라이언트 어플리케이션의 이름(예: clientAppName)(및/또는 UID)을 포함(예: notifyClientAppState(START, clientAppName))하여 제공할 수 있다.
동작 2309에서, MSE(530)는 MSA(520)로부터 통지 메시지(예: notifyClientAppState)를 수신하고, 수신된 통지 메시지에 기반하여 MEC 어플리케이션(또는 해당 MEC 어플리케이션을 포함하는 MEC 호스트(예: 엣지 서버 또는 MEC 서버))을 발견(또는 탐색, 확인)하기 위한 절차(예: 어플리케이션 컨텍스트 생성(application context create))를 수행할 수 있다. 일 실시예에 따르면, MSE(530)는 MSA(520)로부터 클라이언트 어플리케이션(510)의 실행과 관련된 이벤트(event)를 수신하는 경우 어플리케이션 컨텍스트 생성을 활성화 할 수 있다. 일 실시예에 따르면, MSE(530)는 수신된 통지 메시지(예: notifyClientAppState)의 정보에 기반하여 MMP 서버(430)를 통해 원하는 MEC 어플리케이션을 포함하는 MEC 호스트를 찾기 위한 어플리케이션 컨텍스트 생성 동작을 수행할 수 있다. 일 실시예에 따르면, 어플리케이션 컨텍스트 생성은, MSA(520)가 클라이언트 어플리케이션(510) 실행을 감지하는 경우 MSE API 호출에 의하여 활성화(또는 수행)될 수 있다. 일 실시예에 따르면, 어플리케이션 컨텍스트 생성은, 클라이언트 어플리케이션(510)이 컨텍스트 생성(context create) API 호출 시에 활성화(또는 수행)될 수 있다. 일 실시예에 따르면, MSE(530)는 접속하고자 하는 MEC 어플리케이션 이름(예: MEC App Name)에 대한 URI를 MMP 서버(430)로 요청 및 수신할 수 있다. 일 실시예에 따라, MSE(530)는 필요에 따라 전용 DNN(dedicated DNN)에 대한 정보를 MMP 서버(430)에 요청 및 수신할 수도 있다. 일 실시예에 따르면, MMP 서버(430)는 해당 MEC 어플리케이션이 없는 경우에는 MEC 어플리케이션 패키지(package) URI를 MSE(530)로 전달할 수도 있다. 다양한 실시예들에 따른 어플리케이션 컨텍스트 생성 절차에 대하여 후술하는 도면을 참조하여 상세히 설명된다.
동작 2311에서, MSE(530)는 DNS 서버(2320)와 MEC 호스트를 선택하기 위한 호스트 선택 절차(예: MEC Host Selection)를 수행할 수 있다. 일 실시예에 따르면, MSE(530)는 MMP 서버(430)를 통해 획득한 MEC 호스트가 적어도 둘 이상인 경우, DNS 서버(2320)와 어느 하나의 MEC 호스트를 선택하기 위한 호스트 선택 절차(예: MEC Host Selection)를 수행할 수 있다. 일 실시예에 따르면, MEC 호스트가 둘 이상인 경우 하나의 MEC 호스트를 선택하기 위한 호스트 선택 절차는 미리 설정된 정보 및/또는 DNS 서버(2320)로 문의한 정보를 이용하여 결정하거나, 또는 DNS 서버(2320)로 문의한 정보 및/또는 사용자에게 문의하여 특정한 MEC 호스트를 선택(또는 설정)하도록 할 수 있다. 일 실시예에 따르면, MSE(530)가, MEC 호스트가 둘 이상인 경우 특정한 MEC 호스트를 설정하기 위한 미리 설정된 정보는 우선순위 정보를 포함할 수 있다. 일 실시예에 따르면, 호스트 선택 절차는 DNS 프리 리졸빙(Pre-resolving) 동작과 MEC 호스트 우선순위 결정(MEC Host Prioritization) 동작을 포함할 수 있다. 일 실시예에 따라, DNS Pre-resolving는, 예를 들어, 클라이언트 어플리케이션(510)의 DNS 쿼리(query)와 상관 없이 MSE(530) 자체적으로 MEC용 FQDN((fully qualified domain name))에 대해 DNS 리졸빙을 수행하는 것을 포함할 수 있다. 일 실시예에 따라, DNS 리졸빙은, 동작 2303의 MEC Application Look-up 단계 또는 동작 2309의 Application Context Creat 단계를 통해 수신한 URI 또는 도메인 이름(domain name)이 사용하여 수행될 수 있다. 일 실시예에 따라, MEC Host Prioritization는, 예를 들어, DNS 쿼리 응답(query response)으로 복수 개의 IP 주소가 수신되는 경우 IP 우선순위를 설정하는 것을 포함할 수 있다. 다양한 실시예들에 따른 호스트 선택 절차(예: MEC Host Selection)에 대하여 후술하는 도면을 참조하여 상세히 설명된다.
동작 2313에서, 클라이언트 어플리케이션(510)은 이상의 동작을 통해 획득한 정보를 이용하여 DNS 리졸빙(Resolving) 동작을 수행할 수 있다. 일 실시예에 따르면, DNS 리졸빙은, 예를 들어, 클라이언트 어플리케이션(510)의 DNS 쿼리 발생 시 수행할 수 있다. 일 실시예에 따르면, DNS 리졸빙은, 예를 들어, Client-driven normal DNS resolving 또는 DNS proxying (hooking DNS query)를 포함할 수 있다. 다양한 실시예들에 따른 DNS 리졸빙에 대하여 후술하는 도면을 참조하여 상세히 설명된다.
도 24는 다양한 실시예들에 따른 전자 장치(101)에서 디스커버리 절차를 위한 동작 방법을 도시하는 흐름도이다.
도 24를 참조하면, 동작 2401에서, 전자 장치(101)의 프로세서(120)(또는 도 4의 MEC 서비스 모듈(410))는 MEC 디스커버리 정책(discovery policy)을 수신할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSA(520)는 MSE(530)로 MEC 디스커버리 정책을 설정할 수 있다. 예를 들어, 전자 장치(101)의 MSE(530)는 MSA(520)로부터 MSE API를 통해 MEC 디스커버리 정책을 수신할 수 있다. 일 실시예에 따르면, MEC 디스커버리 정책은 <표 1>을 참조한 설명 부분에서 설명한 바와 같은 정보(또는 파라미터) 중 적어도 하나를 포함할 수 있다.
동작 2403에서, 프로세서(120)는 MEC 디스커버리 정책에 기반하여, 지정된 외부 서버(예: MMP 서버(430))로부터 서비스 가능한 MEC 어플리케이션의 앱 리스트를 획득할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSE(530)는 MSA(520)로부터 수신된 MEC 디스커버리 정책에 기반하여 앱 리스트를 획득하기 위한 획득 절차(예: MEC Application Look-up)를 수행할 수 있다. 일 실시예에 따르면, MSE(530)는 MEC 디스커버리 정책에 따라 서비스 가능한 MEC 어플리케이션에 관련된 앱 리스트를 MMP 서버(430)로 요청하여 수신할 수 있다.
동작 2405에서, 프로세서(120)는 클라이언트 어플리케이션(510)에 의해 발생되는 DNS 쿼리(query)를 감지하여 후킹(hooking)할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 클라이언트 어플리케이션(510)은 MSE(530)로 DNS 쿼리(query)를 위한 메시지(예: DNS query 메시지)를 전달할 수 있다. 일 실시예에 따라, DNS 쿼리는 클라이언트 어플리케이션(510)에서 발생할 수 있으며, 일반적으로, DNS 쿼리는 DNS 서버(2320)로 전달되어, DNS 서버(2320)에서 DNS 쿼리에 대한 응답을 제공할 수 있다. 다양한 실시예들에 따르면, DNS 쿼리는 전자 장치(101)의 MSE(530)(예: DHL(535))에 의해 감지할 수 있다. 예를 들어, 클라이언트 어플리케이션(510)에서 DNS 쿼리가 발생하는 경우, MSE(530)에서 발생된 DNS 쿼리를 감지하고, DNS 서버(2320)로 전달되기 이전에 가로채서(hooking), 후술하는 동작 2407(예: Context Create)과 후술하는 동작 2409(예: DNS resolving)을 수행하고, 이후 DNS 응답을 클라이언트 어플리케이션(510)으로 전달할 수 있다.
동작 2407에서, 프로세서(120)는 클라이언트 어플리케이션(510)에서 DNS 쿼리 메시지가 발생하면, 앱 리스트에 기반하여, 클라이언트 어플리케이션(510)과 연관되고 접속하고자 하는 MEC 어플리케이션에 관련된 정보를 지정된 외부 서버(예: MMP 서버(430))로부터 획득할 수 있다. MEC 어플리케이션에 관련된 정보는, 예를 들어, MEC 어플리케이션 이름(MEC App Name)에 대한 URI, 전용 DNN(dedicated DNN) 정보, 또는 MEC 어플리케이션 패키지(package) URI(예: MEC 어플리케이션이 없는 경우) 중 적어도 하나를 포함할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSE(530)는 클라이언트 어플리케이션(510)으로부터의 DNS 쿼리에 응답하여 MMP 서버(430)와 어플리케이션 컨텍스트 생성 동작을 수행할 수 있다. 일 실시예에 따르면, MSE(530)는 클라이언트 어플리케이션(510)에서 DNS query (with FQDN) 메시지 발생 시 해당 MEC 어플리케이션에 대한 어플리케이션 컨텍스트 생성을 수행할 수 있다.
동작 2409에서, 프로세서(120)는 획득된 정보에 기반하여, MEC 호스트(Host)를 선택할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSE(530)는 DNS 서버(2320)와 MEC 호스트를 선택하기 위한 호스트 선택 절차(예: MEC Host Selection)를 수행할 수 있다. 일 실시예에 따르면, 호스트 선택 절차는 미리 설정된 정보 및/또는 DNS 서버(2320)로 문의한 정보를 이용하여 결정하거나, 또는 DNS 서버(2320)로 문의한 정보 및/또는 사용자에게 문의하여 특정한 MEC 호스트를 선택(또는 설정)하도록 할 수 있다.
동작 2411에서, 프로세서(120)는 MEC 호스트 선택 후 클라이언트 어플리케이션으로 DNS 응답을 전달할 수 있다. 일 실시예에 따르면, 전자 장치(101)의 MSE(530)는 클라이언트 어플리케이션(510)으로 이상의 절차들을 통해 획득한 정보를 DNS 응답(Response)으로 제공할 수 있다. 일 실시예에 따르면, MSE(530)는 MEC 호스트 선택 후, DNS 쿼리를 제공한 클라이언트 어플리케이션(510)으로, DNS 쿼리에 대응하는 DNS 응답(response)을 전달할 수 있다.
동작 2413에서, 프로세서(120)는 선택된 MEC 호스트와 데이터 전송을 수행할 수 있다. 예를 들어, 클라이언트 어플리케이션(510)은 MEC 시스템(405)(예: MEC 서버)에 설치된 MEC 어플리케이션과 어플리케이션 레이어 상에서 데이터 전송을 수행할 수 있다.
도 25는 다양한 실시예들에 따른 디스커버리 절차의 예를 도시하는 도면이다.
도 25에 도시한 바와 같이, 도 25는 DNS 쿼리 기반(DNS Query-based)의 MEC 디스커버리 절차의 예를 나타낼 수 있다. 일 실시예에 따르면, 전자 장치(101)는 클라이언트 어플리케이션(또는 Client App)(510), MSA(또는 서비스 에이전트)(520), MSE(또는 서비스 인에이블러)(530)(예: MEL(531), UHL(533) 포함), 및 DNS 캐시(cache)(2310)를 포함할 수 있다.
도 25를 참조하면, 동작 2501에서, 전자 장치(101)의 MSA(520)는 MSE(530)로 MEC 디스커버리 정책(discovery policy)을 설정할 수 있다. 일 실시예에 따르면, MEC 디스커버리 정책은 클라이언트 어플리케이션 이름(예: clientAppNames)과 디스커버리 정책(예: discoveryPolicy)을 포함하여 제공할 수 있다. 일 실시예에 따라, discoveryPolicy에는 동적 DNN(예: dynamicDnn)의 사용 여부가 포함될 수 있고, 위치(예: locationInfo), 디바이스 타입(예: deviceType), 서비스 타입(예: serviceType), 또는 컨텍스트 타입(예: contextType)과 같은 <표 1>의 정보 중 적어도 하나를 포함하여 제공할 수 있다. 일 실시예에 따르면, MSA(520)는 위치(예: locationInfo), 디바이스 타입(예: deviceType), 서비스 타입(예: serviceType)을 discoveryPolicy에 포함하여 앱 리스트를 해당 조건에 맞는 리스트만 한정하여 수신하도록 할 수도 있다. 일 실시예에 따르면, MSA(520)는 컨텍스트 타입(예: contextType)을 discoveryPolicy에 포함하여 어플리케이션 컨텍스트(application context)가 필요한지 여부에 대한 정보를 포함할 수 있다. 일 실시예에 따르면, MSA(520)는 URI Request Flag를 discoveryPolicy에 포함하여 MEC 어플리케이션의 URI가 가용한 경우 앱 리스트에 URI 포함하도록 요청할 수도 있다.
동작 2503에서, MSE(530)는 MSA(520)로부터 수신된 정보(예: MEC 디스커버리 정책)에 기반하여 앱 리스트(예: AppList)를 획득하기 위한 획득 절차(예: MEC Application Look-up)를 수행할 수 있다. 일 실시예에 따르면, MSA(520)와 MSE(530) 간에 MEC 디스커버리 정책 설정에 따라 앱 리스트를 획득하기 위한 획득 절차(예: MEC Application Look-up)가 시작될 수 있다. 일 실시예에 따르면, MSE(530)는 MSA(520)로부터 MSE API를 통해 MEC 디스커버리 정책을 수신하는 경우 MEC Application Look-up을 활성화 할 수 있고, 전자 장치(101)의 특정 조건(예: 전자 장치(101)가 움직이는 중 접속 기지국 Cell ID 변경) 만족 시 수행(또는 시작)할 수 있다. 일 실시예에 따르면, MSE(530)는 MEC 디스커버리 정책에 따라 서비스 가능한 MEC 어플리케이션(예: MEP App)에 관련된 앱 리스트(예: MEC AppList)를 MMP 서버(430)로 요청하여 수신할 수 있다. 일 실시예에 따르면, MSE(530)는 MEC 디스커버리 정책을 <표 1>에 예시한 바와 같은 MEC AppList request message Parameter에 기입하여 MMP 서버(430)에 요청할 수 있고, MMP 서버(430)는 그에 맞는 서비스 가능 앱 리스트(예: <표 2>의 MEC AppList)를 MSE(530)로 제공하여, MSE(530)의 요청에 응답할 수 있다. 다양한 실시예들에 따른 앱 리스트 획득 절차(예: MEC Application Look-up)에 대하여 후술하는 도면을 참조하여 상세히 설명된다.
동작 2505에서, 클라이언트 어플리케이션(510)은 MSE(530)로 DNS 쿼리(query)를 위한 메시지(예: DNS query 메시지)를 전달할 수 있다.
동작 2507에서, MSE(530)는 클라이언트 어플리케이션(510)으로부터의 DNS 쿼리에 응답하여 MMP 서버(430)와 Application Context Create 동작을 수행할 수 있다. 일 실시예에 따르면, MSE(530)는 클라이언트 어플리케이션(510)에서 DNS query (with FQDN) 메시지 발생 시, FQDN 필터링(filtering)을 통해 MEC 용 FQDN 탐지 시, 해당 MEC 어플리케이션(예: MEC App)에 대한 Application Context Create를 수행할 수 있다. 일 실시예에 따르면, MSE(530)는 접속하고자 하는 MEC 어플리케이션 이름(예: MEC App Name)에 대한 URI를 MMP 서버(430)로 요청 및 수신할 수 있다. 일 실시예에 따라, MSE(530)는 필요에 따라 전용 DNN(dedicated DNN)에 대한 정보를 MMP 서버(430)에 요청 및 수신할 수도 있다. 일 실시예에 따르면, MMP 서버(430)는 해당 MEC 어플리케이션이 없는 경우에는 MEC 어플리케이션 패키지(package) URI를 MSE(530)로 전달할 수도 있다. 다양한 실시예들에 따른 Application Context Create 절차에 대하여 후술하는 도면을 참조하여 상세히 설명된다.
동작 2509에서, MSE(530)는 클라이언트 어플리케이션(510)으로부터의 DNS 쿼리에 응답하여 DNS 서버(2320)와 MEC 호스트를 선택하기 위한 호스트 선택 절차(예: MEC Host Selection)를 수행할 수 있다. 일 실시예에 따르면, MSE(530)는 MMP 서버(430)를 통해 획득한 MEC 호스트(예: 도 4의 MEC 호스트(447))가 적어도 둘 이상인 경우, DNS 서버(2320)와 어느 하나의 MEC 호스트를 선택하기 위한 호스트 선택 절차(예: MEC Host Selection)를 수행할 수 있다. 일 실시예에 따르면, MEC 호스트가 둘 이상인 경우 하나의 MEC 호스트를 선택하기 위한 호스트 선택 절차는 미리 설정된 정보 및/또는 DNS 서버(2320)로 요청하여 수신한 정보(예: IP 주소, IP 별 location 정보)를 이용하여 결정하거나, 또는 DNS 서버(2320)로 요청하여 수신한 정보 및/또는 사용자에게 UI(user interface)(예: 선택 버튼)를 통하여 특정한 MEC 호스트를 선택(또는 설정)하도록 할 수 있다. 일 실시예에 따르면, MSE(530)가, MEC 호스트가 둘 이상인 경우 특정한 MEC 호스트를 설정하기 위한 미리 설정된 정보는 우선순위 정보를 포함할 수 있다. 일 실시예에 따르면, 우선순위 정보는, 예를 들어, 호스트 우선순위가 URI 별로 우선순위가 결정된 정보를 포함하거나, 또는 하나의 URI를 DNS 리졸빙(resolving)한 결과인 IP 주소가 복수개일 경우 해당 IP 주소 별 우선순위가 결정된 정보를 포함할 수 있다. 일 실시예에 따르면, 호스트 선택 절차는 DNS 리졸빙(resolving) 동작과 MEC 호스트 우선순위 결정(MEC Host Prioritization) 동작을 포함할 수 있다. 일 실시예에 따라, DNS resolving는, 예를 들어, 클라이언트 어플리케이션(510)의 DNS 쿼리(query)와 상관 없이 MSE(530) 자체적으로 MEC용 FQDN에 대해 DNS 리졸빙을 수행하는 것을 포함할 수 있다. 일 실시예에 따라, MEC Host Prioritization는, 예를 들어, DNS 쿼리 응답(query response)으로 복수 개의 IP 주소가 수신되는 경우 IP 우선순위를 설정하는 것을 포함할 수 있다. 일 실시예에 따라, 우선순위가 URI 별 또는 IP 별 미리 정해져 있을 수 있으며, 복수 개의 IP 주소가 수신되는 경우에는 수신된 복수의 IP 별 성능(performance) 테스트를 통해 그 결과에 따라 동적으로 IP 우선순위를 결정할 수도 있다. 다양한 실시예들에 따른 호스트 선택 절차(예: MEC Host Selection)에 대하여 후술하는 도면을 참조하여 상세히 설명된다.
동작 2511에서, MSE(530)는 이상의 절차들이 완료되면, 클라이언트 어플리케이션(510)으로 이상의 절차들을 통해 획득한 정보를 DNS 응답(Response)으로 제공할 수 있다. 일 실시예에 따르면, MSE(530)는 MEC 호스트 선택((예: DNS 리졸빙) 후, DNS 쿼리를 제공한 클라이언트 어플리케이션(510)으로, DNS 쿼리에 대응하는 DNS 응답(response)을 전달할 수 있다. 다양한 실시예들에 따른 DNS 응답에 대하여 후술하는 도면을 참조하여 설명된다.
도 26은 다양한 실시예들에 따른 전자 장치(101)에서 디스커버리 절차를 위한 동작 방법을 도시하는 흐름도이다.
다양한 실시예들에서, 도 26에 도시된 동작들은, 예를 들어, 전자 장치(101) 또는 전자 장치(101)에 포함된 구성 요소(예: 도 1의 프로세서(120) 또는 도 4의 MEC 서비스 모듈(410))에 의하여 수행될 수 있다.
도 26을 참조하면, 동작 2601에서, 전자 장치(101)는 디스커버리 정책에 기반하여 MEC 시스템(405)이 제공 가능한 MEC 어플리케이션들에 관한 정보(예: 앱 리스트)를 획득하기 위한 어플리케이션 룩업(Application Look-up) 동작을 수행할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 MMP 서버(430)에 앱 리스트를 요청하고 MMP 서버(430)로부터 앱 리스트를 획득(또는 수신)할 수 있다. 일 실시예에 전자 장치(101)의 MSE(530)는 MSA(520)로부터 MSE API를 통해 MEC 디스커버리 정책을 수신하고, MEC 디스커버리 정책에 기반하여, MMP 서버(430)와 통신하여 서비스 가능한 MEC 어플리케이션의 앱 리스트를 획득할 수 있다.
동작 2603에서, 전자 장치(101)는 컨텍스트 생성에 관련된 지정된 조건을 감지할 수 있다. 일 실시예에 따르면, 지정된 조건은 컨텍스트 생성을 위한 트리거를 나타낼 수 있다. 일 실시예에 따르면, 컨텍스트 생성을 위한 트리거는, 예를 들어, 클라이언트 어플리케이션(510)이 실행되거나, 클라이언트 어플리케이션(510)에 의해 컨텍스트 생성이 요청되거나, 또는 클라이언트 어플리케이션(510)이 DNS 쿼리를 발생하는 것을 포함할 수 있다.
동작 2605에서, 전자 장치(101)는 지정된 조건에 기반하여 MEC 호스트(예: 엣지 서버 또는 MEC 서버)를 확인하기 위한 어플리케이션 컨텍스트 생성 동작을 수행할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 앱 리스트에 기반하여 클라이언트 어플리케이션(510)과 연관되고 접속하고자 하는 MEC 어플리케이션에 관련된 정보를 MMP 서버(430)로부터 획득할 수 있다. MEC 어플리케이션에 관련된 정보는, 예를 들어, MEC 어플리케이션 이름(MEC App Name)에 대한 URI, 전용 DNN(dedicated DNN) 정보, 또는 MEC 어플리케이션 패키지(package) URI(예: MEC 어플리케이션이 없는 경우) 중 적어도 하나를 포함할 수 있다.
일 실시예에 따라, 아래 <표 3>과 <표 4>는 컨텍스트 생성 동작에서 교환되는 컨텍스트 생성 요청 메시지(context create request message)(예: <표 3>)와 컨텍스트 생성 응답 메시지(context create response message)(예: <표 4>)의 예를 나타낼 수 있다.
Name
|
Type
|
Cardinal
|
Description
|
ETSI MEC
Compatible
|
contextId |
String |
0...1 |
Uniquely identifies the application context in the MEC system. Assigned by the MEC system and shall be present other than in a create request. The length of the value shall not exceed 32 characters. |
Y |
associateUeAppId |
String |
1 |
Uniquely identifies the device application.The length of the value shall not exceed 32 characters. |
Y |
callbackReference |
URI |
0...1 |
URI assigned by the device application to receive application lifecycle related notifications. Inclusion in the request implies the client supports the pub/sub-mechanism and is capable of receiving notifications.This endpoint shall be maintained for the lifetime of the application context. |
Y |
appInfo |
Structure(inlined) |
1 |
- |
Y |
>appDId |
String |
0...1 |
Identifier of this MEC application descriptor. It is equivalent to the appDId defined in clause 6.2.1.2 of ETSI GS MEC 010-2 [1]. This attribute shall be globally unique. |
Y |
>appName |
String |
1 |
Name of the MEC application.The length of the value shall not exceed 32 characters. |
Y |
>appProvider |
String |
1 |
Provider of the MEC application.The length of the value shall not exceed 32 characters. |
Y |
>appSoftVersion |
String |
0...1 |
Software version of the MEC application.The length of the value shall not exceed 32 characters. |
Y |
>appDVersion |
String |
1 |
Identifies the version of the application descriptor. It is equivalent to the appDVersion defined in clause 6.2.1.2 of ETSI GS MEC 010-2 [1]. |
Y |
>appDescription |
String |
0...1 |
Human readable description of the MEC application (see note 2). |
Y |
>queriedURI |
URI |
0...1 |
It may be FQDN included in the DNS query of a client Application. |
N |
>appPackage-Source |
URI |
0...1 |
URI of the application package.Included in the request if the application is not one in the ApplicationList. appPackageSource enables on-boarding of the application package into the MEC system. The application package shall comply with the definitions in clause 6.2.1.2 of ETSI GS MEC 010-2 [1].This should be the MEC application package source. |
Y |
deviceLocation |
String |
0...1 |
Current location information of the user device |
N |
NOTE 1: If a value of the attribute is included in the request, the same value shall be included in the response.NOTE 2: The design of the current operation with callback reference assumes no web proxy between the entity that originates the notification and the entity that receives it.NOTE 3: The language support for the application description may be limited. |
<표 3>에 예시한 바와 같이, 다양한 실시예들에 따른 컨텍스트 생성 요청 메시지는, ETSI MEC 규격에서 정의되어 있는 파라미터 외에, 예를 들어, contextId, associatedUeAppId, app information, callbackReferenceURI, appPackageSource, 또는 deviceLocation 중 적어도 하나를 포함할 수 있다. 일 실시예에 따라, “contextId”는 MEC 어플리케이션 식별을 위한 ID를 나타낼 수 있다. 일 실시예에 따라, “associatedUeAppId”는 전자 장치(101)(예: 사용자 단말)를 식별하기 위한 ID를 나타낼 수 있다. 일 실시예에 따라, “app information”는, 예를 들면, appName, appVersion(예: appSoftVersion, appDVersion), appProvider, appDescription를 포함할 수 있다. 일 실시예에 따라, “callbackReferenceURI”는 MMP 서버(430)로부터 notification을 수신하기 위한 전자 장치(101)의 콜백 주소를 나타낼 수 있다. 일 실시예에 따라, “appPackageSource”는 MEC 시스템(405) 상에 관련 MEC 어플리케이션이 없을 경우 MEC 시스템(405)에서 해당 어플리케이션을 다운로드하여 설치할 수 있도록 지원하기 위한 MEC app package의 다운로드 주소를 나타낼 수 있다. 일 실시예에 따라, “deviceLocation”은 전자 장치(101)의 위치 정보(예: 해당 위치 근처의 MEC 호스트(447)에 MEC 어플리케이션을 인스턴스화(instantiation) 하기 위함)를 나타낼 수 있다. 일 실싱예에 따르면, “deviceLocation”은 컨텍스트 생성 시점의 전자 장치(101)의 위치를 제공하기 위한 것으로, MEC 시스템(405)에서는 전자 장치(101)의 위치에 기반하여 근접 MEC 호스트(447)에 MEC 어플리케이션의 컨텍스트 생성을 수행할 수 있다.
다양한 실시예들에 따르면, 컨텍스트 생성 요청 메시지는, “queriedURI”를 포함할 수 있다. 일 실시예에 따라, “queriedURI”는 클라이언트 어플리케이션(510)에서 DNS 쿼리(query)한 URI (FQDN)를 포함할 수 있으며, 이러한 경우, 컨텍스트 생성 응답 메시지에 이에 대응되는 MEC app URI (referenceURI)가 포함될 수 있다. 일 실시예에 따라, referenceURI는 MEC 어플리케이션에 접속하기 위한 FQDN 또는 IP 주소를 포함할 수 있다.
Name
|
Type
|
Cardinal
|
Description
|
ETSI MEC
Compatible
|
contextId |
String |
0...1 |
Uniquely identifies the application context in the MEC system. Assigned by the MEC system and shall be present other than in a create request. The length of the value shall not exceed 32 characters. |
Y |
associateUeAppId |
String |
1 |
Uniquely identifies the device application.The length of the value shall not exceed 32 characters. |
Y |
callbackReference |
URI |
0...1 |
URI assigned by the device application to receive application lifecycle related notifications. Inclusion inthe request implies the client supports the pub/submechanism and is capable of receiving notifications.This endpoint shall be maintained for the lifetime ofthe application context. |
Y |
appInfo |
Structure(inlined) |
1 |
- |
Y |
>appDId |
String |
0...1 |
Identifier of this MEC application descriptor. It is equivalent to the appDId defined in clause 6.2.1.2 of ETSI GS MEC 010-2 [1]. This attribute shall be globally unique. |
Y |
>appName |
String |
1 |
Name of the MEC application.The length of the value shall not exceed 32 characters. |
Y |
>appProvider |
String |
1 |
Provider of the MEC application.The length of the value shall not exceed 32 characters. |
Y |
>appSoftVersion |
String |
0...1 |
Software version of the MEC application.The length of the value shall not exceed 32 characters. |
Y |
>appDVersion |
String |
1 |
Identifies the version of the application descriptor. It is equivalent to the appDVersion defined in clause 6.2.1.2 of ETSI GS MEC 010-2 [1]. |
Y |
>appDescription |
String |
0...1 |
Human readable description of the MEC application (see note 2). |
Y |
>referenceURI |
URI |
0...1 |
Address of the user application.It shall only be included in the response. |
Y |
>clientAppName |
String |
0...N |
Client app name that is allowed to connect to the MEC application. If the MEC application is open to all the client application, this field can be omitted. |
N |
>uriTTL |
uint32 |
0...1 |
Time-to-live of the reference URI |
N |
>uriLOC |
String |
0...1 |
Location (range) where the reference URI is available |
N |
>carpRule |
Structure |
0...1 |
Client App Routing Policy Rules |
N |
>>DNN |
String |
0...1 |
DNN selection for this application |
N |
>>S-NSSAI |
String |
0...1 |
Network slice selection for this application |
N |
>>accessType |
String |
0...1 |
Preferrend access type for this application (e.g., 4G, 5G, WiFi, etc.) |
N |
>>sessionType |
String |
0...1 |
Ipv4, ipv6, etc. |
N |
>>mptcp |
Boolean |
0...1 |
Indicates whether to use MPTCP for the matching application |
N |
NOTE 1: If a value of the attribute is included in the request, the same value shall be included in the response.NOTE 2: The design of the current operation with callback reference assumes no web proxy between the entity that originates the notification and the entity that receives it.NOTE 3: The language support for the application description may be limited. |
<표 4>에 예시한 바와 같이, 다양한 실시예들에 따른 컨텍스트 생성 응답 메시지는, ETSI MEC 규격에서 정의되어 있는 파라미터 외에, 예를 들어, App information, clientAppName, refereceURI, uriTTL, uriLOC, 또는 CARP rule 중 적어도 하나를 포함할 수 있다. 일 실싱예에 따라, “app information”는, 예를 들면, appName, appProvider, appVersion(예: appSoftVersion, appDVersion), appDescription를 포함할 수 있다. 일 실싱예에 따르면, “app information”과 “clientAppName”은 MEC 어플리케이션에 접속이 허용된 클라이언트 앱 리스트를 나타낼 수 있다. 일 실시예에 따라, “refereceURI”는 MEC 어플리케이션 접속 주소를 나타낼 수 있다. 일 실시예에 따라, “uriTTL”은 MEC 어플리케이션 접속 주소 가용 시간을 나타낼 수 있다. 일 실시예에 따라, “uriLOC”는 MEC 어플리케이션 접속 가능 지역 정보를 나타낼 수 있다. 일 실시예에 따라, “CARP rule”은 해당 어플리케이션 접속을 위한 DNN과 같은 경로 정보를 나타낼 수 있다.
동작 2607에서, 전자 장치(101)는 MEC 호스트를 선택하기 위한 MEC 호스트 선택 동작을 수행할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 획득된 MEC 어플리케이션에 관련된 정보에 기반하여, DNS 서버(2320)와 MEC 호스트 선택 동작을 통해 최적 MEC 호스트를 선택할 수 있다. 일 실시예에 따르면, MEC 호스트 위치와 사용자 현재 위치, 사용자 이동(또는 움직임) 속도, 또는 MEC 호스트 성능(performance)(예: RTT(round trip time), throughput) 중 적어도 하나에 기반하여 최적 MEC 호스트를 선택할 수 있다. 예를 들어, 전자 장치(101)는 전자 장치(101)에 가장 가까이 위치하거나, 사전 성능 측정(또는 테스트)(예: ping probing 또는 bandwidth estimation)을 통해 최적의 성능을 가지거나, 또는 클라이언트 어플리케이션(510)과 매칭(또는 요청)되는 최적 MEC 어플리케이션을 포함하는 MEC 호스트를 선택할 수 있다.
동작 2609에서, 전자 장치(101)는 선택된 MEC 호스트와 데이터 전송을 수행할 수 있다. 예를 들어, 전자 장치(101)는 클라이언트 어플리케이션(510)과 선택된 MEC 호스트에 설치된 MEC 어플리케이션과 어플리케이션 레이어 상에서 데이터 전송을 수행할 수 있다.
도 27은 다양한 실시예들에 따른 디스커버리 절차에서 앱 리스트를 획득하는 동작 예를 도시하는 도면이다.
도 27에 도시한 바와 같이, 도 27은 일 실시예에 따른 MEC 디스커버리 절차에서 앱 리스트 생성 및 획득(예: MEC Application Look-up)에 관한 동작 예를 나타낼 수 있다.
도 27을 참조하면, 동작 2701에서, 전자 장치(101)의 MSA(520)는 MSE(530)로 MEC 디스커버리 정책(discovery policy)을 전달할 수 있다. 일 실시예에 따르면, MEC 서비스 모듈(410)은 MSA(520)를 이용하여 MEC 디스커버리 정책을 획득하고, MSE(530)를 이용하여 수신된 MEC 디스커버리 정책에 기반한 디스커버리 절차를 수행할 수 있다. 일 실시예에 따르면, MEC 디스커버리 정책은 클라이언트 어플리케이션 이름(예: clientAppNames), 위치(locationInfo), 디바이스 타입(예: deviceType), 서비스 타입(예: serviceType), 컨텍스트 타입(예: contextType), URI 요청 플래그(예: URI Request), 또는 동적 DNN(예: dynamicDnn) 중 적어도 하나를 포함하여 제공할 수 있다. 일 실시예에 따라, 디스커버리 정책은 <표 1>를 참조한 설명 부분에서 설명한 바와 같은 정보들 중 적어도 하나를 포함할 수 있다.
동작 2703에서, MSE(530)는 MSA(520)로부터 수신된 정보(예: MEC 디스커버리 정책)에 기반하여 앱 리스트(예: AppList)를 획득하기 위한 획득 절차(예: MEC Application Look-up)를 수행할 수 있다. 일 실시예에 따르면, 앱 리스트를 획득하는 동작은 MSA(520)와 MSE(530) 간에 MEC 디스커버리 정책 설정에 따라 시작될 수 있다. 일 실시예에 따르면, 앱 리스트 획득 절차는 MSA(520)에서 MEC 디스커버리 정책 API 호출 시 활성화될 수 있고, MEC 디스커버리 정책에 부합하는 MEC 앱 리스트 및/또는 URI를 MMP 서버(430)로 요청하여 수신할 수 있다. 일 실시예에 따르면, 앱 리스트 획득 절차는, 동작 2710, 동작 2720, 동작 2730을 포함할 수 있다.
동작 2710에서, MSE(530)는 앱 리스트를 요청하는 요청 메시지(예: HTTP Get AppList Request Parameters)를 MMP 서버(430)로 전송할 수 있다. 일 실시예에 따르면, MSE(530)는 MEC 디스커버리 정책을 요청 메시지(예: HTTP Get AppList Request Parameters)에 포함(또는 기입)하여 MMP 서버(430)로 제공할 수 있다. 예를 들어, MSE(530)는 <표 1>에 예시한 바와 같은 앱 리스트 요청 파라미터를 포함하여 MMP 서버(430)로 제공할 수 있다. 예를 들어, 요청 메시지는 <표 1>을 참조한 설명 부분에서 설명한 바와 같은 정보(또는 파라미터) 중 적어도 하나의 정보를 포함할 수 있다.
일 실시예에 따르면, Request Parameter에 지원 가능한 필드(field) 정보는 인증(AA) 단계에서 Authorization Response 내 MMP Info에 정의할 수 있다. 일 실시예에 따르면, 앱 리스트 요청과 관련된 파라미터(또는 정보)(예: AppList Request Parameters)는 요청 메시지(예: HTTP GET)의 파라미터 필드(parameter field)에 포함될 수 있다. 일 실시예에 따르면, 앱 리스트 요청 파라미터는, MSA(520)로부터 전달 받은(예: 동작 2701의 setMecDiscoveryPolicy(clientAppNames, discoveryPolicy)) 어플리케이션 이름(예: clientAppNames), 접속 Cell ID, 트래킹 영역(TA, Tracking Area) ID, 지역 정보(예: 시, 구, 동, 건물), 또는 사용자가 지정한 우선 위치(preferred location) 정보 중 적어도 하나를 포함하는 전자 장치(101)의 위치와 관련된 위치 정보(Location Info), 전자 장치(101)의 종류를 식별할 수 있는 디바이스 타입(Device Type)(예: Smartphone, Tablet, Wearable, IoT, Car, Drone), 서비스의 종류를 식별할 수 있는 서비스 타입(Service Type)(예: Game, V2X, AR/VR, LBO, Enterprise, Web), 컨텍스트 정보의 필요 여부를 식별할 수 있는 컨텍스트 타입(Context Type)(예: MEC 어플리케이션 구동에 사용자 또는 어플리케이션의 컨텍스트(context) 정보가 필요한지 여부), 또는 MEC 어플리케이션의 URI가 활성화 가능(available)한 경우 해당 URI를 응답에 포함하도록 요청하는 플래그(Flag)(예: URI Request Flag) 중 적어도 하나를 포함할 수 있다. 일 실시예에 따라, 컨텍스트 타입은 전자 장치(101)의 서비스 어플리케이션 타입을 식별하기 위한 정보로, 예를 들어, 전자 장치(101)에 설치된 어플리케이션(예: 특정 런처 또는 지정된 어플리케이션), 실행 어플리케이션의 이름, 도메인(domain) 중 적어도 하나를 포함할 수 있다.
일 실시예에 따르면, 전자 장치(101)는 앱 리스트를 요청하는 절차에서, 전자 장치(101)에 설치된 어플리케이션 정보(예: 특정 런처 또는 지정된 어플리케이션)를 MMP 서버(430)로 전달할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 전자 장치(101)에 설치된 어플리케이션 정보의 변경(예: 업데이트)이 있는 경우, MMP 서버(430)에 앱 리스트를 요청하는 절차에서, 전자 장치(101)에 설치된 어플리케이션 정보를 전달할 수도 있다.
동작 2720에서, MMP 서버(430)는 MSE(530)로부터 수신된 요청 메시지에 대응하는 응답으로 앱 리스트(예: MEC AppList)를 포함하는 응답 메시지(예: HTTP 200 OK AppList response Data)를 MSE(530)로 제공할 수 있다. 일 실시예에 따르면, MMP 서버(430)는 수신된 클라이언트 어플리케이션 이름에 기반하여 MEC 어플리케이션을 검색하고, 검색된 MEC 어플리케이션을 포함하는 앱 리스트를 응답 메시지에 포함하여 MSE(530)로 제공할 수 있다.
일 실시예에 따르면, 앱 리스트 응답과 관련된 데이터(또는 정보)(예: AppList Response Data)는 응답 메시지(예: HTTP 200 OK)의 메시지 바디(message body)에 포함될 수 있다. 일 실시예에 따라, 응답 메시지는 <표 2>를 참조한 설명 부분에서 설명한 바와 같은 정보들 중 적어도 하나를 포함할 수 있다.
일 실시예에 따르면, MMP 서버(430)는 앱 리스트를 제공할 때, 가용한 전체 MEC App List 또는 Request Parameters 중 적어도 하나에 기반하여 서비스 가능한 MEC App List를 제공할 수 있다. 일 실시예에 따르면, 클라이언트 어플리케이션(Client App) 별 접속 가능한 MEC App Name을 포함할 수 있으며, MEC App Name은 이후 Application Context Create 동작에서 사용(또는 필요)할 수 있다.
일 실시예에 따르면, MMP 서버(430)는 오퍼레이터의 위치 API(Operator’s Location API)가 가용한 경우 알림을 앱 리스트에 포함하여 제공할 수 있다. 일 실시예에 따르면, MMP 서버(430)는 요청 메시지에서, URI Request Flag가 true이고, 전자 장치(101)(예: 사용자 단말) 근처의 가용 MEC 호스트에 해당 MEC App이 실행 중일 경우, 해당 MEC App의 URI를 앱 리스트에 포함하여 제공할 수 있다. 일 실시예에 따르면, MMP 서버(430)는 요청 메시지에서, URI 요청 플래그(URI Request Flag)가 없는 경우에서도, MEC 호스트에 해당 MEC App이 실행 중일 경우, 해당 MEC App의 URI를 앱 리스트에 포함하여 제공할 수도 있다. 일 실시예에 따르면, MMP 서버(430)는 전자 장치(101)로부터 앱 리스트 요청 수신 시, 요청 메시지에서, 컨텍스트 타입에 따라 MEC App이 바로 구동이 가능한 경우 MEC App을 구동한 후 해당 URI를 앱 리스트에 포함하여 제공할 수 있다. 일 실시예에 따르면, MMP 서버(430)는 URI의 유효시간/유효 장소 정보를 앱 리스트에 더 포함하여 제공할 수 있다. 일 실시예에 다르면, URI의 유효시간에 대한 정보는 전자 장치(101)가 결정할 수도 있고, 또는 MMP 서버(430)에서 MEC App 구동 상태에 따라 가변적으로 결정할 수 있다. 일 실시예에 따르면, MMP 서버(430)는 어플리케이션 별 전용 DNN 규칙이 존재하는 경우, 해당 규칙을 제공할 수도 있다.
일 실시예에 따르면, 앱 리스트에 포함된 URI는 하이퍼링크 및/또는 하이라이트 되어 구분될 수 있고, 전자 장치(101)는 앱 리스트에서, URI를 포함하지 않는 MEC App과 하이퍼링크 및/또는 하이라이트에 기반하여 구분하여 표시할 수 있다. 다른 실시예에 따르면, 전자 장치(101)는 앱 리스트에서, URI를 포함하는 MEC App과 URI를 포함하지 않은 MEC App을 구분하지 않고 동일하게 표시할 수도 있다. 일 실시예에 따르면, 전자 장치(101)는 앱 리스트에서, 어플리케이션 별 서비스 가능한 위치 및/또는 시간 정보를 포함하여 제공할 수도 있다.
일 실시예에 따르면, MMP 서버(430)는 앱 리스트를 응답하는 절차에서, 어플리케이션 단위로 DNN 설정이 가능한 경우, 앱 리스트에 어플리케이션 별(또는 앱 별) 사용 DNN 정보를 포함할 수 있다. 일 실시예에 따라, 해당 DNN 서버는, 인증(AA) 정차에서 수신된 DNN 리스트에 포함된 DNN일 수 있다.
일 실시예에 따르면, 전자 장치(101)는 MMP 서버(430)에 앱 리스트를 요청하고, 그에 대한 응답을 수신하는 절차에서, 앱 리스트 및 앱 리스트의 해당 어플리케이션(들)에 대한 MEC 호스트(예: 엣지 서버 또는 MEC 서버)에 대한 정보(예: URI)를 획득(또는 수신)할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 MEC 호스트에 대한 정보(예: URI)를 수신하지 않은 경우, 예를 들어, 해당 앱에 대해, Application Context Create 절차를 더 수행하여, 해당 어플리케이션에 대한 MEC 호스트의 정보(예: URI)를 외부 서버로부터 획득할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 MEC 호스트에 대한 정보(예: URI)를 수신한 경우, 예를 들어, 해당 어플리케이션에 대해, Application Context Create 절차를 수행하지 않고, 바로 해당 MEC 호스트(예: URI를 사용하여)로 접속을 수행할 수 있다.
일 실시예에 따르면, 전자 장치(101)는 MMP 서버(430)에 앱 리스트를 요청하고, 그에 대한 응답을 수신하는 절차에서, 앱 리스트 및 앱 리스트의 해당 어플리케이션(들)에 대한 지정된 네트워킹 경로에 대한 정보(예: DNN)를 수신할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 지정된 네트워킹 경로에 대한 정보(예: DNN)를 수신한 경우, 네트워크와 지정된 네트워킹 경로를 설정하는 절차를 수행할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 DNN 정보를 수신한 어플리케이션들에 대해서만 지정된(또는 전용) DNN(dedicated DNN)으로 통신하도록 DNN 경로를 설정할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 MEC 호스트에 컨텍스트를 생성 요청하는 절차(예: Application Context Create)에서, DNN 정보를 수신한 어플리케이션들에 대해 지정된 DNN 경로를 설정할 수 있다.
동작 2730에서, MSE(230)는 정책 업데이트를 수행할 수 있다. 일 실시예에 따르면, MSE(530)는 앱 리스트를 획득하는 동작(동작 2703)에서, 추가적으로(또는 선택적으로) 정책 업데이트 동작을 포함할 수 있다. 일 실시예에 따르면, MSE(530)는 전용 PDU 세션(dedicated PDU session) 필요 시(또는 새로운 전용 DNN 규칙이 설정된 경우) URSP 규칙(예: DNN)을 수신하고, URSP 규칙에 따라 어플리케이션 별 또는 URI 별 별도 PDU 세션을 설정 및 사용하도록 할 수 있다. 예를 들어, URSP 규칙(또는 CARP 규칙)은 인증 절차의 결과(예: MSA(520)가 수신하여 MSE(530)에 전달), 또는 MSE(530)가 어플리케이션 룩업(예: App lookup) 결과, 또는 컨텍스트 생성(Context Create) 결과로 수신할 수 있으며, URSP 규칙에 새로운 DNN 규칙이 설정되어 있는 경우, PDU 세션 설정(setup)을 수행할 수 있다. 일 실시예에 따르면, PDU 세션 설정(예: 도 17의 PDU 세션 생성, 도 18의 PDU 세션 해제)은 전술한 도 17 또는 도 18을 참조한 설명 부분에서 설명한 바와 같이 MSE(530)가 모뎀(1700)에 요청하면, 모뎀(1700)에서 5G 망(또는 코어 망)의 SMF에 요청하여 생성/해제할 수 있다.
도 28은 다양한 실시예들에 따른 앱 리스트가 제공되는 예를 설명하기 위한 도면이다.
도 28에 도시한 바와 같이, 도 28은 위치 기반 서비스 영역(Location-based Service Area)의 을 예시할 수 있다.
도 28을 참조하면, 일 실시예에 따라, MMP 서버(430)는 제1 서버(Server 1)(2810)(또는 사용자 인접의 제1 MEC 호스트)(예: 도 4의 MEC 호스트(447))로부터 가능한 어플리케이션(Available Apps)에 대한 제1 정보(예: A(+URI), B, C)를 획득하는 것을 가정할 수 있다. 일 실시예에 따라, MMP 서버(430)는 제2 서버(Server 2)(2820)(또는 사용자 인접의 제2 MEC 호스트)(예: 도 4의 MEC 호스트(447))로부터 가능한 어플리케이션에 대한 제2 정보(예: A(+URI), C(+URI), D)를 획득하는 것을 가정할 수 있다.
다양한 실시예들에 따르면, MMP 서버(430)는 제1 서버(2810)와 제2 서버(2820)로부터 획득한 각각의 어플리케이션에 대한 정보들(예: 제1 정보, 제2 정보)을 취합하여, 예를 들어, A(+URI), B, C(+URI), D의 정보를 생성(또는 획득)할 수 있다. 일 실시예에 따르면, MMP 서버(430)는 제1 서버(2810)와 제2 서버(2820)로부터 생성된 A(+URI), B, C(+URI), D를 포함하여 앱 리스트를 생성하고, 생성된 앱 리스트를 사용자(2830)(예: 전자 장치(101))에 제공할 수 있다.
도 29는 다양한 실시예들에 따른 어플리케이션의 라이프 사이클(2900)을 도시하는 도면이다.
다양한 실시예들에 따르면, 전자 장치(101)에 설치된 어플리케이션은 사용자 입력 또는 프로세서(예: 도 1의 프로세서(120))의 명령에 의하여 상태(state)가 변경될 수 있다.
도 29를 참조하면, 어플리케이션(예: 클라이언트 어플리케이션(510))의 라이프 사이클(2900)은, 예를 들어, 어플리케이션의 상태가 시작 상태(launch)(2905), 실행(running) 상태(2910), 중지(paused) 상태(2915), 종료(shut down) 상태(2920), 또는 강제 종료(killed) 상태(2925)로 변경되는 일련의 주기(cycle)를 의미할 수 있다.
일 실시예에 따르면, 전자 장치(101)에 설치된 어플리케이션은 사용자 입력 또는 미리 설정된 조건에 의하여 시작 상태가 될 수 있다. 어플리케이션은 어플리케이션과 관련된 화면이 사용자에게 보여지는 실행 상태(또는 포어그라운드(foreground) 상태)가 되거나, 어플리케이션이 전자 장치(101)의 프로세서(120)(예: 어플리케이션 프로세서(AP))에 의하여 실행(executed) 중이지만 어플리케이션과 관련된 화면이 사용자에게 보여지지 않는 정지(pause) 상태(또는 백그라운드(background) 상태)가 될 수도 있다. 또한, 어플리케이션은 사용자 입력에 의하여 종료(shut down) 상태가 되거나, 메모리 부족으로 인하여 강제 종료(killed) 상태가 될 수 있다.
일 실시예에 따르면, MEC 시스템(405)은 어플리케이션의 상태에 따라서 MEC에 기반한 데이터 전송을 수행하므로, 라이프 사이클이 동기화되지 않으면, MEC 시스템(405)은 자원을 낭비할 수 있다. 일 실시예에 따르면, MSE(230)는 어플리케이션들(310-1, 310-2, …)의 사용 여부를 MMP 서버(430)로 통지할 수 있다. 일 실시예에 따라, 어플리케이션들(예: 310-1, 310-2, …)이 사용 중일 때만 MEC 어플리케이션들(예: 460-1, 460-2, …)이 동작(예: 데이터 전송)을 수행하고, 어플리케이션들(예: 310-1, 310-2, …)이 미사용 중(예: screen off, 클라이언트 어플리케이션 백그라운드(background) 상태 변경, 사용자 이동 속도가 일정 이상 중 적어도 하나 만족)일 때에는 MEC 어플리케이션들(460-1, 460-2, …)이 동작(예: 데이터 전송)을 중지할 수 있다. 일 실시예에 따르면, MSE(530)가 상기와 같이 어플리케이션들(310-1, 310-2, …)의 사용 여부를 MMP 서버(430)에 알려줌으로써, MEC 호스트(447)(또는 엣지 서버(305))의 자원을 효율적으로 관리하도록 할 수 있다. 일 실시예에 따라, 미사용 중인 어플리케이션에 대해서는 MEC 어플리케이션의 자원 할당을 해제하여 MEC 호스트(447)의 자원 소모를 줄일 수 있다. 다양한 실시예들에 따르면, MEC 서비스 모듈(410)(예: MSE(530))에서 어플리케이션(예: 전자 장치(101)의 클라이언트 어플리케이션(예: 310-1, 310-2, …)과 MEC 호스트(447)의 MEC 어플리케이션(예; 460-1, 460-2, …)의 라이프 사이클을 실시간으로 모니터링하고, 모니터링 된 라이프 사이클을 MEC 시스템(505)(예: MMP 서버(430)(또는 LCM 프록시 서버))에게 알려줌으로써 불필요한 자원 소모를 줄일 수 있다.
일 실시예에 따르면, 복수의 어플리케이션들 중에서 라이프 사이클 동기화를 요구하는 어플리케이션과 그렇지 않은 어플리케이션이 존재할 수 있다. 예를 들어, 영상 감시(video surveillance)와 관련된 어플리케이션의 경우, MEC 시스템(405)에 포함되는 MEC 어플리케이션(예: 460-1 또는 460-2)은 전자 장치(101)의 카메라 모듈(예: 도 1의 카메라 모듈(180))에 의하여 획득된 영상 데이터를 분석하고 전자 장치(101)의 요청에 한하여 분석 결과를 전송하므로, 전자 장치(101)와 MEC 어플리케이션 간 라이프 사이클 동기화가 요구되지 않을 수 있다. 다른 예를 들어, 증강 현실(augmented reality) 어플리케이션의 경우, MEC 어플리케이션이 카메라 모듈(180)에 의하여 획득된 영상을 실시간으로 분석하고, 분석된 영상과 관련된 서비스를 전자 장치(101)에게 제공하므로, 전자 장치(101)와 MEC 어플리케이션 간 라이프 사이클 동기화가 요구될 수 있다.
일 실시예에 따르면, 어플리케이션(310-1 또는 310-2)의 라이프 사이클이 변경되면, MEC 서비스 모듈(410)(예: MSE(530))는 라이프 사이클의 변경을 MEC 시스템(405)에게 요청할 수 있다. 예를 들어, MEC 서비스 모듈(410)은 MEC 어플리케이션의 컨텍스트 생성(context create), 컨텍스트 삭제(context delete), 연기(suspend), 또는 재개(resume) 중 적어도 하나를 요청할 수 있다.
도 30은 다양한 실시예들에 따른 디스커버리 절차에서 컨텍스트 생성 절차의 예를 도시하는 도면이다.
도 30에 도시한 바와 같이, 도 30은 일 실시예에 따른 MEC 디스커버리 절차에서 어플리케이션 컨텍스트 생성(예: Application Context Create)에 관한 동작 예를 나타낼 수 있다. 일 실시예에 따라, 어플리케이션 컨텍스트 생성 절차는, 예를 들면, 클라이언트 어플리케이션(510)이 실행되는 경우, MSA(520)가 해당 클라이언트 어플리케이션에 관련된 정보(예: 패키지 이름 또는 UID)와 함께 어플리케이션 시작 정보를 MSE API를 통해 MSE(530)에 전달하는 것으로부터 수행될 수 있다. 다양한 실시예들에 따르면, 어플리케이션 컨텍스트 생성은, 앱 리스트 상의 어플리케이션이 실행(launch)되거나(제1 케이스), 어플리케이션이 MSE API를 통해 컨텍스트 생성(contextcreate)을 요청(예: context create API 호출)하거나(제2 케이스), 또는 어플리케이션에서 DNS 쿼리 전송 시 미리 수신한 앱 리스트에 포함된 어플리케이션 이름 및/또는 URI(예: FQDN)와 매칭이 되는 경우(제3 케이스)에 수행할 수 있다. 일 실시예에 따르면, 어플리케이션 컨텍스트 생성은, 예를 들어, MEC 디스커버리 정책(예: setDiscoveryPolicy(discoveryPolicy))을 통해 전달된 위치 정보 또는 어플리케이션 룩업 응답을 통해 전달된 앱 리스트에 포함된 어플리케이션 별 가용 위치(예: uriLOC)가 현재 사용자(또는 전자 장치(101))의 위치와 매칭되는 경우(예: 제4 케이스)에도 수행할 수 있다. 다양한 실시예들에 따르면, 제1 케이스, 제2 케이스, 제3 케이스, 또는 제4 케이스에 따른 조건 중 적어도 하나가 만족할 때 어플리케이션 컨텍스트 생성을 수행할 수 있다. 도 30에서는 제1 케이스에 따라 어플리케이션 컨텍스트 생성을 수행하는 동작 예를 나타낼 수 있다.
도 30을 참조하면, 동작 3001에서, 특정 클라이언트 어플리케이션(510)이 실행되는(launched) 경우, 해당 클라이언트 어플리케이션(510)은 어플리케이션의 실행을 알리는 정보(예: App Launched)를 MSA(520)로 제공할 수 있다. 일 실시예에 따르면, 동작 3001은 수행하지 않을 수도 있다. 예를 들어, 클라이언트 어플리케이션(510)이 실행되는 경우, 클라이언트 어플리케이션(510)에 의한 실행을 알리는 동작 없이, MSA(520)(예: Framework level)에서 자체적으로 클라이언트 어플리케이션(510)의 실행을 감지할 수 있다.
동작 3003에서, MSA(520)는 클라이언트 어플리케이션(510)의 실행을 알리는 정보(예: App Launched)를 수신하면, 클라이언트 어플리케이션(510)의 상태(state)를 통지(notify)하는 통지 메시지(예: notifyClientAppState)를 MSE(530)로 제공할 수 있다. 일 실시예에 따라, 통지 메시지(예: notifyClientAppState)는, 예를 들어, 클라이언트 어플리케이션의 상태(예: START)와 클라이언트 어플리케이션의 이름(예: clientAppName)(및/또는 UID)을 포함(예: notifyClientAppState(START, clientAppName))하여 제공할 수 있다.
동작 3005에서, MSE(530)는 MSA(520)로부터 통지 메시지(예: notifyClientAppState)를 수신하고, 수신된 통지 메시지의 정보에 기반하여 어플리케이션 컨텍스트 생성 절차를 수행할 수 있다. 일 실시예에 따르면, 어플리케이션 컨텍스트 생성 절차(동작 3005)는, 동작 3010, 동작 3020, 동작 3030을 포함할 수 있다.
동작 3010에서, MSE(530)는 어플리케이션 컨텍스트 생성을 요청하는 요청 메시지(예: HTTP POST AppContext Data)를 MMP 서버(430)로 전송할 수 있다. 일 실시예에 따르면, MSE(530)는 MEC 어플리케이션 컨텍스트 생성이 필요한 경우(예: 앱 리스트에 URI가 없는 경우), URI를 요청하는 요청 메시지를 MMP 서버(430)로 전송할 수 있다. 일 실시예에 따르면, MSE(530)는 MMP 서버(430)에 MEC 어플리케이션이 있을 경우 MEC 어플리케이션 이름(MEC App Name)을 요청 메시지에 포함하여 MMP 서버(430)로 전송할 수 있다. 다른 실시예에 따르면, MSE(530)는 MMP 서버(430)에 MEC 어플리케이션이 없을 경우 해당 MEC 어플리케이션을 다운로드 할 수 있는 URI(예: 어플리케이션 패키지 다운로드 URI(App package download URI)만을 요청 메시지에 포함하여 MMP 서버(430)로 전송할 수 있다.
동작 3020에서, MMP 서버(430)는 MSE(530)로부터 수신된 요청 메시지에 대응하는 응답으로 MEC 어플리케이션의 URI를 포함하는 응답 메시지(예: HTTP OK 200 Response AppContext Data)를 MSE(530)로 제공할 수 있다. 일 실시예에 따르면, 응답 메시지는 해당하는 어플리케이션(예: MEC 어플리케이션)의 URI(FQDN)를 포함할 수 있다. 일 실시예에 따르면, 응답 메시지는 MEC 어플리케이션의 URI 및 해당 URI의 유효 시간 및/또는 유효 위치에 관한 정보를 포함할 수 있다. 일 실시예에 따르면, MSE(530)는 유효 시간 초과 또는 유효 위치 변경 시, 어플리케이션 컨텍스트 재수행 또는 핸드오버 트리거링(handover triggering)이 수행될 수 있다. 일 실시예에 따르면, 응답 메시지는 DNN 정보를 포함할 수 있다.
동작 3030에서, MSE(530)는 정책 업데이트를 수행할 수 있다. 일 실시예에 따르면, MSE(530)는 어플리케이션 컨텍스트 생성 절차(동작 3005)에서, 추가적으로(또는 선택적으로) 정책 업데이트 동작을 포함할 수 있다. 일 실시예에 따르면, MSE(530)는 전용 PDU 세션(dedicated PDU session) 필요 시(또는 새로운 전용 DNN 규칙이 설정된 경우) URSP 규칙(예: DNN)을 수신하고, URSP 규칙에 따라 어플리케이션 별 또는 URI 별 PDU 세션을 설정할 수 있다. 예를 들어, URSP 규칙(또는 CARP 규칙)은 인증 절차의 결과(예: MSA(520)가 수신하여 MSE(530)에 전달), 또는 MSE(530)가 어플리케이션 룩업(예: App lookup) 결과, 또는 컨텍스트 생성(Context Create) 결과로 수신할 수 있으며, URSP 규칙에 새로운 DNN 규칙이 설정되어 있는 경우, PDU 세션 설정(setup)을 수행할 수 있다. 일 실시예에 따르면, PDU 세션 설정(예: 도 17의 PDU 세션 생성, 도 18의 PDU 세션 해제)은 전술한 도 17 또는 도 18을 참조한 설명 부분에서 설명한 바와 같이 MSE(530)가 모뎀(1700)에 요청하면, 모뎀(1700)에서 5G 망(또는 코어 망)의 SMF에 요청하여 생성/해제할 수 있다.
다양한 실시예들에 따르면, 어플리케이션 컨텍스트 생성 절차(동작 3005)는, 예를 들어, 클라이언트 어플리케이션(510)이 접속해야 할 MEC 어플리케이션이 이미 구동 중이고, 앱 리스트 획득 절차(예: MEC Application Look-up)에서 URI가 수신된 경우에는 생략할 수도 있다.
도 31은 다양한 실시예들에 따른 디스커버리 절차에서 컨텍스트 생성 동작의 예를 도시하는 도면이다.
도 31에 도시한 바와 같이, 도 31은 일 실시예에 따른 MEC 디스커버리 절차에서 어플리케이션 컨텍스트 생성(예: Application Context Create)에 관한 동작 예를 나타낼 수 있다. 일 실시예에 따라, 어플리케이션 컨텍스트 생성 동작은, 예를 들면, 클라이언트 어플리케이션(510)이 컨텍스트 생성 요청을 MSE API를 통해 MSE(530)에 전달하는 것으로부터 수행될 수 있다. 다양한 실시예들에 따르면, 어플리케이션 컨텍스트 생성은, 앱 리스트 상의 어플리케이션이 실행(launch)되거나(제1 케이스), 어플리케이션이 MSE API를 통해 컨텍스트 생성(contextcreate)을 요청(예: context create API 호출)하거나(제2 케이스), 또는 어플리케이션에서 DNS 쿼리 전송 시 미리 수신한 앱 리스트에 포함된 어플리케이션 이름 및/또는 URI(예: FQDN)와 매칭이 되는 경우(제3 케이스)에 수행할 수 있다. 일 실시예에 따르면, 어플리케이션 컨텍스트 생성은, 예를 들어, MEC 디스커버리 정책(예: setDiscoveryPolicy(discoveryPolicy))을 통해 전달된 위치 정보 또는 어플리케이션 룩업 응답을 통해 전달된 앱 리스트에 포함된 어플리케이션 별 가용 위치(예: uriLOC)가 현재 사용자(또는 전자 장치(101))의 위치와 매칭되는 경우(예: 제4 케이스)에도 수행할 수 있다. 다양한 실시예들에 따르면, 제1 케이스, 제2 케이스, 제3 케이스, 또는 제4 케이스에 따른 조건 중 적어도 하나가 만족할 때 어플리케이션 컨텍스트 생성을 수행할 수 있다. 도 31에서는 제2 케이스에 따라 어플리케이션 컨텍스트 생성을 수행하는 동작 예를 나타낼 수 있다.
도 31을 참조하면, 동작 3101에서, 클라이언트 어플리케이션(510)은 MSE(530)로 컨텍스트 생성을 위한 메시지(예: contextCreate)를 전달할 수 있다. 일 실시예에 따르면, 클라이언트 어플리케이션(510)은 컨텍스트 생성이 필요한 경우, 해당 클라이언트 어플리케이션에 관련된 정보(예: 어플리케이션 이름(appName) 또는 UID)와 함께 컨텍스트 생성 요청을 MSE API를 통해 MSE(530)로 전달할 수 있다.
동작 3103에서, MSE(530)는 클라이언트 어플리케이션(510)으로부터 컨텍스트 생성을 위한 메시지를 수신하고, 수신된 메시지의 정보(예: 어플리케이션 이름)에 기반하여 어플리케이션 컨텍스트 생성 동작을 수행할 수 있다. 일 실시예에 따르면, 어플리케이션 컨텍스트 생성 동작(동작 3103)은, 동작 3110, 동작 3120, 동작 3130을 포함할 수 있다. 일 실시예에 따르면, 어플리케이션 컨텍스트 생성 동작(동작 3103)은, 전술한 도 30에서 동작 3005의 어플리케이션 컨텍스트 생성 동작에 따른 동작 3010, 동작 3020, 동작 3030를 참조한 설명 부분에서 설명한 바에 각각 대응할 수 있다.
도 32는 다양한 실시예들에 따른 디스커버리 절차에서 컨텍스트 생성 동작의 예를 도시하는 도면이다.
도 32에 도시한 바와 같이, 도 32는 일 실시예에 따른 MEC 디스커버리 절차에서 어플리케이션 컨텍스트 생성(예: Application Context Create)에 관한 동작 예를 나타낼 수 있다. 일 실시예에 따라, 어플리케이션 컨텍스트 생성 동작은, 예를 들면, 클라이언트 어플리케이션(510)이 DNS 쿼리를 MSE(530)에 전달하는 것으로부터 수행될 수 있다. 다양한 실시예들에 따르면, 어플리케이션 컨텍스트 생성은, 앱 리스트 상의 어플리케이션이 실행(launch)되거나(제1 케이스), 어플리케이션이 MSE API를 통해 컨텍스트 생성(contextcreate)을 요청(예: context create API 호출)하거나(제2 케이스), 또는 어플리케이션에서 DNS 쿼리 전송 시 미리 수신한 앱 리스트에 포함된 어플리케이션 이름 및/또는 URI(FQDN)와 매칭이 되는 경우(제3 케이스)에 수행할 수 있다. 일 실시예에 따르면, 어플리케이션 컨텍스트 생성은, 예를 들어, MEC 디스커버리 정책(예: setDiscoveryPolicy(discoveryPolicy))을 통해 전달된 위치 정보 또는 어플리케이션 룩업 응답을 통해 전달된 앱 리스트에 포함된 어플리케이션 별 가용 위치(예: uriLOC)가 현재 사용자(또는 전자 장치(101))의 위치와 매칭되는 경우(예: 제4 케이스)에도 수행할 수 있다. 다양한 실시예들에 따르면, 제1 케이스, 제2 케이스, 제3 케이스, 또는 제4 케이스에 따른 조건 중 적어도 하나가 만족할 때 어플리케이션 컨텍스트 생성을 수행할 수 있다. 도 32에서는 제3 케이스에 따라 어플리케이션 컨텍스트 생성을 수행하는 동작 예를 나타낼 수 있다.
도 32를 참조하면, 동작 3201에서, 클라이언트 어플리케이션(510)은 MSE(530)로 DNS 쿼리(query)를 위한 메시지(예: DNS Query)를 전달할 수 있다.
동작 3203에서, MSE(530)는 클라이언트 어플리케이션(510)으로부터 DNS 쿼리를 수신하고, DNS 쿼리가 미리 수신한 앱 리스트에 포함된 어플리케이션 또는 URI와 매칭이 되는 경우 어플리케이션 컨텍스트 생성 동작을 수행할 수 있다. 일 실시예에 따르면, 어플리케이션 컨텍스트 생성 동작(동작 3203)은, 동작 3210, 동작 3220, 동작 3230을 포함할 수 있다. 일 실시예에 따르면, 어플리케이션 컨텍스트 생성 동작(동작 3203)은, 전술한 도 30에서 동작 3005의 어플리케이션 컨텍스트 생성 동작에 따른 동작 3010, 동작 3020, 동작 3030를 참조한 설명 부분에서 설명한 바에 각각 대응할 수 있다.
다양한 실시예들에서, 도시하지는 않았으나, 다양한 실시예들에 따른 어플리케이션 컨텍스트 생성 동작은, 예를 들어, MEC 디스커버리 정책(예: setDiscoveryPolicy(discoveryPolicy))을 통해 전달된 위치 정보 또는 어플리케이션 룩업 응답을 통해 전달된 앱 리스트에 포함된 어플리케이션 별 가용 위치(예: uriLOC)가 현재 사용자(또는 전자 장치(101))의 위치와 매칭되는 경우에도 수행할 수 있다.
도 33은 다양한 실시예들에 따른 디스커버리 절차에서 MEC 호스트 선택 절차의 예를 도시하는 도면이다.
도 33에 도시한 바와 같이, 도 33은 MSE(530)가 DNS 서버(2320)와 MEC 호스트를 선택하기 위한 MEC 호스트 선택 동작(MEC Host selection)(3301)을 나타낼 수 있다. 일 실시예에 따르면, MEC 호스트 선택 동작(동작 3301)은, DNS (pre)resolving 동작(예: 동작 3310), MEC Host Prioritization 동작(예: 동작 3320), DNS 캐싱(caching) 동작(예: 동작 3330)을 포함할 수 있다.
도 33을 참조하면, 동작 3310에서, MSE(530)는 DNS 리졸빙(resolving 또는 pre-resolving)을 수행할 수 있다. 일 실시예에 따르면, DNS 리졸빙은, 예를 들어, 클라이언트 어플리케이션(510)의 DNS 쿼리(query)와 상관 없이 MSE(530) 자체적으로 MEC용 FQDN에 대해 DNS 리졸빙 할 수 있다. 일 실시예에 따라, DNS 리졸빙(동작 3310)은, 동작 3311과 동작 3313을 포함할 수 있다.
일 실시예에 따라, 동작 3311에서, MSE(530)는 DHL(535)에 의한 DNS 리졸빙 동작을 수행할 수 있다. 일 실시예에 따르면, MSE(530)는 MEC 어플리케이션에 대한 URI(FQDN)로 DNS 쿼리를 DNS 서버(2320)에 전송할 수 있다.
일 실시예에 따라, 동작 3313에서, DNS 서버(2320)는 MSE(530)로부터 DNS 쿼리를 수신하고, DNS 쿼리에 대응하는 응답으로, DNS 응답을 MSE(530)에 전송할 수 있다. 일 실시예에 따르면, DNS 응답은 MEC 호스트에 관련된 적어도 하나의 주소 정보(예: URI 또는 IP 주소)를 포함할 수 있다.
동작 3320에서, MSE(530)는 MEC 호스트 우선순위 결정(MEC Host Prioritization) 동작을 수행할 수 있다. 일 실시예에 따르면, MEC Host Prioritization는, 예를 들어, DNS 쿼리 응답(query response)으로 복수 개의 IP 주소가 수신되는 경우 IP 우선 순위(prioritization)를 설정하는 것을 포함할 수 있다. 예를 들면, MSE(530)는 MEC 호스트에 대한 우선 순위를 설정할 수 있다.
일 실시예에 따르면, MSE(530)는 MMP 서버(430)로부터 복수 개의 MEC 호스트에 대한 후보 IP 리스트(candidate IP list)를 획득(또는 수신)할 수 있고, 후보 IP 리스트의 추가 정보(예: MEC 호스트 위치 사용자 현재 위치, 사용자 속도, 또는 MEC 호스트 성능(performance)(예: RTT(round trip time), throughput) 중 적어도 하나)로부터 MEC 호스트 후보 IP 및 리모트(remote) 서버(예: 도 3의 리모트 서버(306)) IP 주소 중 접속 IP 선택 또는 우선 순위를 지정할 수 있다. 일 실시예에 따르면, 후보 IP 리스트 중 접속 IP 선택 시, MEC 호스트 IP 또는 리모트 서버의 IP 중 어느 하나를 선택할 수 있다. 예를 들어, 사용자 위치로부터 모든 MEC 호스트 위치가 일정 거리 이상이거나, RTT 값이 일정 값 이상이거나, 또는 사용자 움직임 속도가 일정 값 이상일 경우, MEC 호스트 IP를 선택하지 않고 리모트 서버 IP를 선택할 수 있다. 일 실시예에 따르면, MSE(530)(예: MEL(531))는 복수의 후보 MEC 호스트에 대해 사전 성능 측정(또는 테스트)(예: ping probing 또는 bandwidth estimation)을 통해 최적의 MEC 호스트를 선택할 수 있다. 일 실시예에 따르면, DNS 서버(2320)는 DNS 응답(DNS response) 메시지에 MEC 호스트의 IP 주소와 함께, 해당 MEC 호스트의 위치 정보(location information)를 기록(record)할 수 있다. 예를 들어, MSE(530)는 DNS 리졸빙 시 DNS 쿼리(query) 후 수신한 DNS 응답 메시지 내 DNS 타입 중 위치 기록 타입(예: LOC record type)에 대해 MEC 호스트의 위치 정보가 포함되어 있을 경우, 해당 위치 정보를 이용하여 인접 MEC 호스트를 선택할 수도 있다. 일 실시예에 따르면, MSE(530)는 MEC 호스트의 IP 주소를 획득하는 DNS 쿼리 동작에서 DNS 서버(2320)로부터 MEC 호스트의 위치 정보(예: 위도, 경도, 서빙 셀 ID, 도시 정보, 또는 ID)를 획득할 수 있다. 예를 들어, DNS 타입 필드에 MEC 호스트의 위치 정보가 포함될 수 있다.
동작 3330에서, MSE(530)는 DNS 캐시(2310)로 DNS 캐싱(caching)을 수행할 수 있다. 일 실시예에 따르면, MSE(530)는 DNS 서버(2320)로부터 DNS 쿼리에 대응하여 주소 정보를 포함하는 DNS 응답을 수신하는 경우, DNS 응답에 포함된 주소 정보(예: MEC 호스트에 관련된 URI(FQDN)에 대응되는 IP 주소)를 MEC 용 로컬 DNS 캐시(Local DNS Cache)(예: DNS Cache 2)에 저장할 수 있다. 일 실시예에 따르면, MSE(530)는 클라이언트 어플리케이션(510)으로부터 MEC 어플리케이션에 대한 주소 정보(예: URI 또는 IP 주소)가 요청되는 경우, MEC 용 로컬 DNS 캐시에 저장된 주소 정보를 전달할 수 있다. 다양한 실시예들에 따르면, MEC 용 로컬 DNS 캐시(예: DNS Cache 2)의 운영과 관련하여, 후술하는 도 34의 MEC 용 로컬 DNS 캐시(예: DNS Cache 2)를 별도 운용하는 방안, 또는 도 35의 MSE(530) 내에 MEC 용 로컬 DNS 캐시(예: DNS Cache 2)를 포함하여 운용하는 방안이 이용될 수 있다. 일 실시예에 따른 MEC 용 로컬 DNS 캐시를 운용하는 동작과 관련하여 후술하는 도면을 참조하여 상세히 설명된다.
다양한 실시예들에 따르면, 전자 장치(101)는 MEC 호스트 선택 동작에 기반하여, MMP 서버(430)와의 통신 절차(예: 디스커버리/어플리케이션 컨텍스트 생성)에서, MEC 어플리케이션이 동작할 수 있는 복수 개의 MEC 호스트 정보(예: URI 또는 IP 주소)를 수신할 수 있다. 일 실시예에 따르면, 전자 장치(101)는 수시된 복수 개의 MEC 호스트 중 어느 하나의 MEC 호스트를 선택하여 통신할 수 있다. 다양한 실시예들에 따르면, 전자 장치(101)는 MEC 어플리케이션이 동작할 수 있는 복수 개의 MEC 호스트에 대하여, 우선 순위에 따라 선택할 수 있다. 일 실시예에 따르면, 우선 순위는 전자 장치(101)와 MEC 호스트 간의 지연 시간(latency) 측정 정보 또는 MEC 호스트의 위치 정보에 적어도 기반하여 결정될 수 있다.
이하에서, 다양한 실시예들에 따라, 전자 장치(101)에서 일반 클라이언트 어플리케이션(general client Apps)에 대한 DNS 캐싱 데이터와 별도로, MEC 클라이언트 어플리케이션(MEC client Apps)에 대한 DNS 캐싱 데이터를 유지 및/또는 관리하는 동작을 설명한다.
도 34는 다양한 실시예들에 따른 전자 장치(101)에서 MEC 용 로컬 DNS 캐시를 별도로 운용하는 예를 도시하는 도면이다.
도 34를 참조하면, 도 34는 MEC 용 로컬 DNS 캐시(예: 제2 DNS 캐시(3430))를 전자 장치(101)의 MSE(530)와 별도로 구분하여 구성하는 예를 나타낼 수 있다. 일 실시예에 따르면, 일반 클라이언트 어플리케이션(general client Apps)(3410)은 제1 DNS 캐시(3420)로 DNS 캐싱을 수행할 수 있고, MEC 클라이언트 어플리케이션(MEC Client Apps)(510)은 제2 DNS 캐시(3430)로 DNS 캐싱을 수행할 수 있다. 예를 들어, 일반 클라이언트 어플리케이션(3410)은 제1 DNS 캐시(3420)를 이용할 수 있고, MEC 클라이언트 어플리케이션(510)은 제2 DNS 캐시(3430)를 이용할 수 있다.
일 실시예에 따르면, 클라이언트 애플리케이션의 접근하고자 하는 URI에 대해 DNS 리졸빙 API를 사용하여 요청만 수행하고 그에 대한 IP 주소를 수신할 수 있다. 예를 들어, MSE(530)(예: DHL(535))(또는 전자 장치(101)의 OS, 또는 프레임워크(framework) 상의 DNS 처리 모듈)는 클라이언트 어플리케이션의 해당 요청을 DNS 쿼리(예: FQDN) 메시지로 변경하여 DNS 서버(2320)로 요청하고, DNS 응답(예: FQDN에 대응하는 IP 주소)를 수신하여 이를 캐싱하고, 클라이언트 어플리케이션에 전달할 수 있다. 일 실시예에 따르면, MSE(530)는 클라이언트 어플리케이션 별 똔 URI(FQDN) 별로 어떠한 DNS 캐시를 사용할 지에 대한 결정을 할 수 있으며, 그에 따라 별도 DNS 처리 모듈(예: 도 34) 또는 MSE의 DHL(도 35)이 제1 DNS 캐시(3420) 또는 제2 DNS 캐시(3430)를 참조하여 IP 주소를 클라이언트 어플리케이션에 전달할 수 있다. 일 실시예에 따라, DNS 처리 모듈 또는 DHL은 요청받은 URI(FQDN)에 대해 DNS 캐시를 먼저 참조하여 해당 URI에 대응되는 IP가 있으면 이를 전달하고, 캐시에 없을 경우 DNS 서버(2320)로 DNS 쿼리를 수행할 수 있다.
다양한 실시예들에 따라, 일반 클라이언트 어플리케이션(3410)과 MEC 클라이언트 어플리케이션(510)을 구분하여, DNS 캐싱을 수행하는 것과 관련하여, 후술하는 도면(예: 도 36)을 참조하여 상세히 설명된다.
도 35는 다양한 실시예들에 따른 전자 장치(101)에서 MSE(530) 내에 MEC 용 로컬 DNS 캐시를 운용하는 예를 도시하는 도면이다.
도 35를 참조하면, 도 35는 MEC 용 로컬 DNS 캐시(예: 제2 DNS 캐시(3430)를 전자 장치(101)의 MSE(530) 내에 구성하는 예를 나타낼 수 있다. 일 실시예에 따르면, 일반 클라이언트 어플리케이션(3410)은 제1 DNS 캐시(3420)로 DNS 캐싱을 수행할 수 있고, MEC 클라이언트 어플리케이션(510)은 제2 DNS 캐시(3430)로 DNS 캐싱을 수행할 수 있다. 예를 들어, 일반 클라이언트 어플리케이션(3410)은 제1 DNS 캐시(3420)를 이용할 수 있고, MEC 클라이언트 어플리케이션(510)은 제2 DNS 캐시(3430)를 이용할 수 있다.
일 실시예에 따르면, 클라이언트 애플리케이션의 접근하고자 하는 URI에 대해 DNS 리졸빙 API를 사용하여 요청만 수행하고 그에 대한 IP 주소를 수신할 수 있다. 예를 들어, MSE(530)(예: DHL(535))(또는 전자 장치(101)의 OS, 또는 프레임워크(framework) 상의 DNS 처리 모듈)는 클라이언트 어플리케이션의 해당 요청을 DNS 쿼리(예: FQDN) 메시지로 변경하여 DNS 서버(2320)로 요청하고, DNS 응답(예: FQDN에 대응하는 IP 주소)를 수신하여 이를 캐싱하고, 클라이언트 어플리케이션에 전달할 수 있다. 일 실시예에 따르면, MSE(530)는 클라이언트 어플리케이션 별 똔 URI(FQDN) 별로 어떠한 DNS 캐시를 사용할 지에 대한 결정을 할 수 있으며, 그에 따라 별도 DNS 처리 모듈(예: 도 34) 또는 MSE의 DHL(도 35)이 제1 DNS 캐시(3420) 또는 제2 DNS 캐시(3430)를 참조하여 IP 주소를 클라이언트 어플리케이션에 전달할 수 있다. 일 실시예에 따라, DNS 처리 모듈 또는 DHL은 요청받은 URI(FQDN)에 대해 DNS 캐시를 먼저 참조하여 해당 URI에 대응되는 IP가 있으면 이를 전달하고, 캐시에 없을 경우 DNS 서버(2320)로 DNS 쿼리를 수행할 수 있다.
다양한 실시예들에 따라, 일반 클라이언트 어플리케이션(3410)과 MEC 클라이언트 어플리케이션(510)을 구분하여, DNS 캐싱을 수행하는 것과 관련하여, 후술하는 도면(예: 도 36)을 참조하여 상세히 설명된다.
도 36은 다양한 실시예들에 따라 도메인 이름에 대한 IP 주소를 이용하는 동작을 도시하는 도면이다.
도 36을 참조하면, 네트워크 환경(3600)(예: 도 3의 네트워크 환경(300))에서, 제1 상태(3601)는 MEC 서비스 모듈(410)(예: MSE(530))이 비활성화(disabled)된 상태를 나타낼 수 있고, 제2 상태(3602)는 MEC 서비스 모듈(410)이 활성화(enabled)된 상태를 나타낼 수 있다.
일 실시예에 따르면, 전자 장치(101)는 도메인 이름 및 도메인 이름에 대한 IP 주소를 저장하도록 구성되는 제1 DNS 캐시(domain name server cache)(3610) 및 제2 DNS 캐시(3620)를 포함할 수 있다. 일 실시예에 따르면, 제1 DNS 캐시(3610)는 일반적인 어플리케이션의 어플리케이션 이름, 도메인 이름 또는 도메인 이름에 대한 IP 주소 중 적어도 하나를 저장할 수 있고, 제2 DNS 캐시(3620)는 MEC 어플리케이션(460)의 어플리케이션 이름, 도메인 이름, 또는 도메인 이름에 대한 IP 주소 중 적어도 하나를 저장할 수 있다. 전자 장치(101)는 도메인 이름에 매핑되는 IP 주소로 접속하므로, 일 실시예에 따르면 도메인 이름 및 도메인 이름에 대한 IP 주소는 쌍(pair)으로 저장될 수 있다.
일 실시예에 따르면, MEC 서비스 모듈(410)은 어플리케이션에 대한 도메인 이름을 프록시 서버(예: 도 4의 MMP 서버(430)(또는 LCM 프록시 서버) 또는 별도의 프록시 서버)로부터 획득할 수 있다. 도메인 이름은, 예를 들어, FQDN(fully qualified domain name) 또는 URI 중 적어도 하나를 포함할 수 있다. 일 실시예에 따르면, MEC 서비스 모듈(410)은 도메인 이름을 디스커버리 절차에서 획득할 수 있다.
일 실시예에 따르면, MEC 서비스 모듈(410)은 도메인 이름에 기반하여 도메인 이름에 대한 IP 주소를 획득할 수 있다. MEC 서비스 모듈(410)은 획득된 IP 주소가 MEC 서비스를 지원하는 MEC 어플리케이션에 접근할 수 있는 도메인 이름에 대한 IP 주소이면, IP 주소를 제2 DNS 캐시(3620)에 저장할 수 있다.
일 실시예에 따르면, 어플리케이션(예: 클라이언트 어플리케이션(510))이 도메인 이름(예: http:www.xxx.com)에 접근하려 할 때, MEC 서비스 모듈(410)이 비활성화된 상태(예: 제1 상태(3601))이면, 어플리케이션(510)은 제1 DNS 캐시(3610)에 저장된 도메인 이름의 IP 주소(예: 111.222.333)를 이용하여 인터넷(3630)을 통해 연결된 리모트(또는 중앙(central)) 서버(3640)로 접근할 수 있다. 예를 들어, MEC 서비스 모듈(410)은 MEC 서비스 모듈(410)이 비활성화 된 상태이면 제1 DNS 캐시(3610)에 저장된 IP 주소(예: 111.222.333)를 참조하여 도메인 이름을 IP 주소로 변환할 수 있다. 어플리케이션(510)이 접근하려는 도메인 이름에 대응하는 IP 주소가 제1 DNS 캐시(3610)에 없으면, MEC 서비스 모듈(410)은 별도의 서버(예: DNS 서버)로 IP 주소를 요청할 수 있다.
일 실시예에 따라 MEC 서비스 모듈(410)이 활성화된 상태(예: 제2 상태(3602))이면, MEC 서비스 모듈(410)은 어플리케이션(510)이 접근하려는 도메인 이름을 제2 DNS 캐시(3620)를 참조하여 도메인 이름에 대응하는 IP 주소(예: 10.22.33)로 변환하고, 변환된 IP 주소를 통해 어플리케이션(510)이 MEC 시스템(405)에 포함되는 MEC 어플리케이션(460)에 접근하도록 유도할 수 있다. 어플리케이션(510)이 접근하려는 도메인 이름에 대응하는 IP 주소가 제2 DNS 캐시(3620)에 없으면, MEC 서비스 모듈(410)은 별도의 서버(예: DNS 서버)로 IP 주소를 요청할 수 있다.
도 37은 다양한 실시예들에 따라 IP 주소를 공유하기 위한 신호 흐름도(3700)를 도시한다.
도 37을 참조하면, DNS 서버(2320)는 MEC 시스템(405)과 별도의 개체일 수도 있고, MEC 시스템(405)에 포함될 수도 있다.
동작 3705에서, MEC 서비스 모듈(410)(예: MSE(530))는 MEC 시스템(405)(예: 도 4의 MMP 서버(430)(또는 LCM 프록시 서버)에 어플리케이션(예: 클라이언트 어플리케이션(510))에 대한 도메인 이름을 요청할 수 있다. 도메인 이름은, 예를 들어, FQDN을 포함할 수 있다. 일 실시예에 따르면, MEC 서비스 모듈(410)은 어플리케이션(510)에 대한 도메인 이름과 함께 DNS 서버(2320)의 주소를 요청할 수 있다.
동작 3710에서, MEC 시스템(405)은 도메인 이름을 포함하는 정보를 MEC 서비스 모듈(410)에게 전송할 수 있다. 일 실시예에 따르면, MEC 시스템(405)은 도메인 이름과 함께 DNS 서버(2320)의 주소를 MEC 서비스 모듈(410)에게 전송할 수 있다.
일 실시예에 따르면, 동작 3705 및 동작 3710은 MEC 디스커버리 절차에 포함될 수 있다. 예를 들어, MEC 서비스 모듈(410)은 MEC 시스템(405)이 제공 가능한 어플리케이션들에 관한 정보와 함께 도메인 이름을 요청할 수 있다. 다른 예를 들어, MEC 서비스 모듈(410)은 MEC 디스커버리 절차에서 MEC 시스템(405)이 제공 가능한 어플리케이션들에 관한 정보와 별도로 도메인 이름을 요청할 수도 있다. MEC 시스템(405)은 도메인 이름과 MEC 시스템(405)이 제공 가능한 어플리케이션들에 관한 정보를 함께 전송하거나, 또는 별도로 전송할 수 있다.
다른 실시예에 따르면, MEC 서비스 모듈(410)은 동작 3705 및 동작 3710을 MEC 디스커버리 절차와 별도로 수행할 수도 있다. 예를 들어, MEC 서비스 모듈(410)은 어플리케이션(510)이 전자 장치(101)에 설치될 때, 전자 장치(101)의 이동성과 관련된 이벤트를 감지할 때, 어플리케이션(510)이 도 20의 제1 조건을 만족함을 감지할 때, 또는 지정된 주기에 따라서 동작 3705 및 동작 3710을 수행할 수 있다.
동작 3715에서, 어플리케이션(510)은 도메인 이름에 대한 접근을 요청할 수 있다. 일 실시예에 따르면, 동작 3715는 DNS 쿼리(query)로 지칭될 수 있다. 일 실시예에 따르면, 어플리케이션(510)이 MEC 어플리케이션(예: 도 36의 ME 어플리케이션(460))과 MEC 기반 데이터 전송을 수행하기 위해서는 MEC 어플리케이션(460)에 대한 IP 주소가 필요하므로, 이를 위한 DNS 쿼리를 수행할 수 있다.
일 실시예에 다르면, MEC 서비스 모듈(410)은 DNS 쿼리에 포함된 정보 및/또는 제2 DNS 캐시(예: 도 36의 제2 DNS 캐시(3620))에 저장된 정보에 기반하여 동작 3720 내지 동작 3725를 수행하거나 수행하지 않을 수 있다. 예를 들어, MEC 서비스 모듈(410)은 DNS 쿼리에 포함된 어플리케이션의 이름 또는 도메인 이름(예: FQDN 또는 URI) 중 적어도 하나에 대응하는, 제2 DNS 캐시(3620)에 저장된 어플리케이션의 이름 또는 도메인 이름 중 적어도 하나를 식별할 수 있다.
일 실시예에 따라, 식별된 어플리케이션의 이름 또는 도메인 이름 중 적어도 하나에 대응하는 IP 주소가 제2 DNS 캐시(3620)에 존재하면, 동작 3730에서 MEC 서비스 모듈(410)은 IP 주소를 어플리케이션(510)에게 전달(transfer)할 수 있다.
일 실시예에 따라, 식별된 어플리케이션의 이름 또는 도메인 이름 중 적어도 하나에 대응하는 IP 주소가 제2 DNS 캐시(3620)에 존재하지 않다면, 동작 3720에서, MEC 서비스 모듈(410)은 DNS 서버(2320)로 MEC 어플리케이션에 대한 IP 주소를 요청할 수 있다. 동작 3720에서 전송되는 메시지(또는 데이터 패킷)는, 예를 들어, 동작 3710에서 MEC 시스템(405)으로부터 수신된 도메인 이름을 포함할 수 있다. 동작 3725에서, DNS 서버(2320)는 MEC 어플리케이션에 대한 IP 주소를 MEC 서비스 모듈(410)에게 전송할 수 있다. 동작 3730에서, MEC 서비스 모듈(410)은 수신된 IP 주소를 어플리케이션(510)에게 전달할 수 있다.
일 실시예에 따른 도 37은 DNS 쿼리 동작에 응답하여 MEC 서비스 모듈(410)이 IP 주소를 요청하는 실시예를 도시하지만, 다른 실시 예들에 따르면, MEC 서비스 모듈(410)은 DNS 쿼리와 별도로 IP 주소를 DNS 서버(2320)에게 요청할 수도 있다. 이러한 경우, MEC 서비스 모듈(410)이 IP 주소를 요청하기 위해서는 MEC 어플리케이션에 대한 도메인 이름이 요구되므로, MEC 서비스 모듈(410)은 동작 3710 이후에 IP 주소를 요청할 수 있다. 예를 들어, MEC 서비스 모듈(410)은 컨텍스트 생성 동작을 통해 IP주소를 요청할 수도 있다.
동작 3735에서, 어플리케이션(510)은 MEC 서비스 모듈(410)로부터 전달받은 IP 주소를 이용하여 MEC 시스템(405)에 포함된 MEC 어플리케이션과 데이터 전송을 수행할 수 있다.
다양한 실시예들에 따를 때, 전자 장치(101)는 복수의 어플리케이션들에 대응하는 복수의 MEC 어플리케이션들의 IP 주소를 MEC 서비스 모듈(410)을 통하여 일괄적으로 관리할 수 있으므로, 자원 소모를 줄이고 안정적인 서비스를 제공할 수 있다.
도 38은 다양한 실시예들에 따른 전자 장치(101)에서 도메인 이름에 대한 IP 주소를 이용하는 방법을 도시하는 흐름도이다.
다양한 실시예들에서, 도 38에 도시된 동작들은, 전자 장치(101) 또는 전자 장치(101)에 포함된 구성 요소(예: 도 1의 프로세서(120) 또는 도 4의 MEC 서비스 모듈(410))에 의하여 수행될 수 있다.
도 38을 참조하면, 동작 3855에서, 전자 장치(101)(예: MEC 서비스 모듈(410))는 어플리케이션(예: 클라이언트 어플리케이션(510))이 도메인 이름에 접근을 요청함을 감지할 수 있다(예: 도 37의 동작 3715).
동작 3860에서, 전자 장치(101)는 어플리케이션(510)이 접근을 요청하는 도메인 이름이 MEC를 지원할 수 있는지 확인할 수 있다. 예를 들어, 전자 장치(101)는 디스커버리 절차를 통해 수신된 정보에 기반하여, 어플리케이션(510)이 접근을 요청하는 도메인 이름이 MEC를 지원할 수 있는지 여부를 확인할 수 있다.
동작 3860에서, 전자 장치(101)는 접근 요청된 도메인 이름이 MEC를 지원 가능하면(예: 동작 3860의 YES), 동작 3865에서, 제2 DNS 캐시(3820)를 이용하여 도메인 이름에 접근할 수 있다.
동작 3860에서, 전자 장치(101)는 접근 요청된 도메인 이름이 MEC를 지원 가능하지 않으면(예: 동작 3860의 NO), 동작 3870에서, 제1 DNS 캐시(3610)를 이용하여 도메인 이름에 접근할 수 있다.
도 39는 다양한 실시예들에 따른 전자 장치(101)에서 IP 주소를 요청하는 방법을 도시하는 흐름도이다.
다양한 실시예들에서, 도 39에 도시된 동작들은, 전자 장치(101) 또는 전자 장치(101)에 포함된 구성 요소(예: 도 1의 프로세서(120) 또는 도 4의 MEC 서비스 모듈(410))에 의하여 수행될 수 있다. 일 실시예에 따라, 도 39에 도시된 동작들은, 예를 들어, 도 38의 동작 3865의 일 실시예일 수 있다.
도 39를 참조하면, 동작 3940에서, MEC 서비스 모듈(410)는 제2 DNS 캐시(3620)에 MEC 어플리케이션에 대한 IP 주소가 저장되었는지를 식별할 수 있다.
동작 3940에서, MEC 서비스 모듈(410)은 제2 DNS 캐시(3620)에 IP 주소가 저장되어 있으면(예: 동작 3940의 YES), 동작 3945에서, 제2 DNS 캐시(3620)에 저장된 IP 주소를 어플리케이션(510)에게 전달할 수 있다.
동작 3940에서, MEC 서비스 모듈(410)은 제2 DNS 캐시(3620)에 IP 주소가 저장되어 있지 않으면(예: 동작 3940의 NO), 동작 3950에서, DNS 서버(2320)에게 IP 주소를 요청할 수 있다.
동작 3955에서, MEC 서비스 모듈(410)은 DNS 서버(2320)로부터 IP 주소를 수신할 수 있다. 일 실시예에 따르면, 동작 3945를 수행하기 이전에 MEC 서비스 모듈(410)은 수신된 IP 주소를 일시적으로 제2 DNS 캐시(3620)에 저장할 수 있다. 일 실시 예에 따라, 동작 3955에서, MEC 서비스 모듈(410)이 IP 주소와 함께 유효 기간을 나타내는 정보를 포함하면, MEC 서비스 모듈(410)은 정보가 나타내는 유효기간 동안에 IP 주소를 제2 DNS 캐시(3620)에 저장할 수 있다.
동작 3945에서, MEC 서비스 모듈(410)은 제2 DNS 캐시(3620)에 저장된 IP 주소를 어플리케이션(510)에게 전달할 수 있다.
도 40은 다양한 실시예들에 따른 전자 장치(101)에서 IP 주소를 이용하여 MEC 기반 데이터 전송을 수행하는 방법을 도시하는 흐름도이다.
다양한 실시예들에서, 도 38에 도시된 동작들은, 전자 장치(101) 또는 전자 장치(101)에 포함된 구성 요소(예: 도 1의 프로세서(120) 또는 도 4의 MEC 서비스 모듈(410))에 의하여 수행될 수 있다.
도 40을 참조하면, 동작 4065에서, 전자 장치(101)는 MEC 서비스 모듈(410)(예: MSE(530))와 관련된 제1 주소를 포함하고, 도메인 이름을 요청하는 제1 데이터 패킷을 적어도 하나의 외부 서버(예: MEC 시스템(405)(또는 엣지 서버 또는 MEC 서버)의 일부 구성 요소)로 전송할 수 있다. 일 실시예에 따르면, 제1 주소는 전자 장치(101)의 IP 주소 및 MEC 서비스 모듈(410)과 관련된 IP 포트 식별자를 포함할 수 있다. 일 실시예에 따르면, 도메인 이름은 외부 서버에 포함된 MEC 어플리케이션(예: 도 36의 MEC 어플리케이션(460))과 관련된 도메인 이름일 수 있다.
일 실시예에 따르면, 전자 장치(101)는 어플리케이션(510)이 MEC 어플리케이션에 대한 접근을 요청하는 것에 응답하여, 제1 데이터 패킷을 전송할 수 있다. 예를 들어, 어플리케이션(510)이 전자 장치(101)에 설치되거나 또는 어플리케이션(510)의 실행을 요청하는 사용자 입력이 수신되면, 어플리케이션(510)은 MEC 어플리케이션에 대한 접근을 요청할 수 있다. 다른 실시예에 따르면, 전자 장치(101)는 MEC 디스커버리 절차에서 제1 데이터 패킷을 전송할 수 있다. 다른 실시예에 따르면, 전자 장치(101)는 전자 장치(101)의 이동성이 감지되거나, 어플리케이션(510)이 MEC에 기반한 데이터 전송을 수행할 수 있는 조건(예: 도 20의 제1 조건)이 만족되면, 제1 데이터 패킷을 전송할 수 있다. 다른 실시예에 따르면, 전자 장치(101)는 지정된 주기로 제1 데이터 패킷을 전송할 수 있다.
동작 4070에서, 전자 장치(101)는 도메인 이름을 포함하는 정보를 적어도 하나의 외부 서버로부터 수신할 수 있다. 도메인 이름은, 예를 들어, MEC 어플리케이션들과 연관된 도메인 이름일 수 있다.
동작 4075에서, 전자 장치(101)는 제1 주소 및 MEC 어플리케이션들과 연관된 도메인 이름을 포함하고, 도메인 이름에 대한 IP 주소를 요청하는 제2 데이터 패킷을 적어도 하나의 외부 서버(예: DNS 서버(2320))로 전송할 수 있다.
일 실시예에 따르면, 전자 장치(101)는 MEC 디스커버리 절차에서 제2 데이터 패킷을 전송하거나, 전자 장치(101)의 이동성이 감지되거나, 제1 조건이 만족되거나, 또는 지정된 주기로 제2 데이터 패킷을 전송할 수 있다.
동작 4080에서, 전자 장치(101)는 적어도 하나의 외부 서버로부터 도메인 이름에 대한 IP 주소를 포함하는 정보를 수신할 수 있다.
동작 4085에서, 전자 장치(101)는 수신된 IP 주소에 기반하여, 사용자 데이터 및 제2 주소를 포함하는 제3 데이터 패킷을 적어도 하나의 외부 서버(예: MEC 시스템(405)의 일부 구성 요소)로 전송할 수 있다. 제2 주소는 전자 장치(101)의 IP 주소 및 어플리케이션(510)과 관련된 IP 포트 식별자를 포함할 수 있다. 일 실시예에 따르면, 어플리케이션(510)과 관련된 IP 포트 식별자는 MEC 서비스 모듈(410)과 관련된 IP 포트 식별자와 상이할 수 있다.
다른 실시예에 따라, MEC 어플리케이션과 연관된 도메인 이름에 대한 IP 주소가 전자 장치(101)에 기 저장되어 있는 경우, 전자 장치(101)는 동작 4075 및 동작 4080을 생략하고, 동작 4085를 수행할 수 있다.
도 41은 다양한 실시예들에 따른 디스커버리 절차에서 DNS 리졸빙 동작의 예를 도시하는 도면이다.
도 41에 도시한 바와 같이, 도 41은 클라이언트 어플리케이션(510)의 DNS 쿼리에 대한 DNS 리졸빙 동작을 나타낼 수 있다. 일 실시예에 따르면, DNS 리졸빙 동작은, DNS 서버(2320)가 비활성화된 상태인 경우의 동작(예: 동작 4110)과 DNS 서버(2320)가 활성화된 상태인 경우의 동작(예: 동작 4130)을 포함할 수 있다.
일 실시예에 따르면, 동작 4110의 DNS 리졸빙 동작은, 예를 들어, DNS 캐시(2310)에서 MEC용 로컬 DNS 캐시(예: 제2 DNS 캐시(3430))가 비활성화된 상태의 동작 예를 나타낼 수 있다. 도 41을 참조하면, 클라이언트 어플리케이션(510)은 URI에 대한 DNS 쿼리를 DNS 캐시(2310)로 전달(동작 4111)할 수 있고, DNS 캐시(2310)는 클라이언트 어플리케이션(510)의 DNS 쿼리에 대한 응답(예: DNS Cache Response)을 클라이언트 어플리케이션(510)에 전달(동작 4113)할 수 있다. 일 실시예에 따라, DNS 캐시(2310)는 MEC 어플리케이션의 어플리케이션 이름, 도메인 이름, 또는 도메인 이름에 대한 IP 주소 중 적어도 하나를 저장할 수 있다. 일 실시예에 따라, 클라이언트 어플리케이션(510)의 URI에 대한 DNS 쿼리 시 DNS 캐시(2310)에 해당 URI의 MEC 어플리케이션의 IP 주소가 존재하지 않는 경우(예: DNS 캐시 미스(cache miss)), 클라이언트 어플리케이션(510)은 DNS 서버(2320)로 DNS 쿼리를 전달(동작 4115)하고, DNS 서버(2320)로부터 DNS 쿼리에 대응하는 응답(4117)에 기반하여, IP 주소를 획득할 수 있다.
일 실시예에 따르면, 동작 4130의 DNS 리졸빙 동작은, 예를 들어, DNS 캐시(2310)에서 MEC용 로컬 DNS 캐시(예: 제2 DNS 캐시(3430)가 활성화된 상태의 동작 예를 나타낼 수 있다. 도 41을 참조하면, 클라이언트 어플리케이션(510)은 URI에 대한 DNS 쿼리를 MSE(530)를 통해 DNS 캐시(2310)로 전달(동작 4131, 동작 4133)할 수 있다. 일 실시예에 따라, DNS 캐시(2310)는 MSE(530)로 DNS 쿼리에 대한 DNS 응답을 전달(동작 4135)할 수 있다. 일 실시예에 따라, 클라이언트 어플리케이션(510)의 URI에 대한 DNS 쿼리 시 DNS 캐시(2310)에 해당 URI의 MEC 어플리케이션의 IP 주소가 존재하지 않는 경우(예: DNS 캐시 미스), MSE(530)는 DNS 서버(2320)로 DNS 쿼리를 전달(동작 4137)하고, DNS 서버(2320)로부터 DNS 쿼리에 대응하는 응답을 수신(동작 4139)하고, 수신된 응답을 클라이언트 어플리케이션(510)에 포워딩(동작 4141) 할 수 있다.
일 실시예에 따르면, 클라이언트 어플리케이션(510)의 URI에 대한 DNS 쿼리 시 DNS 캐시(2310)에 해당 URI의 MEC 어플리케이션의 IP 주소가 있을 경우, 해당 주소로 MEC 어플리케이션에 접속할 수 있다. 일 실시예에 따르면, DNS 리졸빙에서, DNS 캐시 미스 시, DNS 리졸빙을 통해 리모트(remote) 서버(예: 도 3의 리모트 서버(306)) 또는 Client App-driven MEC 어플리케이션에 접속할 수 있다. 일 실시예에 따르면, DNS 리졸빙에서, DNS 프록시(proxy)가 있을 경우, DNS 프록시가 클라이언트 어플리케이션의 DNS 쿼리를 후킹(hooking)하여 MEC 앱 리스트에 따라 DNS 리졸빙을 수행할 수 있다.
일 실시예에 따르면, MSE(530)에서는 3rd 파티 어플리케이션(party application)에 DNS Pre-resolving 또는 DNS 프록시 기능을 지원할 수 있다. 예를 들어, 기존 기본 PDU 세션을 통해 데이터 연결이 된 상태에서 MEC 용 클라이언트 어플리케이션(510)이 특정 서비스 접속을 위한 DNS 쿼리를 하면, DNS 프록시가 DNS 쿼리를 가로채서, MEC 용 도메인 이름으로 DNS 서버(2320)에 쿼리를 하거나, 또는 DNS 캐시(2310)에서 룩업(lookup)하여 해당 MEC 도메인 IP 주소를 반환할 수 있다. 이를 통해, 3rd 파티 어플리케이션이 별도의 소프트웨어 수정 없이, 그리고 오퍼레이터의 별도 트래픽 필터링(traffic filtering)(또는 steering) 작업 없이 MEC 서비스를 제공할 수 있다.
도 42는 다양한 실시예들에 따른 디스커버리 절차에서 서비스 클로즈 절차의 예를 도시하는 도면이다.
도 42에 도시한 바와 같이, 도 42는 일 실시예에 따른 MEC 디스커버리 절차에서 MEC 서비스 클로즈(MEC Service Close)(예: MEC Application Context Delete)에 관한 동작 예를 나타낼 수 있다. 일 실시예에 따라, 어플리케이션 컨텍스트 삭제 동작은, 예를 들면, 클라이언트 어플리케이션(510)이 종료되는 경우, MSA(520)가 앱 종료 이벤트를 MSE API를 통해 MSE(530)에 전달하는 것으로부터 수행될 수 있다. 다양한 실시예들에 따르면, 어플리케이션 컨텍스트 삭제는, 클라이언트 어플리케이션 사용이 종료되거나(제1 케이스), 또는 클라이언트 어플리케이션이 직접 MSE API를 통해 컨텍스트 삭제(contextDelete)를 요청(제2 케이스)하는 경우에 수행할 수 있으며, 도 42에서는 제1 케이스에 따라 어플리케이션 컨텍스트 삭제를 수행하는 동작 예를 나타낼 수 있다.
도 42를 참조하면, 동작 4201에서, 특정 클라이언트 어플리케이션(510)이 종료되는(App stop detected) 경우, 해당 클라이언트 어플리케이션(510)은 어플리케이션의 사용 종료를 알리는 정보(예: App Stop)를 MSA(520)로 제공할 수 있다.
동작 4203에서, MSA(520)는 클라이언트 어플리케이션(510)의 종료를 알리는 정보를 수신하면, 클라이언트 어플리케이션(510)의 상태(state)를 통지(notify)하는 통지 메시지(예: notifyClientAppState)를 MSE(530)로 제공할 수 있다. 일 실시예에 따라, 통지 메시지(예: notifyClientAppState)는, 예를 들어, 클라이언트 어플리케이션의 상태(예: STOP)와 클라이언트 어플리케이션의 이름(예: clientAppName)(및/또는 UID)을 포함(예: notifyClientAppState(STOP, clientAppName))하여 제공할 수 있다.
동작 4205에서, MSE(530)는 MSA(520)로부터 통지 메시지(예: notifyClientAppState)를 수신하고, 수신된 통지 메시지의 정보에 기반하여 어플리케이션 컨텍스트 삭제 동작을 수행할 수 있다. 일 실시예에 따르면, 어플리케이션 컨텍스트 삭제 동작(동작 4205)은, 동작 4210, 동작 4220, 동작 4230을 포함할 수 있다.
동작 4210에서, MSE(530)는 어플리케이션 컨텍스트 삭제를 요청하는 요청 메시지(예: HTTP DELETE AppContext Data)를 MMP 서버(430)로 전송할 수 있다. 일 실시예에 따르면, MSE(530)는 여러 개의 클라이언트 어플리케이션이 한 번에 종료되는 경우(예: 파워 오프(power off) 또는 네트워크 오프(network off)), 컨텍스트 삭제 요청을 여러 번 반복하여 MMP 서버(430)로 전송하거나, 또는 하나의 컨텍스트 삭제 요청에, 여러 컨텍스트 정보(Context Info)를 포함하여 MMP 서버(430)로 전송할 수 있다.
동작 4220에서, MMP 서버(430)는 MSE(530)로부터 수신된 요청 메시지에 대응하는 응답으로 응답 메시지(예: HTTP OK 204 No Content)를 MSE(530)로 제공할 수 있다. 일 실시예에 따르면, MMP 서버(430)는 구동 중인 MEC 어플리케이션에서 컨텍스트 삭제 요청된 MEC 어플리케이션을 종료하고, 그 결과(예: No content)를 응답 메시지에 포함하여, MSE(530)로 제공할 수 있다.
동작 4230에서, MSE(530)는 PDU 세션 해제(session release)를 수행할 수 있다. 일 실시예에 따르면, MSE(530)는 MMP 서버(430)로 컨텍스트 삭제 요청 후, 필요에 따라(예: PDU 세션 해제가 필요한 경우), 해당 PDU 세션의 해제(release) 작업을 수행할 수 있다. 예를 들어, URSP 규칙(또는 CARP 규칙)은 인증 절차의 결과(예: MSA(520)가 수신하여 MSE(530)에 전달), 또는 MSE(530)가 어플리케이션 룩업(예: App lookup) 결과, 또는 컨텍스트 생성(Context Create) 결과로 수신할 수 있으며, URSP 규칙에 새로운 DNN 규칙이 설정되어 있는 경우, PDU 세션 설정(setup)을 수행할 수 있다. 일 실시예에 따르면, PDU 세션 설정(예: 도 17의 PDU 세션 생성, 도 18의 PDU 세션 해제)은 전술한 도 17 또는 도 18을 참조한 설명 부분에서 설명한 바와 같이 MSE(530)가 모뎀(1700)에 요청하면, 모뎀(1700)에서 5G 망(또는 코어 망)의 SMF에 요청하여 생성/해제할 수 있다.
도 43은 다양한 실시예들에 따른 디스커버리 절차에서 서비스 클로즈 절차의 예를 도시하는 도면이다.
도 43에 도시한 바와 같이, 도 43은 일 실시예에 따른 MEC 디스커버리 절차에서 MEC 서비스 클로즈(MEC Service Close)(예: MEC Application Context Delete)에 관한 동작 예를 나타낼 수 있다. 일 실시예에 따라, 어플리케이션 컨텍스트 삭제 동작은, 예를 들면, 클라이언트 어플리케이션(510)이 컨텍스트 삭제 요청을 MSE API를 통해 MSE(530)에 전달하는 것으로부터 수행될 수 있다. 다양한 실시예들에 따르면, 어플리케이션 컨텍스트 삭제는, 클라이언트 어플리케이션 사용이 종료되거나(제1 케이스), 또는 클라이언트 어플리케이션이 직접 MSE API를 통해 컨텍스트 삭제(contextDelete)를 요청(제2 케이스)하는 경우에 수행할 수 있으며, 도 43에서는 제2 케이스에 따라 어플리케이션 컨텍스트 삭제를 수행하는 동작 예를 나타낼 수 있다.
도 43을 참조하면, 동작 4301에서, 클라이언트 어플리케이션(510)은 MSE(530)로 컨텍스트 삭제를 위한 메시지(예: contextDelete)를 전달할 수 있다. 일 실시예에 따르면, 클라이언트 어플리케이션(510)은 사용이 종료되는 경우, 해당 클라이언트 어플리케이션에 관련된 정보(예: 어플리케이션 이름(appName) 또는 UID)와 함께 컨텍스트 삭제 요청을 MSE API를 통해 MSE(530)로 전달할 수 있다.
동작 4303에서, MSE(530)는 클라이언트 어플리케이션(510)으로부터 컨텍스트 삭제를 위한 메시지를 수신하고, 수신된 메시지의 정보(예: 어플리케이션 이름)에 기반하여 어플리케이션 컨텍스트 삭제 동작을 수행할 수 있다. 일 실시예에 따르면, 어플리케이션 컨텍스트 삭제 동작(동작 4303)은, 동작 4310, 동작 4320, 동작 4330을 포함할 수 있다. 일 실시예에 따르면, 어플리케이션 컨텍스트 삭제 동작(동작 4303)은, 전술한 도 42에서 동작 4205의 어플리케이션 컨텍스트 삭제 절차에 따른 동작 4210, 동작 4220, 동작 4230을 참조한 설명 부분에서 설명한 바에 각각 대응할 수 있다.
본 명세서와 도면에 개시된 본 개시의 다양한 실시예들은 본 개시의 기술 내용을 쉽게 설명하고 본 개시의 이해를 돕기 위해 특정 예를 제시한 것일 뿐이며, 본 개시의 범위를 한정하고자 하는 것은 아니다. 따라서 본 개시의 범위는 여기에 개시된 실시예들 이외에도 본 개시의 기술적 사상을 바탕으로 도출되는 모든 변경 또는 변형된 형태가 본 개시의 범위에 포함되는 것으로 해석되어야 한다.