1. 이 책은 학원 수강을 통해 습득한 내용과 멘토링을 진행하면서 스스로 학습한 내용을 바탕으로 답안 형태로 작성하였고, IT 분야 기술사인 정보관리기술사와 컴퓨터시스템응용기술사 자격을 취득하기 위해 학습하고 있거나 학습하고자 하는 분들을 위해 만들었습니다.
2. 본 교재는 발전 동향, 배경 그리고 유사 기술과의 비교, 다양한 도식화 등 실무 개발자 경험을 토대로 작성한 내용으로 풍부한 경험적인 요소가 내재하여 있는 장점이 있습니다.
■ 책의 특징
Part 1. 클라우드(Cloud) 네이티브의 개요
클라우드 네이티브, 등장 배경, 구성, 특징, 구성요소, Cloud Native Application, 성숙도 단계, 클라우드 네이티브의 장·단점, 전환 효과, 클라우드 네이티브의 안전성·확장성·신속성, 공공부문의 클라우드 네이티브의 도입 목표 등 학습에 기본이 되는 토픽들입니다. [관련 토픽 – 19개]
Part 2. 클라우드 네이티브 구성요소 및 원칙
컨테이너(Container)와 Virtual Machine의 차이, 오케스트레이션의 주요 기능, MSA(Micro Service Architecture), MSA 구조 및 장·단점, 특징, CI/CD, DevOps, DevSecOps 등에 대해 알차게 학습할 수 있습니다. [관련 토픽 – 16개]
Part 3. 클라우드 네이티브 적합성 검토
클라우드 네이티브 정책과 업무 관점의 검토 항목과 기술 및 서비스 관점의 검토 항목, 프로세스 관점, 조직 관점의 검토 항목, Cloud Native 개발 비용 산정, 우선순위 결정요소 등을 이해하고 답안화 할 수 있는 방법을 제시했습니다. [관련 토픽 – 6개]
Part 4. 클라우드 네이티브 기반 기술
REST, SSL, SOA, EAI, AnyLink, JSON, Open API, 서버리스 아키텍처, Platform Engineering, 카프카(Kafka), Apache Storm, 넷퍼넬, AMQP, 로드 밸런싱, IPC, BaaS와FaaS, 멀티 클라우드(Multi Cloud), 클라우드 상호운용성 등에 대해 답안으로 작성할 수 있습니다. [관련 토픽 – 35개]
Part 5. 클라우드 네이티브 내·외부 아키텍처
내부 아키텍처, 외부 아키텍처, 개발 절차, MSA 전환 예시, API Gateway, 서비스 메시(Service Mesh), Service Discovery, 쿠버네티스(Kubernetes), 개발 및 실행 지원 서비스, 실행 영역과 Backend 서비스, 운영지원 서비스와 Cloud 인프라 등의 출제 경향을 파악할 수 있습니다. [관련 토픽 – 18개]
Part 6. 클라우드 네이티브 분석단계
마이크로 서비스 도출, DDD설계, 바운디드 컨텍스트와 애그리거트, 컨텍스트 맵핑(Context Mapping), Micro-Service 식별 및 경계 도출 방안, Micro-Service 도출 예시, 이벤트 스토밍을 통한 마이크로서비스 도출 과정 등에도 쉽게 접근할 수 있도록 하였습니다. [관련 토픽 – 12개]
Part 7. 클라우드 네이티브 설계단계
MSA의 기술 요소 및 도입 시 고려사항과 운영 시 예상문제와 해결 방안, Cloud Native Application 아키텍처의 구성, Micro Service 아키텍처의 설계 방안, SAGA 패턴, CQRS 패턴, 통신 패턴, 폴리글랏 아키텍처, Cloud Migration, 12 Factors 기반 개발원칙 등에 대해 쉽게 이해할 수 있도록 기술하였습니다. [관련 토픽 – 23개]
Part 8. 클라우드 네이티브 보안 분야
개방형 API(Open API)의 취약점과 대응 방안, 클라우드 서비스 위험관리 원칙 및 기준과 보안대책 수립 및 보안성 검토, 전통적인 Cloud 보안과 Cloud Native 보안 비교, 다층 보안 체계(Multi Level Security) 등에 대해 쉽게 이해할 수 있도록 기술하였습니다. [관련 토픽 – 4개]
목차
PART 1. 클라우드 네이티브 개요
1. 클라우드 네이티브(Cloud Native)란
2. 클라우드 네이티브(Cloud Native) 등장
3. 클라우드 네이티브(Cloud Native) 구성
4. 클라우드 네이티브(Cloud Native) 특징
5. 클라우드 네이티브(Cloud Native)의 구성요소
6. 클라우드 네이티브(Cloud Native)(2교시)
7. 정보 System 주요 이슈 및 문제점, Cloud Native 도입 배경과 효과, 전산 장애 발생원인 및 해결 방안에 대해 설명하시오.
29. 실행 중인 Application에 대한 배포(Release) 전략 및 테스트 전략에 대해 설명하시오.
30. DevOps
31. DevOps의 개념, 유형
32. DevOps의 구성 및 설명
33. DevSecOps
34. DevOps 구현 시 Monolithic과 MSA 장·단점, 활용 방안
35. Cloud Native의 조직변화와 합리적인 개발 방법론과 DevOps 조직 구성 시 고려사항에 대해 설명하시오.
PART 3. 클라우드 네이티브 적합성 검토
36. 클라우드 네이티브(Cloud Native) 적합성 검토 항목 중 정책과 업무 관점의 검토 항목과 기술관점의 검토 항목에 대해 기술하시오.
37. 클라우드 네이티브(Cloud Native) 적합성 검토 항목 중 서비스 관점의 검토 항목에 대해 기술하시오.
38. 클라우드 네이티브(Cloud Native) 적합성 검토 항목 중 프로세스 관점의 검토 항목에 대해 기술하시오.
39. 클라우드 네이티브(Cloud Native) 적합성 검토 항목 중 조직 관점의 검토 항목에 대해 기술하시오.
40. Cloud Native 개발 비용 산정
41. CloudNative 사업 추진의 우선순위 결정요소와 사업단계별 고려사항에 대해 설명하시오.
PART 4. 클라우드 네이티브의 기반 기술
42. 분할과 정복(Divide and Conquer)
43. REST(Representational State Transfer)
44. REST(Representational State Transfer) API(Application Programming Interface)
45. SSL(Secure Sockets Layer) Offloading(Proxy)
46. SOA(Service Oriented Architecture)
47. EAI(Enterprise Application Integration)
48. System 및 서비스(Service) 간의 연계방식인 EAI, ESB, API Gateway, Service Mesh에 대해 설명하시오.
49. Anylink
50. JSON(Java Script Object Notation)
51. Open API
52. Open AP
53. Open API, System, 구성요소, 요소기술
54. 개방형 API(Open API)에 대해 설명하시오.
가. 정의 및 특징
나. SOAP 및 REST 구성요소
다. SOAP와 REST 비교
55. REST, SOAP
56. 서버리스 아키텍처(Serverless Architecture)
57. 플랫폼 엔지니어링(Platform Engineering)
58. 클라우드 관리 플랫폼(Cloud Management Platform)
59. Block 스토리지, File 스토리지, Object 스토리지
60. 카프카(Kafka)
61. 대용량 실시간 처리를 위해 사용하는 System인 카프카(Kafka)에 대해 특징, 구성요소, 동작방식에 대해 설명하시오.
62. Apache Storm
63. Apache Spark
64. 넷퍼넬(Net Funnel)
65. AMQP(Advanced Message Queue Protocol)
66. 가중 라운드 로빈(Weighted Round Robin) 방식의 로드밸런싱(Load Balancing)
67. IPC(Inter-Process Communication)
68. IPC(Inter-Process Communication) 기법 중 Pipe 방식에 대해 설명하시오.
69. 클라우드 컴퓨팅(Cloud Computing) 제공 모델의 이점을 활용하는 Application 구축 및 실행 접근 방법으로 Cloud Native Application이 주목받고 있다. Cloud Native Application 의 주요 특징과 관련 기술, 참조 아키텍처에 대해 설명하시오.
70. 폭포수 개발모형과 애자일(Agile) 개발 방법론
71. Agile 개발 방법론의 특징, Waterfall(폭포수) 개발모형과 비교, 장단점에 대해 설명하시오.
72. Single/Hybrid/Multi/Edge Cloud의 정의, 특징, 구조, 적용 시 검토할 사항에 대해 설명하시오.
73. BaaS(Backend as a Service)와 FaaS(Function as a Service)
74. Cloud Service 중 온프레미스(On-Premise), IaaS, CaaS, PaaS, FaaS, SaaS의 설명