출처 : http://blog.naver.com/sealriel/10189298953

 

 

 

OLAP(online analytical processing) 개념

 

OLAP는 쉽게 다차원 분석으로 생각하면 된다. 정의를 내리자면, 최종사용자가 직접 다차원으로 이루어진 데이터로부터 통계적인 요약 정보를 분석하여 의사결정 에 활용하는 방식을 말한다.

 

OLAP 그림출처 : http://118k.tistory.com/66

OLAP 시스템은 데이터 웨어하우스나 데이터 마트와 같은 시스템과 상호 연

관되는 정보 시스템이다.

데이터 웨어하우스가 데이터를 저장하고 관리한다면 OLA P는 데이터 웨어하

우스의 데이터를 전략적인 정보로 변환시키는 역할을한다.

OLAP는 중간 매개체 없이 이용자들이 직접 컴퓨터를 이용하여 데이터에 접

근하는 데 있어 필수적인 시스템이라할수 있다.

 

올해 가장 매출이 저조한 대리점과 저조한 상품 품목은 ?

    서울지역에서 가장 매출이 높은 상품과 순이익이 가장 높은 상품은 ?

    지역별로 전월 대비 매출이 가장 높은 상품은 ?

출처 : http://i-bada.blogspot.kr/2014/01/olap-online-analytical-processing.html

 

 

 

 

OLAP 연산

- Roll-up : 분석할 항목에 대해 한 차원의 계층 구조를 따라 단계적으로 구체적인 내용의 상세 데이터로부터 요약된 형태의 데이터로 접근하는 기능

 

- Drill- down : 분석할 항목에 대해 한 차원의 계층 구조를 따라 단계적으로 요약된 형태의 데이터로부터 구체적인 내용의 상세 데이터로 접근하는 기능

 

 

- Pivoting : 보고서의 행,열,페이지 차원을 바꾸어 볼 수 있는 기능

 

- Slicing : 다차원 데이터 항목들을 다양한 각도에서 조회하고 자유롭게 비교하는 기능

-Dicing : 위와 동일하지만 slicing을 더 쪼개는 형태.

 

OLAP 종류

ROLAP(Relational-OLAP) : 관계형 데이터베이스와 관계형 질의어를 사용하여 다차원 데이터를 저장하고 분석함

MOLAP(Multi- dimension OLAP) : 다차원 데이터를 저장하기 위해 특수한 구조의 다차원 데이터베이스를 사용하고 데이터 검색 속도를 향상시키기 위해 큐브 캐시(Cube Cache )라고 하는 주기억장치 속에 데이터 큐브를 보관함

데이터 큐브는 데이터가 여러차원으로 모델링되는 것으로,차원(Dimension )과 사실(F a c t)로 정의된다. 차원은 한 조직이 그것에 대하여 기록하기를 원하는 시각이나 개체를 의미한다. 또한, 위 그림과 같은 데이터웨어하우스 스키마들을 사용 한다.

 

HOLAP(Hybird OLAP ) : ROLAP와 MOLAP의 특성을 모두 가지고 있으며,빠른 검색이 필요한 경우에는 요약을 메모리에 저장하고 기본 데이터나

다른 요약들은 관계형 데이터베이스에 저장함

그림출처 : http://apandre.wordpress.com/data/datacube/

 

OLAP Cubes

OLAP (online analytical processing) cube on one hand extends a 2-dimensional array (spreadsheet table or array of facts/measures and keys/pointers to dictionaries) to a multidimensional DataCube, a…

apandre.wordpress.com

 

 

 

 

 

 

네이버 쉽게 배우는 소프트웨어 공학

 

http://terms.naver.com/entry.nhn?docId=3533059&cid=58528&categoryId=58528

 

 

 

쉽게 배우는 소프트웨어 공학

CMMI 모델

 

1. CMMI 모델의 등장 배경과 개념

1984년 카네기멜론 대학에 소프트웨어 공학 전문 연구소인 SEI(software engineering institute)가 미 국방성의 지원을 받아 미국 소프트웨어 산업 능력을 향상시킬 목적으로 설립되었다. 미 국방성이 이 연구소에 요청한 것은 소프트웨어를 위한 성숙도 모델의 개발이다. 미 국방성은 수많은 업체로부터 소프트웨어 납품을 받는데 업체마다 품질이 달랐다.

그래서 업체의 개발 능력이 과연 어느 정도인지 객관적으로 측정하고, 요구하는 품질에 대한 기준을 제시해줄 목적으로 요청을 한 것이다. 그 결과 성숙도 모델인 SW-CMM(SW-Capability Maturity Model, 이하 CMM)이 만들어졌다. 이는 프로젝트 개발 조직에서 프로세스 성숙도가 높은 조직이 성숙도가 낮은 조직보다 높은 품질의 소프트웨어를 생산할 수 있다는 모델이다.

CMM은 소프트웨어 공급자의 강점과 약점을 평가하는 수단으로, 개발자가 프로세스의 능력을 스스로 평가하고 평가 결과에 따른 개선 방향을 설정하는 데도 사용되었다. 이 후 여러 모델이 추가 개발되고, 소프트웨어 사용 환경의 변화, 기존 모델 등과의 중복 문제 등을 해결하기 위하여 새로운 모델의 필요성이 대두되었다.

SEI는 소프트웨어 역량 성숙도 모델 CMM 2.0 버전과 SECM(System Engineering Capability Model) 그리고 통합제품개발(integrated product development)-CMM 모델을 통합하고 정리하여 ISO 15504(SPICE)와 호환이 가능한 CMMI라는 통합 모델을 2000년 8월 발표하게 되었다. CMM과 CMMI의 차이는 [표 9-12]와 같다.

표 9-12 CMM과 CMMI의 비교

표 9-12 CMM과 CMMI의 비교
단계 CMM CMMI
1 초기(initial) 초기(initial)
2 반복(repeatable) 관리(managed)
3 정의(defined) 정의(defined)
4 관리(managed) 정량적 관리(quantitatively managed)
5 최적화(optimizing) 최적화(optimizing)

CMMI(Capability Maturity Model Integration)는 프로세스 표준화의 기준과 방향을 제시하므로 조직 프로세스에 대한 측정뿐 아니라 평가 지표로도 활용할 수 있는데, 이때 능력을 평가하거나 성숙도를 평가할 수 있다. CMMI의 각 약자는 다음과 같은 의미를 지닌다.

■ C(능력, Capability)
일반적으로 능력이 있다, 없다는 뭔가를 할 수 있는 힘이 있느냐, 없느냐로 말할 수 있다. 소프트웨어 개발에서 능력이란 개발 목표(주어진 기간, 정해진 비용, 고품질 등)를 달성할 수 있는 힘이다. 능력이 있는 조직은 개발 목표를 달성할 수 있다. 그러나 능력이 없는 조직은 개발 기간이 연장된다거나 비용이 더 추가된다거나 품질이 떨어지는 소프트웨어를 개발함으로써 개발 목표를 달성하지 못한다.

■ M(성숙도, Maturity)
성숙의 사전적 의미는 '생물의 발육이 완전히 이루어짐', '몸과 마음이 자라서 어른스럽게 됨', '경험이나 습관을 쌓아 익숙해짐' 등으로, 다 자라서(완성되어) 책임감이 있는 느낌을 준다. 소프트웨어 개발에서 성숙도가 높은 조직이란 책임감이 있는 조직으로서 사용자가 만족하는 고품질의 소프트웨어를 개발하기 위해 개발 과정에서 객관적이고 정량적인 근거에 따라 프로세스가 측정되고 지속적인 개선이 이루어지는 조직을 말한다.

반면 성숙하지 못한 조직은 책임감이 떨어지는 서투른 조직으로, 개발 프로세스가 객관적인 근거에 의해 진행되지 않기 때문에 사용자가 만족하는 고품질의 소프트웨어가 만들어질 수 없다.

표 9-13 성숙도가 높은 조직과 낮은 조직의 특징

표 9-13 성숙도가 높은 조직과 낮은 조직의 특징
구분 특징
성숙도 높음 • 소프트웨어 개발/관리 프로세스가 조직 차원에서 이루어진다.
• 구성원들이 소프트웨어 프로세스를 잘 알고 있다.
• 프로세스를 따라 수행함으로써 역할과 책임이 명확하다.
• 제품 품질을 중요하게 여기고, 사용자의 만족도를 측정한다.
• 조직 차원의 표준 프로세스가 일관성 있게 준수되고 있다.
성숙도 낮음 • 조직 내에 정해진 프로세스가 없어 필요할 때마다 임시방편으로 만들어 사용하고 있다.
• 문제가 발생했을 때 근본적인 해결 방안을 찾기보다는 임시방편으로 해결하려고 한다.
• 객관적인 비용 산정과 근거에 의한 일정이 산출되지 않아 개발 기간과 비용이 초과하는 경우가 많다.
• 제품 품질에 대해 객관적으로 평가하지 못한다.
• 제품의 기능, 품질보다 납기일을 최우선으로 생각한다.

■ M(모델, Model)
여기서 모델은 일반적으로 알고 있는 모델의 의미와 약간 다르다. 여기서는 프로세스를 감사(audit)하는 의미로 사용한다. 즉 기준대로 하고 있는지, 그렇지 않은지를 검사하는 것이다. CMMI는 그 기준을 제시하고 있는데 그것이 '수행 지침(best practice)'이라는 모델이다. 조직이 프로세스 개선을 원한다면, CMMI는 그 조직이 무엇을 해야 하는지에 대해 '수행 지침'을 통해서 알려준다. 그러나 구체적으로 어떻게 할지는 조직의 역량에 맡겨둔다.

■ I(통합, Integration)
여러 가지 프로세스의 기준을 하나로 통합했다는 의미이다. 소프트웨어 개발 생명주기의 각 단계, 즉 계획부터 유지보수까지 모든 과정을 통합한 모델이라는 의미가 있다.

결국 CMMI는 조직의 프로세스에 대한 가이드이자 기준이며 '능력'과 '성숙도'로 조직의 프로세스를 측정하고 평가하는 모델의 통합 버전인 프로세스 개선 성숙도 모델이라 할 수 있다.

2. CMMI의 구성

CMMI는 개발 조직의 소프트웨어 프로세스 성숙도를 [표 9-14]처럼 5단계로 구분한 후, 각 단계별 목적을 달성하기 위해 [표 9-15]와 같이 4개의 범주로 구분된 22개의 프로세스 영역(PSProcess Area)으로 구성하고 있다.

표 9-14 CMMI 5단계(소프트웨어 프로세스 성숙도)

표 9-14 CMMI 5단계(소프트웨어 프로세스 성숙도)
단계 프로세스 내용
1. 초기(initial) 단계 프로세스 없음 예측/통제 불가능
2. 관리(managed) 단계 규칙화된 프로세스 기본적인 프로젝트 관리 체계 수립
3. 정의(defined) 단계 표준화된 프로세스 조직 차원의 표준 프로세스를 통한 프로젝트 지원
4. 정량적 관리(quantitatively managed) 단계 예측 가능한 프로세스 정량적으로 프로세스가 측정/통제됨
5. 최적화(optimizing) 단계 지속적 개선 프로세스 프로세스 개선 활동

표 9-15 CMMI의 4가지 범주로 구분된 22개의 프로세스 영역

표 9-15 CMMI의 4가지 범주로 구분된 22개의 프로세스 영역
범주 프로세스 영역
프로젝트 관리 프로젝트 계획, 감시, 제어와 관련된 프로젝트 관리 행위들을 다루는 프로세스 영역들로 구성됨.

① 프로젝트 계획(PPproject planning-L2)
② 프로젝트 감시 및 통제(PMCProject Monitoring and Control-L2)
③ 협력 업체 관리(SAMSupplier Agreement Management-L2)
④ 통합된 프로젝트 관리(IPMIntegrated Project Management+IPPD-L3)
IPPDIntegrated Product and Process Development
⑤ 위험 관리(RSKMRisk Management-L3)
⑥ 정량적 프로젝트 관리(QPMQuantitative Project Management-L4)
공학 여러 공학 분야에 걸쳐서 공유되는 개발과 유지보수와 관련된 활동들을 다루는 프로세스 영역들로 구성됨.

⑦ 요구 사항 관리(REQMRequirements Management-L2)
⑧ 요구 사항 개발(RDRequirements Development-L3)
⑨ 기술적 솔루션(TSTechnical Solution-L3)
⑩ 제품 통합(PIProduct Integration-L3)
⑪ 확인(VERVerification-L3)
⑫ 검증(VAL : Validation-L3)
프로세스 관리 프로세스의 정의, 계획, 배치, 구현, 감시, 제어, 평가, 측정, 개선과 관련된 여러 프로젝트에 걸쳐진 활동들을 포함하는 프로세스 영역들로 구성됨.

⑬ 조직 차원의 프로세스 개선(OPFOrganizational Process Focus-L3)
⑭ 조직 차원의 프로세스 정의(OPDOrganizational Process Definition+IPPD-L3)
⑮ 조직 차원의 교육 훈련(OTOrganizational Training-L3)
⑯ 조직 차원의 프로세스 성과 관리(OPPOrganizational Process Performance-L4)
⑰ 조직 차원의 혁신 활동 전개(OIDOrganizational Innovation and Deployment-L5)
지원 제품 개발과 유지보수를 지원하는 활동들을 다루는 내용으로, 프로젝트를 목적으로 한 프로세스 영역과 조직에 적응하는 것을 목적으로 하는 프로세스 영역들로 구성됨.

⑱ 형상 관리(CMConfiguration Management-L2)
⑲ 프로세스/제품 품질 보증(PPQAProcess and Product Quality Assurance-L2)
⑳ 측정 및 분석(MAMeasurement and Analysis-L2)
㉑ 의사결정 분석 및 해결(DARDecision Analysis and Resolution-L3)
㉒ 근본 원인 분석 및 해결(CARCausal Analysis and Resolution-L5)

CMMI는 22개 각각의 프로세스 영역을 만족시키기 위해서 반드시 일반(공통) 목표(GGGeneric Goal)와 세부(구체) 목표(SGSpecific Goal)를 만족시켜야 한다.

■ 일반 목표와 수행 지침
• 목표 : 모든 프로세스 영역에 공통으로 적용되는 목표로서 하나의 프로세스 영역에서 일반적인 목표를 달성했다는 것은 해당 프로세스의 활동들이 조직에 내재화되어 자연스럽게 수행될 수 있음을 의미한다.

• 수행 지침 : 일반적인 목표를 만족시키기 위해 수행해야 하는 활동이 무엇인지를 설명한다.

■ 세부 목표와 수행 지침
• 목표 : 특정 프로세스 영역에만 적용되는 좁은 의미의 구체적인 목표로서 특정 프로세스 영역을 만족시키기 위해서는 반드시 세부적인 목표를 완전히 만족시켜야 한다.

• 수행 지침 : 세부적인 목표를 만족시키기 위해 수행해야 하는 활동이 무엇인지를 설명한다.

각 프로세스 영역의 구성 요소는 3가지 범주로 그룹화되는데, 22개의 프로세스 영역(PA)이 [그림 9-18]과 같은 구조를 따른다. 반드시 달성해야 할 필수 구성 요소에 일반 목표와 세부 목표가 있고, 수행할 것으로 기대되는 예상 구성 요소에는 일반 수행 지침과 세부 수행 지침이 있으며, 정보 제공 측면의 다양한 구성 요소가 있다.

 

 

 

■ 필수 구성 요소
조직이 프로세스 영역을 만족시키기 위해 무엇을 성취해야 하는지를 기술하는 구성 요소이다. 세부 목표와 일반 목표가 이에 해당한다. 목표를 만족시키는 것은 프로세스 영역이 만족되었는지를 결정하기 위한 기반으로 평가 시 사용된다.

■ 예상 구성 요소
조직이 필수 구성 요소를 성취하기 위해 전형적으로 무엇을 구현해야 하는지를 기술하는 구성 요소이다. 이 구성 요소들은 누가 평가를 수행하고 개선을 구현하는지를 가이드한다. 일반 수행 지침과 세부 수행 지침이 이에 해당된다.

■ 정보 제공 구성 요소
필수 구성 요소와 예상 구성 요소에 접근할 수 있도록 돕는 세부 내용을 제공한다. 예제 작업 산출물, 하위 지침, 일반 수행 지침의 정책, 입문 노트, 관련 프로세스 영역 등이 이에 해당된다.

 

 

3. CMMI의 평가 방법

CMMI 평가는 단계적 표현(staged representation) 방법의 성숙 단계(maturity level)와 연속적 표현(continuousrepresentation) 방법의 능력 단계(capability level)로 나누어 이루어진다.

 

4. 단계적 표현 방법의 성숙 단계

성숙 단계는 조직에서 해당 업무를 얼마나 체계적으로 수행하고 있는지를 나타내며, 지표로는 1에서 5까지 5단계로 구분하여 사용하고 있다.

CMMI 성숙 단계는 [표 9-16]과 같이 단계별로 충족되어야 하는 프로세스 영역이 정의되어 있고, [그림 9-21]처럼 계단형으로 구성되어 단계적 표현 방법이라고도 한다. 그리고 각 단계의 프로세스 영역을 모두 만족하면 다음 단계로 넘어간다. 예들 들어, 정의 단계는 관리 단계의 프로세스 영역을 모두 만족하고, 정의 단계의 프로세스 영역까지 모두 만족한다는 의미이다.

표 9-16 성숙도 단계별 프로세스 영역

표 9-16 성숙도 단계별 프로세스 영역
단계 범주 프로세스 영역
1. 초기 단계 프로세스 없음
2. 관리 단계 프로젝트별로 프로세스 존재 • 요구 사항 관리
• 프로젝트 계획 수립
• 프로젝트 감시 및 통제
• 협력 업체 관리
• 측정 및 분석
• 프로세스/제품 품질 보증
• 형상 관리
3. 정의 단계 조직 차원의 프로세스 존재(프로세스 표준화) • 요구 사항 개발
• 기술적 솔루션
• 제품 통합
• 검증, 확인
• 조직 차원의 프로세스 개선
• 조직 차원의 프로세스 정의
• 조직 차원의 교육 훈련
• 통합된 프로젝트 관리
• 위험 관리
• 의사결정 분석 및 해결
4. 정량적 관리 단계 측정 가능한 정량적 프로세스 존재 • 조직 차원의 프로세스 성과 관리
• 정량적 프로젝트 관리
5. 최적화 단계 프로세스를 지속적으로 개선 • 조직 차원의 혁신 활동 전개
• 근본 원인 분석 및 해결
 
 

5. 연속적 표현 방법의 능력 단계

능력 단계에 대한 이해를 돕기 위해 성숙 단계와 같은 예를 사용해보자. 연속적 표현 방법의 능력 단계는 국어(80점), 수학(90점), 영어(70점), 과학(85점), 사회(78점)의 각 과목별 등급을 정하는 것이다. 즉 능력 단계는 프로세스 영역 능력 수준을 측정하는 연속적 표현 모델로, 해당 조직의 각 프로세스 영역에 대한 능력이 얼마나 되는지를 나타낸다.

능력 단계는 프로세스 영역별 능력 수준을 확인함으로써 어떤 영역이 잘되고, 어떤 영역의 능력이 떨어지는지를 살펴 보완할 부분을 파악하기도 한다.

이렇게 프로세스 영역별 능력 수준을 점검하면 어떤 프로세스 영역이 다른 프로세스 영역에 비해 떨어지는지 알 수 있으므로 그 영역만 집중적으로 관리할 수 있다. 또 중요하다고 생각하는 프로세스 영역에 대해서는 그 수준을 높이기 위해 더 많은 자원을 투입하여 능력 수준을 높일 수 있다. 앞에서 든 비유로 설명한다면, 과학 과목이 다른 과목보다 성적이 낮은 경우 과학 과목을 열심히 공부해서 점수를 올리고, 수학이 중요하다고 생각하면 다른 과목보다 수학을 집중적으로 공부하여 수학 실력을 향상시킬 수 있는 것과 같다.

[네이버 지식백과] CMMI 모델 (쉽게 배우는 소프트웨어 공학, 2015. 11. 30., 한빛아카데미(주))

 

 

 

'ITPE > SE' 카테고리의 다른 글

소프트웨어 테스팅 국제표준 - ISO 29119  (0) 2021.02.19
TOC-Thinking Process  (0) 2018.04.06
단위 테스트 및 통합테스트  (0) 2018.02.22

 

 

 

 

출처 : https://blog.naver.com/jhlee1026200/20139655031

 

 

* Thinking Process

 

1. 정의

기업의 의사결정에 있어서 부서,조직간의 복잡하게 얽힌 문제들로 인해서 대립이 생기고 결국 논의자체도 진행되지 못하는 상황을 개선시키위해 근본원인을 찾아 이를 극복할 수 있는 혁신적인 방안을 도출하고 하기와 같은 일련의 과정을 논리적으로 파악해 나감.

-. 무엇을 어떻게 바꿀것인가? (What to do change?) – 흐름을 막는 제약과 핵심문제를 찾음

-. 무엇으로 바꿀것인가? (What to change to?) – 전체 흐름량을 최대화

-. 어떻게 바꿀것인가? (How to cause the change?) – 핵심문제를 해결하고 제약흐름을 최대화

등과 같은 일련의 과정을 논리적으로 파악해 나감.

 

2. 6가지도구

-. CRT : Current Reality Tree (현재 상황나무)

-. Cloud (Core Conflict Cloud : 대립의 중심)

-. EC : Evaporating Cloud (갈등해소를 위한 해결책 주입)

-. FRT : Future Reality Tree (미래 상황나무)

-. PT : PreRequisite Tree (전제 조건나무)

-. TT : Transition Tree (실행 계획 나무)

* CRT (문제점 열거, 인과관계 파악, 문제점 도출) -> UDE : 바람직하지 않은 결과 (CRT에서의 문제점 들) -> Cloud (문제원인, 모순, 대립 해소하기 위한 수단) -> FRT (Cloud의 문제해결책의 검증) -> NB : 부정적 가지 (Cloud의 대립해소 아이디어 실행 시, 새롭게 발생하는 문제) -> PT (어떻게 바꿀것인가?에 대한 수단, 목표달성과정의 장애와 극복을 위한 중간목표 전개) -> TT (PT의 중간목표 달성을 위한 필요행동)

 

 

 

++ 참조자료 : Thinking Process Sample

 

 

 

 

'ITPE > SE' 카테고리의 다른 글

소프트웨어 테스팅 국제표준 - ISO 29119  (0) 2021.02.19
CMMI  (0) 2018.04.12
단위 테스트 및 통합테스트  (0) 2018.02.22

 

 

 

 

데이터베이스에서의 무결성..




데이터 무결성과 릴레이션 무결성으로 구분

 

[정의] 데이터를 인가되지 않은 방법으로 변경할 수 없도록 보호하는 성질. 

 

[분류] 데이터 무결성과 릴레이션 무결성으로 구분
1. 데이터 무결성
- 개체 무결성
- 참조 무결성 : [규칙] 입력규칙(자식): Dependant, Nullify, Default // 삭제규칙(부모): Restrict, Cascade, Nullify, Default
- 속성(도메인)무결성 : [규칙] Unique, Not null, check, 기본키, 외래키
- 사용자 정의 무결성
- 키 무결성

 

 

 


2. 릴레이션 무결성 : 릴레이션을 조작하는 과정에서 의미적 관계를 명세, 삽입/삭제/갱신과 같은 연산을 수행하기 전과 후에 대한 상태에 대한 정확성 보장
  - [제약유형]
   - 상태제약(parent.family_nm=child.family_nm) :데이터베이스가 일관성 있는 상태가 되기 위한 조건 명세.
   - 과도제약(emp.newsal > emp.oldsal) : 데이터베이스의 한 상태에서 다른 상태로 변환되는 과정에서 적용되는 규칙.
   - 집합제약(avg(emp.sal)>600) : 튜플집합 전체에 관련되어 적용되는 규칙
   - 튜플제약(updating emp.sal; sal>5000) : 처리되고 있는 튜플에만 적용되는 규칙
   - 즉시제약(updating emp.sex; sex='M' or sex='F') : 연산이 수행되는 즉시 적용되는 규칙
   - 지연제약(When commit : check((a+b) > 0)  : 트렌젝션완전히 수행후 적용되는 규칙


[릴레이션 무결성을 DB 구현하는 방법]
1) 무결성 제약조건 활용 : DBA가 DCL을 이용하여 무결성 제약조건을 명시적으로 기술
2) 트리거 활용 : 트리거는 DB가 특정 상태에 도달하면 자동으로 작동
3) 저장 프로시저 활용 : 저장 프로시저를 사용해 데이터에 대한 접근을 제어. (저장 프로시저는 SQL과 SPL 언어를 조합해 만든 프로시저)
4) 데이터베이스 응용프로그램 활용 : 데이터베이스의 응용프로그램 코드에 업무규칙을 강제로 시행.
5) DBMS기능 활용 : ACID 보장 위한 동시성 제어 기능, 회복/복구 기능, 보안기능 등.

 

 

 

 

 

'ITPE > DB' 카테고리의 다른 글

데이터 모델링  (0) 2021.03.06
ARIES (Algorithms for Recovery and Isolation Exploiting Semantics)  (0) 2021.03.06
MVCC (MultiVersion concurrency control)  (0) 2021.03.06
Timestamp Ordering  (0) 2021.03.06
낙관적 검증(Validation)  (0) 2021.03.06

 

 

출처 : http://www.hardcopyworld.com/gnuboard5/bbs/board.php?bo_table=lecture_rpi&wr_id=60

 

 

 

 

 

 

홈 오토메이션과 센서 네트웍 관련 자료들을 찾다보니 MQTT 프로토콜이 자주 등장하더군요. 좀 더 세부적으로 살펴보니 여러모로 유용한 것 같아 자료들을 정리해 봤습니다. 실제 테스트도 가능하도록 예제도 첨부했습니다.

MQTT(MQ Telemetry Transport)는 아두이노나 라즈베리파이 같은 임베디드 장치간 통신을 위한 가벼운 메시징 프로토콜입니다. TCP/IP 기반으로 대역폭이 작은 네트워크에서 동작할 수 있도록 설계된 프로토콜입니다. 쉽게 얘기해서 임베디드 장치들을 위한 트위터라고 볼 수 있습니다.

MQTT 자체는 메시지를 어떻게 보낼 것인지를 정의하는 규약일 뿐입니다. 따라서 실제 MQTT 트위터를 동작시키기 위해서는 서버 역할을 해주는 장치(프로그램)가 필요한데 이를 MQTT 브로커(Broker)라고 합니다. MQTT 브로커는 각종 장치들(MQTT Client)이 보내주는 메시지를 수집하고 이걸 다시 필요한 장치들에게 전송해주는 중계서버 역할을 합니다.

MQTT 클라이언트는 브로커에게 메시지를 전달하고 필요한 메시지를 받기만 하면 되고 MQTT 프로토콜의 구조도 간단하기 때문에 처리능력이 낮은 임베디드 장치에 잘 어울립니다. 메시지는 트위터처럼 140자 제한이 없으므로 긴 메시지나 JSON 포맷 또는 파일도 전송이 가능합니다. 이런 특징들 때문에 MQTT 프로토콜은 센서 네트웍을 구성하는데 유용한 도구로 관심을 받고 있습니다.

 

 

MQTT 동작 구조 (PUB/SUB)

 

트위터 서비스의 동작구조를 떠올려보세요. 트위터에서 사용자는 다른 사용자를 follow 할 수 있습니다. 그럼 다른 사용자가 생성하는 메시지(트윗)를 받아볼 수 있죠. 그리고 스스로 메시지를 생성할 수도 있습니다. 그럼 자신을 follow하는 사용자에게 메시지가 전달되죠.

MQTT도 거의 유사한 동작구조를 갖습니다. MQTT 시스템에 참여하는 MQTT 클라이언트는 메시지 발행(publish, 트윗에 해당), 메시지 구독(subscribe, follow에 해당) 두 가지 동작을 할 수 있습니다. MQTT 클라이언트가 메시지를 특정 채널(Topic, 토픽)에 발행하면 이 채널을 구독한 모든 클라이언트에게 메시지가 전달되는 겁니다. 중간에서 메시지를 수집, 재분해 하는 작업은 MQTT 브로커가 담당합니다.

 

0912embmqtt01

 

 

토픽

 

메시지를 발행/구독(pub/sub) 하는 행위는 채널 단위로 일어납니다. 이를 MQTT에서는 토픽(Topic)이라고 합니다. 토픽은 슬래시(/)로 구분된 계층구조를 갖습니다.

topic_basics

메시지를 구독/발행 할 때 여러개의 토픽을 한번에 지정할 수 있도록 wild card 문자를 지원합니다. [+] 문자는 단 1개의(1 레벨) 토픽을 임의의 토픽으로 대체하는 와일드카드 문자입니다.

topic_wildcard_plus

반면 [#] 문자는 여러 레벨의 토픽을 대체할 수 있습니다. [myhome/#] 처럼 사용하면 myhome 의 하위 토픽들 모두를 지칭하게 됩니다. [#] 문자는 토픽 문자열 끝에만 사용할 수 있으며 하위 토픽 모두를 지칭합니다. (2단계 이상 하위 토픽도 포함)

topic_wildcard_hash

[$] 문자로 시작하는 토픽은 시스템에 의해 사용되는 특수한 토픽을 의미합니다. 이 토픽들은 [#] 문자열로 지정해도 포함되지 않는 토픽이 됩니다. 주로 [$SYS/] 로 시작하는 토픽들이 브로커의 내부 메시지를 위해 사용됩니다. (이에 대한 명확한 표준은 없는 상태인듯)

토픽 구조를 구성할 때 몇 가지 주의할 점이 있습니다.

  • 최상위 토픽이 [/] 문자로 시작하지 않도록 합니다. [/home/sensor/humid] 이렇게 사용할 수는 있지만 최상위 토픽이 이름이 없는 토픽이 되므로 사용하지 않는 것을 권장합니다.
  • 토픽 이름에 공백을 사용하지 않습니다.
  • 토픽 이름은 ASCII 문자만 사용합니다. (임베디드 장치와의 호환성을 위해 주의)
  • [#] 를 이용해서 토픽 전체를 구독하지 않도록 합니다. 오버헤드가 심할 경우 브로커/클라이언트 프로세스가 중단될 수 있습니다.

 

 

QOS (QUALITY OF SERVICE)

 

MQTT는 시스템에 참여하는 장치들의 처리 능력, 네트워크 대역폭, 메시지 오버헤드 등 주변상황에 맞게 시스템이 동작할 수 있도록 3단계 QoS(Quality of Service) 를 제공합니다.

  • 0 : 메시지는 한번만 전달하며, 전달여부를 확인하지 않는다. Fire and Forget 타입이다.
  • 1 : 메시지는 반드시 한번 이상 전달된다. 하지만 메시지의 핸드셰이킹 과정을 엄밀하게 추적하지 않기 때문에, 중복전송될 수도 있다.
  • 2 : 메시지는 한번만 전달된다. 메시지의 핸드셰이킹 과정을 추적한다. 높은 품질을 보장하지만 성능의 희생이 따른다.

0에 가까울수록 메시지 처리에 대한 부하가 적은 대신 메시지 손실 위험이 높아집니다. 2에 가까울수록 메시지 손실 위험은 줄어들지만 메시지 처리 부하가 급격히 늘어납니다.

(보통 0~1 정도의 QoS를 사용하면서 메시지 손실등의 위험은 상위 어플리케이션 차원에서 관리하도록 하는듯 합니다.)

 

 

MQTT 브로커

 

MQTT 시스템의 핵심 서버 역할을 하며,  여기에 메시지가 수집되고 다시 재분배 됩니다. 다양한 MQTT 브로커 프로그램들이 개발되어 있는데 ActiveMQ, Apollo, IBM Message SightJoramMQMosquittoRabbitMQSolace Message Routers 등이 자주 사용됩니다. 아래 링크에 MQTT 브로커의 특징을 비교한 자료가 있습니다.

여기서는 Mosquitto 브로커를 사용할 것입니다. Mosquitto는 MQTT의 기본 기능을 충실히 지원하는 가벼운 MQTT 브로커 프로그램입니다. Mosquitto 클라이언트 프로그램도 있으므로 여러대의 PC를 이용해서 테스트를 할 수 있습니다.

mosquitto

 

 

MQTT 동작 테스트

 

홈 오토메이션이나 센서 네트워크를 구성하기에는 라즈베리파이같은 손바닥 PC가 제격입니다. 여기서는 MQTT 동작 테스트를 위해 PC와 라즈베리파이에 Mosquitto MQTT 클라이언트, 브로커를 설치할 것입니다.

라즈베리파이에 Mosquitto 브로커를 설치하는 작업부터 시작합니다. Mosquitto 는 apt-get 명령어를 통해 간단히 설치할 수도 있지만 업데이트가 되지 않는 문제점이 보고되고 있습니다. 아래 순서로 설치하길 권장합니다. (최신 소스코드를 다운로드 받아 설치하실땐 링크를 참고하세요.)

  • wget http://repo.mosquitto.org/debian/mosquitto-repo.gpg.key
  • sudo apt-key add mosquitto-repo.gpg.key
  • cd /etc/apt/sources.list.d/
  • sudo wget http://repo.mosquitto.org/debian/mosquitto-wheezy.list
  • sudo apt-get install mosquitto

설치가 완료되면 브로커는 1883 포트를 사용하게 됩니다.

 

이제 PC와 모바일 폰에 MQTT 클라이언트를 설치해서 연동을 해보겠습니다. PC(Windows, Linux, OS X)에서는 MQTT.fx 클라이언트를 설치하면 됩니다. 아래 링크에서 프로그램을 받을 수 있습니다.

MQTT.fx 클라이언트는 윈도우 64비트만 지원합니다. 이 문제 때문에 설치가 안된다면 크롬 브라우저의 확장 앱으로 설치해서 사용하는 방법도 있습니다. 크롬 브라우저에서 아래 링크를 통해 설치할 수 있습니다.

모바일 폰에서는 앱 스토어에서 MQTT로 검색하시면 됩니다. 다양한 클라이언트가 등록되어 있는데 대부분 비슷하므로 아무거나 사용하셔도 됩니다. 유명한 MQTT 클라이언트들은 링크에서 확인하실 수 있습니다.

 

설정 방법은 간단합니다. 아래 항목들만 정확히 설정해 주면 됩니다.

  • MQTT 브로커 URL : MQTT 브로커를 설치한 서버의 URL 입니다.
  • Port : 앞서 설치한 Mosquitto 브로커는 기본 1883 포트를 사용합니다.
  • Username / Password : 지금은 설정하지 않아도 됩니다.

테스트를 위해 클라이언트에서 subscribe 버튼을 누르고 토픽에 messagebox를 입력합니다. 그럼 messagebox 토픽이 생성되고 구독이 됩니다. PC, 모바일 등 모든 장치에서 같은 작업을 해줍니다.

이제 PC, 모바일에서 publish 를 합니다. 이때 토픽은 messagebox로 선택합니다. 그럼 입력한 메시지가 브로커로 전달되고 messagebox 토픽을 구독하는 다른 장치들에도 전달되어야 합니다. 제대로 동작하는지 확인해보세요.

 

MQTT 브로커를 설치한 라즈베리파이에 MQTT 클라이언트를 설치해서 확인할 수도 있습니다.

  • apt-get install mosquitto-clients

아래 명령으로 메시지 발행(pub)을 할 수 있습니다. 다른 기기에도 메시지가 보여야겠죠.

  • mosquitto_pub -d -t messagebox -m "sent from RPi server"

특정 토픽을 구독(sub) 할 수 있습니다. 이 경우 특정 토픽에 메시지가 도착 할 때마다 표시됩니다. Ctrl+c 를 눌러 멈추기 전까지는 메시지 표시하는 상태로 유지됩니다.

  • mosquitto_sub -d -t messagebox

 

 

MQTT - IOT 장치 만들기

 

앞선 MQTT 테스트는 단순한 메시지를 공유하는 일종의 채팅 예제였습니다. 여기서 메시지 내용만 원하는대로 바꿔서 사용하면 센서 네트웍, 홈 오토메이션에도 MQTT가 메시지 전송 프로토콜로 활용될 수 있음을 알 수 있습니다. 여기서는 IoT 장치를 직접 만들기 위해서 마이크로 컨트롤러에 MQTT를 이식하고 메시지를 전달하는 예제를 만들어 보겠습니다.

예제 장치를 만들기 위해 아래와 같은 모듈들이 필요합니다.

  • ESP8266 - NodeMCU (ESP12E 기반) 보드
  • DHT22 (온습도 측정용 센서)
  • I2C 128x64 OLED (옵션, 현재 상태와 송수신 메시지 표시용, 반드시 SSD1306 드라이버 칩을 사용한 모듈 필요)

esp8266_title

ESP8266 - NodeMCU (ESP12E 기반) 보드

가성비와 활용성 면에서 최고의 평가를 받는 ESP8266 WiFi 모듈을 마이크로 컨트롤러로 사용합니다. 여기서는 모듈에 올라갈 펌웨어 작성을 위해서 Sming 개발환경을 사용할 예정인데, ESP8266 Arduino IDE로 작성하는 것도 가능합니다.

먼저 모듈들을 연결을 해줘야겠죠. ESP8266과 DHT22은 아래 순서로 연결합니다.

  • ESP8266 --> DHT22
  • 3V --> VCC
  • GND --> GND
  • D5(GPIO14) --> DAT

ESP8266 에 OLED 디스플레이도 연결합니다.

  • ESP8266 --> OLED
  • 3V --> VCC
  • GND --> GND
  • D3(GPIO0) --> SCL
  • D4(GPIO2) --> SDA

 

모듈 연결이 끝나면 ESP8266에 올라갈 펌웨어를 만들어야 합니다. Eclipse 기반 Sming 개발환경을 구축하면 MQTT client 예제 파일도 같이 설치됩니다. 이걸 수정해서 DHT22 센서로 온습도를 측정하고 MQTT broker로 전송하도록 만들었습니다. 아래 링크에서 소스코드를 구하실 수 있습니다.

소스에서 몇 가지를 수정해줘야 합니다. 공유기 ID(SSID)와 PASSWORD, 센서값을 전송할 간격, 토픽의 이름(여기서는 messagebox  토픽 사용) 입니다.

...... #ifndef WIFI_SSID 	#define WIFI_SSID "your_ssid" // Put you SSID and Password here 	#define WIFI_PWD "your_password" #endif ...... MqttClient mqtt("your_mqtt_server.com", 1883, onMessageReceived); ...... 	mqtt.publish("your_topic", message); // or publishWithQoS ...... 	mqtt.subscribe("your_topic"); ......

 

소스가 수정되면 컴파일을 하고, 생성된 펌웨어를 MSP8266 모듈에 올려 구동하면 정해진 시간 간격마다 MQTT 메시지를 전송합니다. PC, Mobile 폰에서 messagebox 토픽에 해당 메시지가 들어오는지 확인하면 되겠죠.

그리고 반대로 PC, Mobile 폰에서 messagebox 토픽에 메시지를 생성(publish)하면 ESP8266 모듈의 디스플레이에 표시되어야 합니다.

mqtt_exam

메시지가 정상적으로 표시된다면 기본적인 수준의 IoT 장치가 완성된 것입니다!! 이걸 응용하면 IoT 장치를 인터넷 서비스와 연동하는데 사용할 수 있습니다.

 

 

 

 

HOME-ASSISTANT 홈 오토메이션 서버와 연동

 

MQTT 프로토콜은 단순히 메시지/데이터를 전송하는데 사용되는 규약일 뿐입니다. 대신 MQTT broker/client, 라이브러리를 통해 송수신된 데이터를 처리하는 도구를 풍부하게 제공합니다. MQTT로 전송하는 메시지가 무엇인가는 전혀 관여하지 않습니다. 전송되는 데이터 자체를 어떻게 처리할 것인가는 서비스 개발자의 몫입니다.

따라서 센서 네트웍, 홈 오토메이션에 MQTT 를 사용하더라도 전달되는 데이터를 어떤 형식으로 보낼 것인지는 직접 정의해야 합니다. 이런 작업을 직접 다 하기에는 고려해야 할 점도 많고 구현도 힘들기 때문에 오픈소스로 표준화/공개된 솔루션을 사용할 수 있습니다. 여기서는 Home-assistant 라는 홈 오토메이션 솔루션을 이용해 우리가 만든 IoT 장치를 연동해 보도록 하겠습니다.

홈 어시스턴트 서버를 설치하고 설정하는 방법은 아래 링크에서 다루고 있습니다.

 

앞서 ESP8266 보드로 만든 장치를 다시 이용하도록 하겠습니다. 대신 소스코드에 약간의 수정이 필요합니다.

void publishMessage() { 	...... 	// Make JSON data 	String message = "{\"temp\":"; 	message += th.temp; 	message += ", \"humi\":"; 	message += th.humid; 	message += "}";  	// publish message 	Serial.println("Let's publish message now!"); 	mqtt.publish("home/thirdroom/temp_humi", message, true); // retained message 	...... }

앞서와 다른 점은 데이터를 보낼 때 JSON 형식으로 보낸다는 겁니다. 예를 들어 온도 23.11', 습도 68.35%를 보낼 때 아래처럼 보냅니다.

{"temp": 23.11, "humi": 68.35}

그리고 이 데이터는 [home/thirdroom/temp_humi] 토픽으로 전송합니다. 마지막에 true 파라미터가 붙은건 마지막 데이터를 저장했다가 새로 구독(subscribe)하는 기기가 있으면 보내주기 위한 retained message 기능입니다.

홈 어시스턴트 서버에서는 [home/thirdroom/temp_humi] 토픽을 구독하면서 새로운 업데이트가 생겼을 때 JSON 데이터를 파싱하면 됩니다. 홈 어시스턴트 설정파일인 [configuration.yaml] 파일에서 아래와 같이 설정해주면 됩니다.

sensor 3:   platform: mqtt   state_topic: "home/thirdroom/temp_humi"   name: "Thirdroom Humidity"   qos: 0   unit_of_measurement: "%"   value_template: '{{ value_json.humi }}'  sensor 4:   platform: mqtt   state_topic: "home/thirdroom/temp_humi"   name: "Thirdroom Temperature"   qos: 0   unit_of_measurement: "°C"   value_template: '{{ value_json.temp }}'

[home/thirdroom/temp_humi] 토픽을 구독하면서 데이터가 도착하면 humi, temp 변수를 찾아 그 안에 할당된 값을 추출합니다. 정상적으로 동작하면 홈 어시스턴트 웹 페이지에서 아래처럼 보이게 됩니다.

ha_mqtt_device

 

 

OPENHAB 홈 오토메이션 서버와 연동

 

openHAB 도 홈 어시스턴트와 같은 컨셉을 가진 홈 오토메이션 서버입니다. 아래에 설명하는 과정은 openHAB 홈 오토메이션 서버에 MQTT 브로커를 연동해서 센서값을 보여주는 방법입니다. 여기서는 이미 openHAB이 설치된 리눅스 서버가 있다는 가정하에 진행하겠습니다. 라즈베리파이에 openHAB 서버 설치는 링크의 내용을 참고하세요.

 

openHAB 서버가 MQTT 브로커와 연결되기 위해서는 전용 add-on 을 설치해야 합니다.

  • sudo apt-get install openhab-addon-binding-mqtt
  • sudo chown -R openhab:openhab /usr/share/openhab

openHAB 설정 파일을 수정해줍니다.

  • sudo nano /usr/share/openhab/configurations/openhab.cfg

아래 내용을 추가

mqtt:broker.url=tcp://localhost:1883 mqtt:broker.clientId=openhab

openHAB 재실행

  • sudo service openhab restart

 

MQTT 로 들어온 메시지가 연결될 Number item 추가 작업

(이하 내용 작성 중...)

참고 링크

 

 

 

 

참고자료

아두이노와 Ethernet 모듈을 이용한 센서 장치 만들기

 

 

 

'ITPE > NW' 카테고리의 다른 글

NDN  (0) 2018.02.26
 
oo
 
출처 : http://www.kpubs.org/article/articleMain.kpubs?articleANo=MTMDCW_2016_v19n2_291
 
 
1. 서 론
 

초기 인터넷의 주요 개발 목적은 원격 호스트들 사이의 안전한 네트워크 연결을 제공하는 것이었다. 그러므로 현재와 같은 멀티미디어 데이터 전송 증가로 인한 잦은 네트워크 병목현상, 취약한 보안으로 인한 심각한 침해 사고, 호스트의 빈번한 이동으로 인한 비효율성과 같은 다양한 문제점들과 그 해결 방안을 고려하지 않았다 [1] . 특히, 다양한 스마트 IT 융복합 서비스의 증가는 이와 같은 문제점들을 더욱 심화시킬 수 있으며, 인터넷의 기존 문제점들은 IT 융복합 서비스의 저변확대를 방해하는 주요 요인이 될 수 있다. 그러므로 이와 같은 문제들을 해결하고 인터넷을 통하여 다양한 데이터 및 정보를 보다 효과적으로 지원하기 위한 미래 인터넷 기술 연구가 여러 방향으로 진행되고 있다 [2 - 4] . 특히, 미래 인터넷 기술 중 하나인 정보 중심의 네트워킹 기술(Information Centric Networking, ICN)은 데이터 소스에게 집중되는 데이터 요청 메시지를 효율적으로 분산 처리하기 위하여 멀티미디어 프락시 시스템(Multimedia Proxy System)이나 네트워크 기기 (Network Node)에 데이터를 임시 저장한 후, 데이터 소스를 대신하여 이들 기기들이 데이터 요청 메시지를 직접 처리하는 기술을 제공하고 있다.

 

ICN 기술 중 하나인 데이터 이름 기반 네트워킹(Named-Data Networking, NDN)은 데이터의 계층화된 고유 이름에 기반 한 패킷 전송과 네트워크 기기에 데이터 임시 저장 기능(Caching)을 구현하여 효과적으로 데이터를 전송할 수 있도록 설계되었다 [3 , 4] . 기본적으로 네트워크 노드에 저장된 데이터를 이용하여 네트워크의 효율성을 높이고 있기 때문에 캐싱되는 데이터의 종류와 데이터를 캐싱하는 네트워크 노드의 네트워크 토폴로지 상에서 위치가 NDN의 성능에 매우 큰 영향을 미친다.

 

본 논문에서는 데이터의 이용 빈도를 기반으로 데이터 캐싱 노드를 선택/운영하는 NDN 데이터 캐싱 기법들을 살펴보고, 캐싱 기법의 성능 개선을 위하여 네트워크 토폴로지 상에서의 노드별 캐싱 이용률을 관찰하고, 관찰 결과를 토대로 개선된 NDN 캐싱 기법을 제안한다.

 
 
2. NDN Overview
 

인터넷의 성능 향상을 위하여 제안된 NDN은 다음과 같은 특징을 갖고 있다:

 

(1) 데이터의 고유 이름 기반의 패킷 포워딩

 

(2) 중간 네트워크 노드에서의 데이터 캐싱 및 포워딩

 

(3) 전자 서명 기반의 데이터 인증

 

또한, 이와 같은 특징을 구현하기 위하여 NDN은 다음과 같은 추가적인 요소들을 정의 한다:

 

(1) FIB (Fowarding Information Base) 테이블: 데이터 요청 메시지(Interest)에 포함되어 있는 데이터 이름/식별자를 기반으로 해당 Interest를 포워딩 할 전송 인터페이스 (Face)를 결정할 때 필요한 정보를 제공한다.

 

2) PIT (Pending Interest Table): 응답 메시지(Data) 수신 시, 해당 Data를 사용자들에게 전송하기 위하여, 수신된 Interest와 incoming Face 정보를 기록/관리한다.

 

(3) 네트워크 캐쉬 (Content Store, CS): 수신된 Data를 임시 저장한다.

 

(4) 데이터 서명 및 검증: 전송되는 Data는 각각 처음 Data를 생성한 생성자(Publisher)의 전자 서명을 포함하고 있으며, 수신자는 이 전자 서명 값을 이용하여 Publisher와 데이터 위/변조 여부를 확인한다.

 

Fig. 1 은 NDN의 Interest와 Data 처리 절차를 설명한다.

 
Fig. 1.
 
PPT Slide
Lager Image
 
NDN Interest/Data Forwarding Process.
 

(1) 수신 노드의 인터페이스 (예를 들어, Face 0)로 Interest를 수신한다.

 

(2) Interest에 해당하는 Data를 CS에 저장하고 있는지 여부를 확인한다. 만약 해당 Data를 저장하고 있다면, 저장하고 있는 Data를 Face 0를 통하여 전송한 후, Interest 처리를 완료한다.

 

(3) Interest에 해당하는 entry가 PIT에 이미 존재하는지 확인하다. 만약 대응되는 entry가 PIT에 존재한다면, 해당 entry에 Interest의 유입 Face (Face 0)를 추가한 후, Interest 처리를 완료한다.

 

(4) FIB 테이블을 참조하여, Interest를 포워딩할 Face (예를 들어, Face 2)를 선택한다.

 

(5) PIT에 Interest를 위한 새로운 entry를 추가한다.

 

(6) 4단계에서 선택된 Face로 Interest를 전송한 후, Interest 처리 절차를 완료한다.

 

(7) 이 후, 노드의 인터페이스 (Face 2)로 Data를 수신한다.

 

(8) 수신 된 Data에 해당하는 entry가 PIT에 존재하는지 확인한다. 만약 해당 entry가 PIT에 존재하지 않는다면, 수신된 Data를 폐기한 후, 처리 절차를 종료한다.

 

(9) Data를 CS에 저장한다.

 

(10) 단계 8에서 검색된 entry에 기록되어 있는 Face들로 Data를 전송한 후, 해당 entry를 PIT에서 삭제한다.

 
 
 
 
oo
 
3. NDN 캐쉬 관리 기술
 

기본적인 NDN은 전송되는 모든 데이터를 전송 경로상의 모든 네트워크 노드에 저장한 후, 이를 이용하여 네트워크 성능을 향상시킬 수 있음을 보여주고 있다. 그러나 전송되는 모든 데이터를 캐싱할 경우, 각 노드마다 데이터 캐싱을 위해 대용량의 CS를 운영해야 한다. 또한, 이와 같은 대용량의 CS 운영은 저장 공간에 대한 오버해드 뿐만 아니라, Interest를 수신할 때마다 저장된 많은 수의 데이터를 매번 검색해야 하기 때문에 전체적인 응답 시간을 지연시킬 수 있다. 그러므로 전송되는 모든 데이터를 모든 노드가 저장하는 것은 매우 비효율적이다. 이와 같은 문제를 해결하기 위하여 데이터의 이용 빈도에 따라 캐싱 노드를 선택/운영하는 다양한 기법들이 다음과 같이 제안되었다 [5 - 9] .

 

(1) LCD: 임의의 노드가 저장하고 있는 데이터에 대한 Interest를 수신하여, 해당 데이터를 전송하는 경우, 해당 데이터의 전송 경로 위에 있는 노드들 중에서 첫 번째로 데이터를 수신한 노드만 해당 데이터를 캐싱 한다. 즉, 전송 경로 위에 있는 나머지 노드들은 데이터를 캐싱 하지 않고 전송만한다.그림 2 -(A)는 LCD의 운영 방법을 설명한다. 데이터를 저장하고 있는 Source가 Interest를 수신하면, Interest의 전송경로의 반대 방향을 따라 Data가 전송될 때, Source와 직접 연결된 A-Node만 Data를 캐싱 한다. 이 후, 해당 데이터를 요청하는 Interest를 A-Node가 수신하면, Data 전송 경로 위에 있는 노드 중에서 ANode와 직접 연결된 B-Node만 Data를 캐싱 한다. 이와 같은 캐싱 정책을 구현할 때, 데이터의 요청 빈도에 따라 데이터를 캐싱 하는 노드의 수를 점진적으로 증가시킬 수 있으며, 요청 빈도가 높은 데이터의 경우 사용자가 포함된 네트워크 (Edge Network)의 노드에 캐싱 된다.

 
Fig. 2
 

PPT Slide
Lager Image
 
NDN Cache Management Schemes.
 

(2) MCD: LCD는 데이터를 캐싱하는 노드의 수를 점진적으로 늘려간다. 그러나 Interest 전송 경로의 제일 앞단에 위치한 노드에 데이터가 캐싱되어 있는 경우, 전송 경로 상에서 해당 노드보다 뒤에 위치한 노드들에 캐싱된 데이터는 사용되지 않는다. 즉, 사용되지 않는 불필요한 데이터 캐싱이 발생하게 된다. 이와 같은 문제를 해결하기 위해서 MCD는 데이터의 이용 빈도에 따라 데이터를 캐싱하는 노드를 사용자의 Edge Network 방향으로 점진적으로 이동시킨다. 즉, 데이터 소스가 아닌 중간 노드의 경우, CS에 저장된 데이터를 전송한 후, CS에서 해당 데이터를 삭제한다. Fig. 2 -(B)는 MCD의 운영 방법을 설명한다. A-Node가 캐싱하고 있는 데이터에 대한 Interest를 수신하여 대응되는 Data를 전송하면, 전송 경로사에서 A-Node와 직접 연결된 B-Node만 Data를 캐싱 한다. 이 때, A-Node는 Data를 전송한 후, CS에서 해당 Data를 삭제한다. MCD를 적용할 경우, Interest 전송 경로 위에 있는 노드들 중에서 데이터를 캐싱하고 있는 노드는 한 개뿐이다. 그러나 A-Node에서 데이터가 삭제된 후, 다른 경로를 통하여 A-Node가 삭제된 데이터에 대한 Interest를 수신하면, A-Node는 이를 처리할 수 없기 때문에 Interest를 데이터 소스에게 전송해야 한다. 이러한 경우, 네트워크 성능 저하를 초래할 수 있다.

 

(3) WAVE: NDN은 파일(File)을 일정 크기 이하의 여러 segment로 단편화 한 후, 각각의 segment를 단일 데이터로 간주하여 처리한다. LCD와 MCD는 이렇게 단편화된 데이터 단위로 캐싱을 운영한다. 즉, LCD와 MCD는 개별 데이터의 이용 빈도에 따라 해당 데이터의 캐싱을 결정한다. 반면에, WAVE는 파일의 이용 빈도를 이용하여 캐싱을 결정한다. 특히, WAVE는 데이터 캐싱 단위를 파일의 요청 빈도에 따라 지수 승으로 증가 시킨다. 예를 들어 Fig. 2 -(C)에서와 같이, 파일에 대한 첫 번째 요청 Interest들을 수신하며, 해당 파일의 첫 번째 segment의 Data가 캐싱 되기 시작하고, 해당 파일에 대한 두 번째 요청 Interest들이 수신되면, 두 번째 segment와 세 번째 segment의 Data들이 캐싱 되기 시작하며, 세 번째 요청에는 네 번째부터 일곱 번째 segment의 Data들이 캐싱 되기 시작한다. 이와 같은 캐싱을 통해서 WAVE는 LCD와 같이 점진적으로 데이터를 사용자의 Edge Network에 캐싱 하지만, WAVE는 이용 빈도에 따라 캐싱 증가 속도를 지수 승으로 증가 시킬 수 있다.

 

이와 같은 기법들의 공통적인 특징은 데이터의 이용 빈도가 높을수록 사용자의 Edge Network의 노드에 데이터를 캐싱하고, 해당 데이터에 대한 Interest를 사용자의 Edge Network 안에서 응답 처리되게 함으로써, Core Network에서 교환되는 패킷의 수를 효과적으로 줄일 수 있을 것으로 예상했다. 또한, 전송되는 데이터를 모두 캐싱하는 것이 아니라, 이용 빈도에 따라 캐싱되는 노드의 수를 증가시키기 때문에, 데이터 캐싱을 위한 노드의 저장 공간을 보다 효율적으로 유지/관리할 수 있을 것으로 기대되었다.

 

그러나 이와 같은 결과를 얻기 위해서는 사용자가 요청한 데이터가 사용자의 Edge Network에 캐싱되어 있어야 한다. 즉, 해당 데이터의 이용 빈도가 매우 높은 데이터의 경우에만 이와 같은 성능 구현이 가능하다. 실제로 2015년 Youtube의 이용 통계 자료에 의하면, 10억 명 이상의 이용자가 지난 1년 동안 Youtube를 통해 비디오를 시청했으며, 매일 평균 40 억 개의 비디오가 시청되고 있으며, 가장 높은 누적 시청 회수는 2억 5천회 이상의 시청 기록을 갖고 있다. 그러나 9개의 주요 카테고리 별 누적 평균 시청회수를 분석할 때, 가장 많은 평균 이용 회수 기록을 갖는 카테고리는 Entertainment로 평균 9,816건의 시청을, 가장 적은 카테고리는 People and Blogs로 2,354건의 평균 시청 회수를 기록하고 있다 [10 - 13] . 즉, 누적 평균을 고려할 때 대부분의 데이터들이 일만 건 이하의 시청 기록을 갖고 있다. 이는 데이터당 평균 0.001%의 이용자들만이 시청한다는 것을 의미한다. 그러므로 사용자의 Edge Network에 데이터가 캐싱 되는 경우는 전체 데이터 이용 건수를 고려할 때 매우 적을 수 있다. Fig. 3 은 이와 같은 분석을 바탕으로 계층적으로 구성된 네트워크 도메인의 각 Level에 캐싱된 데이터의 이용 빈도를 조사한 결과이다. 계층적 네트워크 구조의 Root에 해당하는 Core Network Node에 데이터가 저장될수록 데이터의 이용 빈도가 높고, Leaf Node에 해당하는 Edge Network Node에 데이터가 저장될수록 데이터 이용 빈도가 낮게 조사된다. 그러므로 이와 같은 각각의 노드별 데이터 이용 빈도를 고려하여 NDN 데이터 캐싱 기법을 개선할 필요가 있다.

 
Fig. 3
 
PPT Slide
Lager Image
 
Cache Hitting Rate Comparison Considering Network Hierarchy Level.
 
 
4. 노드 이용 빈도 기반 NDN 캐쉬 관리 기술
 

네크워크 노드에 캐싱된 데이터의 이용 빈도를 높이기 위하여 다음과 같은 두 가지 원칙을 기준으로 데이터 캐싱을 운영하는 방안을 제안 한다:

 

(1) 네트워크 성능 개선: 사용자가 생성한 Interest의 전송 경로 위에 있는 노드들 중에서, 많은 Interest들이 공통적으로 경유하는 노드에 데이터를 캐싱 한다.

 

(2) 저장 공간의 효율적 운영: 데이터의 이용 빈도에 따라 데이터 캐싱 영역을 점진적으로 확장한다.

 

이와 같은 데이터 캐싱 운영 기준에 따라 NDN 데이터 캐싱을 개선하기 위하여 네트워크 토폴로지 구성과 캐싱 프로세스를 다음과 같이 제안한다.

 
 
- 4.1 도메인 식별자 기반 계층적 네트워크 토폴로지
 

많은 수의 노드들을 네트워크로 연결하고, 이들 노드들 사이의 전송 효율성을 높이기 위하여 네트워크 도메인에 포함된 노드들을 계층적으로 구성하는 것이 일반적이다. 또한, NDN은 Domain Name Server와 같은 Resolution Server를 이용하지 않고 Interet/Data를 전송하기 위하여 데이터의 유일한 식별자인 데이터 이름을 계층화하여 운영한다.

 

본 논문에서는 NDN의 계층화된 데이터 이름과 네트워크 도메인의 계층을 연계하여 운영하는 방안을 제안한다. 즉, Fig. 4 처럼, 명명된 계층화된 네트워크 도메인(Named-Network Doamin Hierarchy)을 다음과 같이 운영한다.

 
Fig. 4
 
PPT Slide
Lager Image
 
Named-Network Domain Hierarchy.
 

(1) 각각의 네트워크 도메인 (CU-HD과 CS_HD)은 Border Gateway를 Root Node로 하고, 계층화된 서브 도메인마다 Gateway를 운영한다. 또한, 이들 도메인(서브도메인)/사용자 호스트는 계층화된 도메인/호스트 식별자를 각각 갖고 있으며, 도메인/서브도메인의 Gateway 관리자는 도메인/서브도메인 식별자를 해당 Gateway에 설정되고, 사용자는 사용자 호스트에 호스트 식별자를 설정한다.

 

(2) 데이터의 유일한 식별자는 이들 계층화된 호스트 식별자를 이용하여 생성한다. 예를 들어 데이터 소스의 호스트가 연결된 네트워크의 계층의 도메인/서브도메인의 식별자를 구성하는 요소가 Root Node로부터 각각 'dn1', 'dn2', 'dn3' 라하고, 해당 호스트의 식별자 요소를 ‘sou'라고 한다면, 해당 호스트의 네트워크 계층 식별자는 ’dn1/dn2/dn3/son‘이 된다. 이 때 해당 호스트에서 생성/배포하는 데이터의 이름은 ’dn1/dn2/dn3/son’을 데이터 이름 접두어(Content Name Prefixs)로 사용한다.

 
 
- 4.2 도메인 식별자 기반 데이터 캐싱(DNbC)
 

Fig. 4 에서와 같이, 계층화된 도메인 식별자를 기반으로 데이터를 점진적으로 캐싱 하기 위하여, 본 논문에서는 기존 Data 구성 형식에 Caching Flag Bit (CFB)를 추가한다. Interest를 수신한 노드가 해당 Interest에 의해 요청된 데이터를 CS에 캐싱 하고 있다면, 다음과 같은 절차를 따라 Interest를 처리 한다:

 

(1) PIT 검사를 수행한다. 수행 절차는 기본적인 NDN 수행 절차와 동일하다.

 

(2) CS 검사를 수행한다. 수행 절차는 기본적인 NDN 수행 절차와 동일하다. 가정에 따라 해당 노드의 CS에는 대응하는 데이터가 저장되어 있다.

 

(3) CS에 저장되어 있는 데이터의 CFB를 True로 설정한 후, 해당 Interest의 유입 Face를 통하여 전송한다.

 

(4) PIT에서 해당 Interest에 대응하는 entry를 삭제한 후, Interest 처리 절차를 종료한다.

 

Data를 수신한 노드는 다음과 같은 절차를 따라 수신된 Data를 처리한다.

 

(1) PIT 검사를 수행한다. 수행 절차는 기본적인 NDN 수행 절차와 동일하다.

 

(2) 수신된 Data의 CFB를 확인한다. CFB가 False이면, 수신된 Data를 CS에 저장하지 않는다.

 

(3) CFB가 True이면, 다음과 같은 두 가지 경우에만 해당 Data를 CS에 저장한다.

 

① 수신 노드의 네트워크 계층 이름이 Data의 데이터 계층 이름의 prefix에 포함된 경우. 즉, 수신 노드가 데이터 소스의 네트워크 도메인의 Root Node와 데이터 소스 사이의 전송 경로 위에 존재하는 Gateway인 경우.

 

② 수신 노드가 네트워크 도메인의 Root Node인 경우. 즉, 수신 노드가 Core Network 망을 구성하는 노드인 경우.

 

(4) 수신된 Data의 CFB를 False로 수정한다.

 

(5) Data를 PIT에 기록된 관련 entry의 Face들을 통해서 전송한다. 이 때, 어떤 경우에든지 Data의 CFB는 항상 False이다.

 

(6) PIT에서 해당 entry를 삭제한 후, Data 처리 절차를 종료한다.

 
 
5. 성능 평가
 
 
- 5.1 성능 평가를 위한 환경 구성
 

제안된 데이터 캐싱 기법의 성능 평가를 위하여 NDN, LCD 그리고 제안된 DNbC의 성능을 비교 평가한다. 이를 위하여, 본 논문에서는 랜덤하게 선택된 사용자들이 생성된 데이터를 랜덤하게 요청하는 시뮬레이션을 구현하여 그 결과를 관찰하였다. 시뮬레이션은 Fig. 5 와 같이 5개의 서로 다른 Network Domain으로 구성된 Core Network 망을 가정하고 있으며, 각각의 Network Domain은 다음과 같이 계층적으로 구성하였다.

 
Fig. 5
 
PPT Slide
Lager Image
 
Network Topology for Simulation.
 

(1) Root Node는 5개의 Sub-domain들을 Child로 갖으며, Leaf Node를 제외한 나머지 노드들은 각각 4개의 Sub-domain들을 Child로 갖는다.

 

(2) Leaf node는 사용자 기기로 간주하며, Interest의 최초 생성자는 Leaf node로 한정한다.

 

(3) 각각의 노드는 Interest 전송을 위한 FIB 테이블을 구성/관리한다고 가정한다.

 

네트워크를 구성하는 각각의 노드들의 환경 설정은 다음과 같다:

 

(1) 네트워크를 통해 접근 가능한 데이터는 16,000 개이며, 랜덤하게 선택된 노드들에서 생성한다. 또한, 이들 데이터는 동일한 이용 빈도를 갖는다.

 

(2) 각각의 노드는 1000개의 데이터를 동시에 저장할 수 있는 CS를 운영한다.

 

(3) 캐싱된 데이터의 생명주기(Lifetime)는 모든 노드에서 50초로 설정한다.

 

(4) 랜덤하게 선택된 Leaf Node에서, 16,000개의 데이터 중 하나를 랜덤하게 선택하여 요청한다.

 

(5) 평균 응답률은 96.7%로 설정한다.

 
 
- 5.2 성능 평가 결과
 

Fig. 6 은 시뮬레이션 과정 중에서 각각의 노드에 캐싱된 데이터의 평균 개수의 총합을 나타낸다. LCD와 DNbC는 데이터의 요청 빈도에 따라서 해당 데이터의 캐싱 노드의 수를 점진적으로 늘려나가기 때문에 모든 노드에 데이터를 캐싱 하는 NDN에 비하여 효율적으로 네트워크 캐쉬를 운영할 수 있다. 그림 6 에서와 같이 NDN에 비해 20% 정도의 캐쉬 만으로도 서비스 운영이 가능하다. 또한, DNbC의 경우, 점진적으로 캐싱 되는 노드를 Core Network으로 한정시켜 운영하기 때문에, 사용자의 Edge Network에 추가적으로 캐싱되는 경우는 데이터 소스가 포함된 네트워크 도메인으로 한정된다. 그러므로 LCD에 비해 30% 정도의 추가 절감 효과를 기대할 수 있다.

 
Fig. 6
 
PPT Slide
Lager Image
 
The Total Number of Caches.
 

Fig. 7 은 NDN, LCD, DNbC의 Interest 전송량을 비교 분석한 결과를 나타낸다. 최대 100,000개의 Interest가 랜덤하게 선택된 데이터를 요청하기 위하여 생성/전송될 때, 네트워크 노드에서 해당 Interest들을 포워딩한 수를 누적하여 측정하였다: NDN과 비교할 때 LCD와 DNbC는 2% 정도의 Interest 전송량이 증가한다. 그러나 LCD와 DNbC만을 비교할 때, 오히려 0.2% 정도 감소하는 것으로 나타났다. 이는 데이터 이용 빈도와 오차를 고려할 때 무시할만한 수치이지만, 데이터를 사용자의 Edge Network에까지 캐싱하는 것에 비해, Core Network에까지 캐싱하는 것이 전송 효율에 큰 영향을 미치지 않음을 알 수 있다.

 
Fig. 7
 
PPT Slide
Lager Image
 
The Total Number of transmitted Interests.
 

또한, 내부 도메인과 Core Network을 구성하는 Border Gateway로 캐싱 구간을 이중화 하여 제한함으로써, Interest가 집중되는 영역을 분산시키는 NDN의 장점을 그대로 유지시키면서도 네트워크와 스토리지의 오버해드를 개선할 수 있다.

 
 
6. 결 론
 

NDN은 네트워크 노드에 캐싱된 데이터를 활용하여 네트워크의 효율성을 높이기 위해 제안되었다. 그러므로 어떤 데이터를 어느 위치에 캐싱하여 운영할지를 결정하는 것이 무엇보다 중요하다. 지금까지 발표된 대부분의 연구들은 사용자 노드가 위치한 Edge Network에 데이터를 캐싱하는 방안들이 대부분을 차지하고 있다. 이는 Interest를 사용자의 Edge Network내에서 응답 처리되게 함으로써 Core Network으로 유입되는 Interest/Data의 수를 줄일 수 있을 것으로 예상했기 때문이다. 그러나 본 논문에서는 이와 같은 연구 결과는 일부 인기 데이터에 대해서만 도출이 가능하고, 대부분의 데이터는 일부 Edge Network에만 캐싱 되기 때문에, 해당 Interest들이 여전히 Core Network로 유입될 수 있음을 지적하였다.

 

이와 같은 문제들을 해결하기 위하여 본 논문은 기존의 데이터 요청 빈도에 따른 점진적으로 데이터 캐싱 범위를 확대하던 기존의 기술에 노드의 접근 빈도를 추가적으로 감안하여 데이터 캐싱 여부를 결정하도록 제안한다.

 

본 논문의 제안을 시뮬레이션을 통해 관찰한 결과 기존 캐싱 기법과 비교할 때 유사한 네트워크 효율성을 나타내면서도 스토리지 효율성을 개선할 수 있음을 알 수 있다. 또한, 내부 도메인과 Core Network을 구성하는 Border Gateway로 캐싱 구간을 이중화하여 제한함으로써, Interest가 집중되는 영역을 분산시키는 NDN의 장점을 그대로 유지시키면서도 네트워크와 스토리지의 오버해드를 개선할 수 있다. 그러므로 네트워크 캐쉬의 효율적인 운영을 통하여 점차 다양해지고 있는 스마트 IT 융복합 서비스의 안정적인 구현이 가능할 것으로 기대된다.

 
 
BIO
 

 

김 대 엽

 

1997년 3월∼2000년 2월 고려대학교 대학원 수학과 이학박사

 

1997년 9월∼2000년 3월 ㈜텔리맨 CAS팀 연구원

 

2000년 4월∼2002년 8월 시큐아이닷컴 정보보호연구소 차장

 

2002년 9월∼2012년 2월 삼성전자 종합기술원 전문연구원

 

2012년 3월∼현재 수원대학교 정보보호학과 조교수

 

2016년 1월∼현재 수원대학교부설 IT연구소 소장

 

관심분야 : 보안프로토콜, 네트워크/시스템 보안, 콘텐츠 보안, 미래 인터넷 보안

 
 
References
 
1.
Clark D. 1988 “The Design Philosophy of the DARPA Internet Protocols,” ACM SIGCOMM Computer Communications Review 18 (1) 106 - 114    DOI : 10.1145/52325.52336
 
2.
Ahlgren B. , Dannewitz C. , Imbrenda C. , Kutscher D. , Ohlmann B. 2012 “A Survey of Information-Centric Networking,” IEEE Communications Magazine 50 (7) 26 - 36    DOI : 10.1109/MCOM.2012.6231276
 
3.
Jacobson V. , Smetters D. , Thornton J. , Plass M. , Briggs N. , Braynard R. “Networking Named Content,” Proceeding of 5th International Conference on Emerging Networking Experiments and Technologies 2009 1 - 12
 
4.
Kim D. 2012 “Content Centric Networking Naming Scheme for Efficient Data Sharing,” Journal of Korea Multimedia Society 15 (9) 1126 - 1132    DOI : 10.9717/kmms.2012.15.9.1126
 
5.
Psaras I. , Chai W.K. , Pavlou G. 2013 “In-network Cache Management and Resource Allocation for Information-centric Networks,” IEEE Transactions on Parallel Distributed Systems 25 (11) 2920 - 2931    DOI : 10.1109/TPDS.2013.304
 
6.
Laoutaris N. , Che H. , Stavrakakis I. 2006 “The lcd Interconnection of Lru Caches and Its Analysis,” Performance Evaluation 63 (7) 609 - 634    DOI : 10.1016/j.peva.2005.05.003
 
7.
Zhang G. , Ki Y. , Lin T. 2013 “Caching in Information Centric Networking: A Survey,” Computer Networks 57 (16) 3128 - 3141    DOI : 10.1016/j.comnet.2013.07.007
 
8.
Zhang M. , Luo H. , Zhang H. 2015 ”A Survey of Caching Mechanisms in Information-Centric Networking,” IEEE Communication Surveys & Tutorials 17 (3) 1473 - 1499    DOI : 10.1109/COMST.2015.2420097
 
9.
Cho K. , Lee M. , Park K. , Kwon T. , Choi Y. , Pack S. "WAVE: Popularity-based and Collaborative In-network Caching for Content-Oriented Networks," Proceeding of IEEE INFOCOM Workshop on Emerging Design Choices in Name-Oriented Networking 2012 316 - 321
 
10.
2016 Youtube Statistics https://www.youtube.com/yt/press/en-GB/statistics.html
 
11.
2016 Youtube Trend Map https://www.youtube.com/trendsmap
 
12.
2016 How Many Views Does A Youtube Video Get? Average Views By Category http://www.reelseo.com/average-youtube-views/
 
13.
Cheng X. , Dale C. , Liu J. "Statistics and Social Network of Youtube Videos," Proceeding of 16th International Workshop on Quality of Service 2008 229 - 238
 

 

 

 

 

 

'ITPE > NW' 카테고리의 다른 글

MQTT 프로토콜 참고  (0) 2018.03.02

 

 

 

 

테스트 드라이버와 테스트 스텁의 개념 이해 (테스트 하네스에 포함)

 

 

출처 : [네이버 지식백과] 단위 테스트 (쉽게 배우는 소프트웨어 공학, 2015. 11. 30., 한빛아카데미(주))

출처 : [네이버 지식백과] 통합 테스트 (쉽게 배우는 소프트웨어 공학, 2015. 11. 30., 한빛아카데미(주))

 

 

 

단위 테스트

 

단위 테스트(unit test)는 프로그램의 기본 단위인 모듈을 테스트하여 모듈 테스트(module test)라고도 한다. 구현 단계에서 각 모듈의 개발을 완료한 후 개발자가 명세서의 내용대로 정확히 구현되었는지를 테스트한다. 즉 개별 모듈이 제대로 구현되어 정해진 기능을 정확히 수행하는지를 테스트한다. 화이트박스 테스트와 블랙박스 테스트를 모두 사용할 수 있지만 모듈 내부의 구조를 구체적으로 들여다볼 수 있는 화이트박스 테스트 같은 구조적 테스트를 주로 시행한다.

단위 테스트가 개발된 모듈만 테스트하기 때문에 쉬울 것 같지만, 시스템은 수많은 모듈이 서로 정보를 주고받으며 연결되어 있다. 즉 테스트할 모듈을 호출하는 모듈도 있고, 테스트할 모듈이 호출하는 모듈도 있다. 따라서 한 모듈을 테스트하려면 그 모듈과 직접 관련된 상위 모듈과 하위 모듈까지 모두 존재해야 정확히 테스트할 수 있다.

그러나 하나의 모듈을 테스트할 때 상위나 하위 모듈이 개발이 안 된 경우도 있다. 이때 상위나 하위 모듈이 개발될 때까지 기다릴 수는 없으므로 가상의 상위나 하위 모듈을 만들어 사용해야 한다. 상위 모듈의 역할을 하는 가상의 모듈을 테스트 드라이버(test driver)라 하고 그 역할은 테스트할 모듈을 호출하는 것이다. 즉 필요한 데이터를 인자를 통하여 넘겨주고, 테스트가 완료된 후 그 결과 값을 받는 역할을 해준다.

반대로 하위 모듈의 역할을 하는 모듈을 테스트 스텁(stub)이라고 한다. 스텁 모듈은 테스트할 모듈이 호출할 때 인자를 통해 받은 값을 가지고 수행한 후 그 결과를 테스트할 모듈에 넘겨주는 역할을 한다. 따라서 드라이버와 스텁 모듈은 테스트할 때 필요한 기능만 제공할 있도록 단순히 구현한다.

[그림 8-23]은 드라이브와 스텁 모듈이 테스트 대상과 맺는 관계를 보여준다.

그림 8-23 드라이버/스텁 모듈과 테스트 대상 모듈의 관계

그림 8-23 드라이버/스텁 모듈과 테스트 대상 모듈의 관계

단위 테스트를 수행하면 다음과 같은 오류를 발견할 수 있다.

• 잘못 사용한 자료형
• 잘못된 논리 연산자
• 알고리즘 오류에 따른 원치 않는 결과
• 틀린 계산 수식에 의한 잘못된 결과
• 탈출구가 없는 반복문의 사용

 

 

 

 

 

 

 

통합 테스트

 

단위 테스트가 끝난 모듈을 통합하는 과정에서 발생할 수 있는 오류를 찾는 테스트가 통합 테스트(integrationtest)이다. 실제 업무에서는 단위 모듈이 개별적으로 존재하는 것이 아니고 여러 모듈이 유기적 관계를 맺고 있으므로 이러한 모듈들을 결합한 형태로 테스트를 수행해봐야 한다. 이때 주로 확인하는 것은 '모듈 간의 상호작용이 정상적으로 수행되는가'이다. 즉 모듈 사이의 인터페이스 오류는 없는지, 모듈이 올바르게 연계되어 동작하고 있는지를 체크한다.

개별 모듈을 테스트하는 단위 테스트에서는 오류가 발견되지 않았어도, 모듈을 통합하면 상호 간의 인자나 공유 데이터 구조 등에서 오류가 발생할 수 있다. 또 단위 테스트 시 가상의 드라이버와 스텁 모듈을 만들어 테스트를 잘 수행했더라도, 상당히 제한적인 여건에서 테스트를 수행한 것이다. 그러므로 실제 모듈 통합 시에는 다른 결과가 나올 수도 있다. 실제 개발에서는 모듈 간의 상호작용과 인터페이스에서 많은 오류가 발생하는 것을 볼 수 있다. 그러므로 통합 테스트가 필요한데, 그 방법에는 모듈 통합을 한꺼번에 하는 방법과 점진적으로 하는 방법이 있다.

모듈 통합을 한꺼번에 하는 방법으로는 빅뱅(big-bang) 테스트를 들 수 있다. 빅뱅 테스트는 단위 테스트가 끝난 모듈을 한꺼번에 결합하여 수행하는 방식이다. 이 방법은 소규모 프로그램이나 프로그램의 일부를 대상으로 하는 경우가 많고 그만큼 절차가 간단하고 쉽다. 그러나 한꺼번에 통합하면 오류가 발생했을 때 어떤 모듈에서 오류가 존재하고 또 그 원인이 무엇인지 찾기가 매우 어렵다.

모듈 통합을 점진적으로 하는 방법은 모듈 통합을 한꺼번에 하는 방법의 문제를 극복하는 방법으로, 완성된 모듈을 기존에 테스트된 모듈과 하나씩 통합하면서 테스트한다. 문제가 발생하면 바로 직전에 통합하여 테스트한 모듈에서 오류가 발생했다고 짐작할 수 있으므로 오류를 찾기가 쉽다. 점진적 통합 방식은 가장 상위에 있는 모듈부터 테스트하는지, 가장 하위에 있는 모듈부터 테스트하는지에 따라 하향식 기법과 상향식 기법으로 나뉜다.

1. 점진적 모듈 통합 방법 : 하향식 기법

하향식(top-down) 기법은 시스템을 구성하는 모듈의 계층 구조에서 맨 상위의 모듈부터 시작하여 점차 하위 모듈 방향으로 통합하는 방법이다.

[그림 8-24]의 예에서 맨 상위 모듈 A를 모듈 B와 통합하여 테스트한다. 그다음으로 모듈 C를 먼저 선택할지, 아니면 B 아래에 있는 모듈 E를 먼저 선택할지 결정해야 한다. 이때 모듈 C를 먼저 선택하는 방식을 넓이 우선(breadth first) 방식이라 하고 모듈 E를 먼저 선택하는 방식을 깊이 우선(depth first) 방식이라 한다.

넓이 우선 방식으로 테스트하면 (A, B)→(A, C)→(A, D)→(A, B, E)→(A, B, F)→(A, C, G)와 같이 같은 행에서는 옆으로 가며 통합 테스트를 한다. 반면, 깊이 우선 방식에 따라 테스트하면 (A, B)→(A, B, E)→(A, B, F)→(A, C)→(A, C, G)→(A, D) 순으로 통합하며 테스트한다. 즉 하위 방향으로 내려가면서 통합하지만, 같은 행에서는 옆이 우선이 아니라 그 아래 모듈을 먼저 통합하여 테스트한다. 또한 하향식 방식에서는 상위 모듈부터 테스트를 수행하기 때문에 단위 테스트에서 설명한 스텁 모듈이 필요하다.

그림 8-24 점진적 모듈 통합 방법을 설명하기 위한 모듈 구성도

그림 8-24 점진적 모듈 통합 방법을 설명하기 위한 모듈 구성도

일반적으로 모듈의 종속 관계에서 상위 모듈은 시스템 전체의 흐름을 관장하고, 하위 모듈은 각 기능을 구현하는 형태로 구성되어 있다. 그러므로 하향식 기법을 이용하면 프로그램 전체에 영향을 줄 수 있는 오류를 일찍 발견하기가 쉽다. 그러나 하위 모듈이 임시로 만든 스텁들로 대체되어 결과가 완전하지 않을 수도 있고 스텁 수가 많으면 스텁을 만드는 데 시간과 노력이 많이 들 수 있다. 따라서 모듈 간의 인터페이스와 시스템의 동작이 정상적으로 잘되고 있는지를 빨리 파악하고자 할 때 하향식 기법을 사용하는 것이 좋다.

2. 점진적 모듈 통합 방법 : 상향식 기법

상향식(bottom-up) 기법은 하향식 기법과는 반대로 가장 말단에 있는 최하위 모듈부터 테스트를 시작한다. 하향식에서 스텁이 필요했다면, 상향식에서는 상위 모듈의 역할을 하는 테스트 드라이버가 필요하다. 이 드라이버는 하위 모듈을 순서에 맞게 호출하고, 호출할 때 필요한 매개 변수를 제공하며, 반환 값을 전달하는 역할을 한다.

[그림 8-24]에서 상향식 기법을 이용하여 테스트하는 순서는 다음과 같다. 우선 가장 말단(레벨 3)에 있는 모듈 E와 F를 모듈 B에 통합하여 테스트한다. 그다음 모듈 G를 모듈 C에 통합하여 테스트한다. 마지막으로 모듈 B, C, D를 모듈 A에 통합하여 테스트한다.

상향식 기법의 장점은 최하위 모듈들을 개별적으로 병행하여 테스트할 수 있기 때문에 하위에 있는 모듈들을 충분히 테스트할 수 있다는 것이다. 또한 정밀한 계산이나 데이터 처리가 요구되는 시스템 같은 경우에 사용하면 좋다. 그러나 상위 모듈에 오류가 발견되면 그 모듈과 관련된 하위의 모듈을 다시 테스트해야 하는 번거로움이 생길 수 있다.

 

 

 

 

 

 

'ITPE > SE' 카테고리의 다른 글

소프트웨어 테스팅 국제표준 - ISO 29119  (0) 2021.02.19
CMMI  (0) 2018.04.12
TOC-Thinking Process  (0) 2018.04.06

 

 

 

 

 

 

퍼온글
 
 
 
 

ITWorld 용어풀이 | 인터클라우드

박재곤 기자 | ITWorld
인터클라우드(Intercloud)는 ‘클라우드의 클라우드’란 뜻입니다. ‘네트워크의 네트워크’가 인터넷인 것과 같은 맥락으로 만들어진 용어입니다. 와이어드 편집자 케빈 켈리가 2007년 클라우드 컴퓨팅을 설명하며 처음 사용했고, 이후 업계에서 보편적으로 사용되고 있습니다.

그럼 ‘클라우드의 클라우드’란 어떤 의미일까요? 클라우드 서비스는 ‘구름 속에 있는 컴퓨팅 자원’의 실체에 관계없이 필요한 만큼 가져다 사용하고 사용한만큼 비용을 지불하는 것을 기본 개념으로 합니다. 

하지만 단일 클라우드 서비스의 실제 물리 자원은 무한하지 않으며, 지역적으로 모든 곳에 서비스를 제공할 수 있는 것도 아닙니다. 만약 수요가 포화 상태에 이른 클라우드 서비스가 새로운 고객의 요청을 받는다면, 혹은 자사가 서비스할 수 없는 지역으로부터 요청을 받는다면 어떻게 해야 할까요? 이때 다른 클라우드 서비스의 인프라에서 필요한 자원을 가져다 서비스하는 것으로 이런 문제를 해결한다는 것이 인터클라우드의 핵심 개념입니다.

물론 실제로 이런 일이 가능하기 위해서는 클라우드 간의 상호호환성이 있어야 하며, 클라우드 간의 인터페이스, 네트워크 프로토콜 표준화 등의 작업이 필요합니다. 그리고 IEEE는 2010년 7월 클라우드 컴퓨팅 상호호환성과 서비스에 대한 국제 워크샵을 시작으로 관련 연구를 계속해 오고 있습니다.
 
 
이런 기술적인 노력과는 달리 시장에서 인터클라우드가 관심을 모으기 시작한 것은 2013년 말, 시스코가 처음으로 인터클라우드 관련 제품을 발표하면서부터입니다. 인터클라우드가 결국 클라우드가 어느 정도 확산된 단계에서나 구현할 수 있는 개념이라는 점에서 당연한 수순이기도 합니다. 시스코는 2014년부터 클라우드 사업 확대에 10억 달러를 투자하겠다고 발표하며 자사의 인터클라우드 전략을 본격적으로 내세우기 시작했습니다.

인터클라우드는 아직 실제로 구현된 모습이 나타나지 않았으며, 기술적으로도 보안이나 QoS, 지불결제, 상호 신뢰, 거버넌스, 법적 책임 문제 등 많은 해결과제를 안고 있는 상황입니다. 하지만 클라우드의 발전 방향 중 하나라는 것만은 확실한 것으로 평가되고 있습니다.

한편 인터클라우드와 연관성이 있는 개념으로는 하이브리드 클라우드(Hybrid Cloud), 멀티클라우드(Multi-Cloud), 메타클라우드(Meta-Cloud) 등을 들 수 있습니다.

하이브리드 클라우드는 퍼블릭 클라우드와 프라이빗 클라우드를 연동해 함께 사용할 수 있는 환경을 말하는 것으로, 다양한 배치 형식의 클라우드를 하나로 이용하는 것이 핵심입니다. 사실 시스코의 인터클라우드 전략도 파트너 생태계가 완성되기 전에는 하이브리드 클라우드 단계라고 볼 수 있죠.

멀티클라우드는 단일 기업이 여러 클라우드 서비스를 하나의 환경에서 동시에 사용하는 것을 말하는 것으로, 보안이나 거버넌스 등의 복잡한 문제를 사용 기업이 해결하는 방식입니다. 메타클라우드는 시스코가 인터클라우드 전략을 위해 인수한 업체 이름이기도 하며, 여러 클라우드 인프라를 엮어서 메타 서비스를 프로비저닝할 수 있도록 해 주는 것을 말합니다. 멀티클라우드의 서비스 업체 버전이라고 할 수 있습니다.  editor@itworld.co.kr



원문보기: 
http://www.itworld.co.kr/tags/63516/%EC%9D%B8%ED%84%B0%ED%81%B4%EB%9D%BC%EC%9A%B0%EB%93%9C/91416#csidx6999ff0023f1c17ad9c81aa3d204c51 

 

 

 

 

 

 

 

'ITPE > DS' 카테고리의 다른 글

패브릭 컴퓨팅  (0) 2018.06.24

 

 

 

AUTOSAR 공부중 검색한 글로,

 

원본글 : http://cafe.naver.com/powworld/7055

 

문제시 삭제

 

 

프랑스와 독일 자동차 ecu표준 방식은 iso인증한
OSEK/VXD 이방식이 쓰이며 표준입니다

 

프로그램 구조도 입니다

 

oo

 

 


- Application Layer : 우리하 흔히 알고 있는 OSI 7 Layer에서 Application Layer와 거의 동일하다고 보면 됩니다


- Interaction Layer : 소프트웨어 구조 설계시 정의 된 메시지 전송 형태의 핸들링을 처리하는 기능의 Layer이다. 또 데이터 교환에 관한 API를 제공하고 각종 기본 값들을 설정 할 수 있습니다


- Diganostic Layer : 자동차에 내장 된 각종 진단 기능에 대해 인터페이스를 제공하는 Layer 이다. 또 예외처리(Busy 등)를 담당하고 있으며 CAN과 관련한 진단사항 요구를 처리합니다


- Transport Protocol : 대용량(기본 전송 데이터는 8byte인데 이보다 더 큰) 데이터를 보내기 위한 고안된 Protocol이다. 네트워크의 7Layer 중 Transport Layer처럼 데이터 분할 기능도 있다. 또 동기화 기능과 에러감지 기능도 가지고 있습니다


- Network Management : 주된 목적은 자동차의 전원 사용 효율성이다. 각 상태(Network Wakeup, Network Active, Network Slepp)에 따라 전원 사용량을 달리 하는 기능을 가지고 있습니다


- CAN Calibratoin Protocol : ECU의 Flash ROM에 다양한 데이터 접근 방식으로 읽기와 쓰기를 담당하는 프로토콜입니다



 

회로 이해도 입니다

ecu코딩이나 맵핑에 필요한 프로그램은 시중에
많이 나와 있습니다 대표적으로 win ols라든지요

 

 

'ITPE > CA_OS' 카테고리의 다른 글

Cache Clean, Flush  (0) 2021.04.28
MESI protocol  (0) 2021.04.28
CPU 명령어 사이클  (0) 2021.04.27
CPU 구성  (0) 2021.04.24
개요  (0) 2021.04.24

+ Recent posts