분산처리환경에서 단순화된 개발방법을 제시하는 AKKA 분산환경에서의 동시성 처리에대한 해결모델은 언어및 플랫폼에 종속적이지 않으며,AKKA가 아니여도 됩니다.
AKKA는단지 분산처리에있어서 필요한 기본개념을 먼저 알려주고 이벤트중심 설계를 활용한 단순화된 개발모델을 제시하며
개발자는 그것을 이용하여 응용프로그램내에 직접 작성 할수있습니다.
그 중심엔 액터가 있으며 선택가능한 수많은 툴중 하나입니다.
다음과 같은 컨셉으로 컨텐츠를 정리하고 있습니다.
- 분산처리 환경의 이해와 필요한것들
- 분산처리 개발에서 고전적인 개발방법이 가진 한계와 이를 단순화하는 방법
- C# 닷넷 진영에서의 AKKA활용
- JAVA 진영에서의 AKKA활용법
- 최신제공 공식문서를 통해 활용법 유닛테스트화
- AKKA와 대응되는 ReactiveStream의 주변기술 조사
ACTOR :
여러가지 개발 플래폼에서 도입 하기 시작하였으며, 분산 미들웨어에서 수많은 일을 하기위한, 능동적 메시지 객체
마이크로서비스의 구성요소로 적합하며, 마이크로서비스보다 더 작은 단위
- 어떠한 액터라도, 리모트상에 위치가가능하며 클러스터 구성이 가능하며 고성능 대화가가능
- 언랭에서 처음 소개된 프로그래밍 모델
Akka :
- Akka는 오픈 소스 툴킷으로 동시성과 분산 애플리케이션을 단순화하는 런타임이다.
- 동시성을 위한 여러 프로그래밍 모델을 지원하며, Erlang으로부터 영향을 받아 actor기반의 동시성이 두드러진다.
- Akka는 Java환경및 .net Framework에서 이용가능하며, Actor모델은 이제 대부분의 개발플래폼에서 툴킷형태로 사용가능합니다.
AKKA에서 내세우는 강점
시스템
액터와 스트림을 사용하면 여러 서버에서 효율적으로 리소스를 사용하여
확장하는 시스템을 구축 할 수 있는 개발 모델지원
디자인에 의한 유여한 장애 처리
현대시스템에서 시스템의 일부가 다운되거나 고장 나는것은 예외적인 현상이아니라
평범한 동작의 일부이다.
장애가 발생할 경우,자가 치유되고 응답 성을 유지하는 시스템을 작성할 수 있는
개발 모델을 제시해줍니다.
Resilient : 탄력적인 , 유연한
고성능
단일 기계에서 최대 초당 5 천만 메시지 처리 가능하며
메모리 힙 GB 당 250 만명의 액터생성가능합니다.
탄성및 분산
단일 실패 지점이없는 분산 시스템. 로드 밸런싱 및 라우팅 노드. 클러스터 소싱을 사용한 이벤트 소싱 및
CQRS CRDT를 사용한 최종 일관성을위한 분산 데이터 프로그래밍 모델지원
반응형 스트리밍 데이터
성능에 있어서 역압력장치(backpressure) 사용으로, 비동기 비 차단 스트림을 모두 처리하려고함.
완전 비동기 및 스트리밍 HTTP 서버 및 클라이언트에서 마이크로 서비스를 구축하기위한 훌륭한 플랫폼을 제공합니다.
이것은 AkkaStream에서 지원을 합니다.
키워드로 살펴본 AKKA 제공 툴킷
추가 이점
JAVA와 .NET 진영에서 동시성및 고성능 분산메시징 처리에 관련된 문제를 동일해결모델을 통해 해결할수 있습니다.
그 해결방법을 AKKA를 통해 배울수도 있으며, 해결툴로 AKKA가 아니여도 됩니다.
그 중심엔 액터와 리액티브 스트림이 있습니다.
페이스북 채널을 통해서 최신 기술소식을 국내버전으로도 전달하고 있습니다.
액터모델을 도입한 개발 툴킷들
- Akka : http://akka.io/ -Akka (Scala및 Java에서 사용가능)
- Akka.net : http://getakka.net/ ( JVM버젼을 닷넷 변환으로 포팅)
- Erlang : http://erlang.org/doc/getting_started/conc_prog.html - Actor의 원조
- Orleans : https://dotnet.github.io/orleans/ - MS에서도 Actor모델을 도입
- LightBend : https://www.lightbend.com/products/reactive-platform (종합선물 셋트 : 중심엔 AKKA가있고 주위에 마이크로서비스를 위한 플랫폼이 있음)
- LightBend_한국지원 : http://www.qtii.co.kr/product/LRP.html
- PHP : https://dev.to/withinboredom/php-actors-dapr-39h1
- 코틀린 : https://github.com/psmon/kopring-reactive-labs/tree/main/KotlinBootReactiveLabs
- 코틀린 언어가 액터모델을 기본채택했으나~ akka툴킷에비해 깡옵션(pure actor)이라 akka 쿨다운 오픈소스인 pekko를 코틀린기반 연구한 저장소입니다.
그외 기타 정보
- 액터도입현황 : https://en.wikipedia.org/wiki/Actor_model#Actor_libraries_and_frameworks
- 파이썬 Actor : http://thespianpy.com/doc/#outline-container-orgheadline7
- 국내도서 추천 : Akka 코딩 공작소 ( 길벗 )
- https://www.axoniq.io/blog/axon-and-akka-how-do-they-compare : akka는 툴킷으로 분류되며, axon의 경우 프레임워크로 ddd(cqrs)를 활용할수 있는 환경을 제공합니다.
- Reactive Stream : https://www.reactive-streams.org/