목록MSA (3)
공부하는 스누피

도커는 가상 머신을 대체하는 경량 컨테이너 개념을 새롭게 제시한 오픈 플랫폼으로, 애플리케이션들을 빠르게 구축할 수 있도록 한다. 컨테이너는 리눅스 호스트에서 실행되며, 리눅스 namespace를 이용해 시스템 리소스를 분배한다. 이 방법은 기존 가상 머신이 작동하는 방식보다 자원 사용량에 있어 효율적이다. 가상 환경이 기존 OS 위에 사용하고 싶은 OS를 올리는 방식이라면, 컨테이너는 도커가 대신 자원을 관리하기 때문에 오버헤드를 줄였다. 다음은 대표적인 도커 사용 사례이다. - 도커 컨테이너를 사용해 애플리케이션을 공유한다. - 테스트 환경 구축, 실행까지 자동화가 가능하다. - 개발 환경에서 수정한 애플리케이션을 테스트 환경에 재배포할 수 있다. - 테스트가 끝나면 상용 환경에 이미지를 쉽게 배포할..

서비스 검색 Service discovery 문제 client가 마이크로서비스와 인스턴스를 찾을 수 있어야 한다. 인스턴스의 동적 IP 주소는 인스턴스가 시작될때 할당받아서 HTTP 기반 API를 호출하기 어려워진다. 해결 => 사용 가능한 인스턴스와 서비스를 추적하는 새 컴포넌트(service discovery)를 추가한다. - 방법 1: 클라이언트 측 라우팅으로 클라이언트가 서비스 검색 서비스를 이용해 요청을 보낼 만한 인스턴스를 찾게 한다. - 방법 2: 서버 인프라에 리버스 프록시를 노출시켜 클라이언트를 대신해 적절한 인스턴스로 요청을 전달하게 한다. ex. 넷플릭스 유레카, 넷플릭스 리본, 쿠버네티스 kube-proxy, 쿠버네티스 서비스 리소스 에지 서버 Edge server 문제 공개된 마이..

마이크로서비스 마이크로서비스는 독자적인 업그레이드와 스케일링이 가능한 독립된 소프트웨어 컴포넌트이다. 일체형 애플리케이션과는 달리 마이크로서비스는 여러 개의 작은 서버에 배포할 수 있어 애플리케이션을 쉽게 확장하고 빠르게 개발할 수 있다. 마이크로서비스가 독립된 컴포넌트로 동작하려면 다음과 같은 기준을 충족해야 한다. - 아무것도 공유하지 않는 아키텍처를 유지해야 한다. (ex. 데이터베이스의 데이터 공유 x) - 동기 방식이나 명확한 API를 이용해서만 통신해야 한다. - 개별적인 런타임 프로세스로 배포해야 한다. - 마이크로서비스 인스턴스는 stateless하기 때문에 모든 인스턴스가 요청을 처리할 수 있다. 마이크로서비스 개발은 플랫폼의 각 기능을 독립적인 소프트웨어 컴포넌트로 개발하는 방식으로 이..