You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 10 Next »

 최근에는 AKKA자체의 장점을 주위 사람에게 소개해주고 있지만, 성공사례가 있는지? 들어보긴했는데 그걸 왜 배워라던지?

설득하는데는 어려움에 있습니다. 국내에서 성공사례가 잘없고  운영서비스 자체에 대부분 분산 처리 뿐아니라

실시간 처리 장치가 없으며, 부자연스럽게 어떤 외부장치 또는 솔류션과 연동하여 분산 서비스를 잘 유지시키고 있기때문입니다.


하지만 "분산환경에서 유연한  동시성 개발모델" 이라는 주제하에

언랭-OTP / GO언어등  직접 서비스에 녹인 성공사례가 많이 나오고 있으며,  성공사례의 이면을 살펴보면

기존 언어및 프레임워크 그리고 고전전인 해결방법의 문제점을 철저하게 분석하고 새로운 개발 모델을 제시한다란점입니다.

기존 개발언어및 프레임워크를 바꿔서 해결한다? 이것은 더 심각한 문제가 될것입니다. 


 자바및 닷넷프레임워크 진영에서 우리의 방식으로 문제를 풀래라고 귀를 닫았으면  AKKA는 탄생하지 못했습니다.

자바 진영에서는 심지어 SCALA라는 새로운 언어를 만들고 JAVA와 AKKA를 동시에 사용할수있는 프레임워크도 만들었습니다.

또한 기존 솔리드형태의 웹서비스의 한계를 느끼고 https://www.playframework.com/ 라는 새로운 마이크로서비스에 적합한 웹서비스도 준비했습니다.



MS진영에서도 이에 대응하기위해  orleans 이라는 프로젝트를 공식적으로 진행하고 있으며, 저의 플래폼 예상이 항상맞지는

않으나~  언젠가 닷넷 프레임워크에 기본으로 탑재를 시킬듯도 보입니다.

또한  MS역시 IIS형태의 솔리드 서비스가 스케일아웃이되는 분산환경에 적합하지 않을것으로 분석하고

 http://owin.org/  라는 오픈형 웹서비스를  MS가 개발팀을사고 닷넷프레임워크에 공식적으로 녹였습니다.

오픈프로젝트는 별개로 진행되고 있으며 asp.net 개발자도 잘모르더군요   microsoft.iis.host 같은 네임스페이스를 버린지 오래되었으며

실제 asp.net이 owin.host 기반으로 작동중인 사실을  owin.host의 탄생배경은 윈도우/IIS탈출을 통한 마이크로 웹서비스에 있습니다.

이야기가 돌아 웹서비스까지 갔지만 , 웹서비스 환경에 적용하는 이슈라면 중요한 내용입니다.


어쨋건 Actor개념은 언랭에서 나왔으며, Actor모델 지원은 각 진영에서 가진 프레임워크에서 아주 중요하게 생각하고

있다란것이며, 과장을 하면 AKKA의 시작은 Actor이며 마지막까지 Actor입니다.

분산환경 비동기처리를 유연하게 하기 위해 AKKA일 필요는 없습니다.


다만 이에 준하는 개발모델을 미리 익혀두고 대비해두는것

능동적으로 개발모델을 개선하지 않는 다고하면 새로운 개발 모델을 배울필요가 없습니다.

액터는 능동적으로 적용하지 않으면, 성공할수 없습니다.

비능동적으로 완성된 어떠한 메시지큐 서비스를 이용하는게 적합하다라고하면

그것을 통해 성공적인 서비스를 해도 무관합니다. 


하지만 각 주요 플래폼 개발 진영에서 서비스 해도 문제없을만큼 성공 사례와 문서및 샘플을 준비 해놓았으며

개발자에게 능동적으로 분산환경을 직접 설계할수 있는 기회를 줬다라고 생각하며,

이 기회를 놓치면 안된다라고 생각합니다.

객체 지향이후 비동기프로그래밍에 이은  액터모델은 새로운 개발 패러다임이 되지 않을까? 추측해보며

아래 링크를 통해 각 진영에서 어떻게 프로젝트가 진행이 되고 있는지 정도는 파악을 하면 도움이 될듯 합니다.


Actor지원 개발 툴킷:

확장에 용이한 마이크로 웹서비스: 웹서비스를 한곳에 몰아넣고, 내부에서 추가삭제가 용이한 솔리드 형태와 반대성격입니다.

기타: c++ python node.js 등 주요 메이져 언어에서도 actor를 지원하려는 움직임이 구글링을 통해 포착이됩니다.


분산환경 동시성처리를 위해 Actor가 유일한 개발모델이 아니며, 언젠가 Actor모델의 단점을 지적하는 새로운 개발모델이 나올수도 있습니다.

언급대상이 너무많고 주제가 흐려질까 제외하였습니다. 이러한 개발모델은 사실 파악못할정도로 많습니다.

다만 액터모델은 자바/MS진영에 서 공식적으로 지원하는 개발 모델이며

분산환경에서의 서비스 설계를 개발자에게 직접할수있게 라이브러리를 통해 제공해준다란 것입니다.

개발자가 직접하지 않는다면, 이러한 분산환경 서비스 설계는 데브옵스에게 뺏기거나, 데브옵스화가 될것입니다.

액터와 반대인 해결방법으로 개발자의 관여없이 설치형/클라우드 완성형 패키지 서비스를 사용해서 부분적으로 해결하는 방법도 있기때문입니다.

하지만 그것또한, Akka Stream 을 제공하여 외부와 고응답성 실시간으로 잘 연동하는 방법에 대해 가이드를 제시해줍니다.

Akka with (알고 있는 모든 패키지형 분산처리시스템) 으로 구글링을 통해 확인이 가능합니다.




  • No labels