>  기사  >  백엔드 개발  >  golang의 마이크로서비스란 무엇입니까?

golang의 마이크로서비스란 무엇입니까?

青灯夜游
青灯夜游원래의
2023-01-03 10:11:544373검색

golang에서 마이크로서비스(또는 마이크로서비스 아키텍처)는 단일 애플리케이션을 작은 서비스 집합으로 나누는 것을 옹호하는 소프트웨어 아키텍처 스타일(기술)입니다. 서비스는 서로 조정하고 협력하여 사용자에게 궁극적인 가치를 제공합니다. 각 서비스는 자체 독립적인 프로세스에서 실행되며 가벼운 통신 메커니즘(일반적으로 HTTP 기반 RESTful API)을 사용하여 서로 통신합니다. 각 서비스는 특정 비즈니스를 중심으로 구축되며 프로덕션과 유사한 프로덕션 환경에 독립적으로 배포될 수 있습니다. 환경 등

golang의 마이크로서비스란 무엇입니까?

이 튜토리얼의 운영 환경: Windows 7 시스템, GO 버전 1.18, Dell G3 컴퓨터.

마이크로서비스란 무엇입니까

마이크로서비스 아키텍처는 단일 애플리케이션을 그룹으로 나누는 것을 옹호하는 SOA(서비스 지향 아키텍처) 아키텍처 스타일의 변형인 소프트웨어 아키텍처 스타일입니다. 소규모 서비스는 서로 조정하고 협력합니다. 사용자에게 최고의 가치를 제공합니다. 각 서비스는 자체 독립 프로세스에서 실행되며 서비스는 경량 통신 메커니즘(일반적으로 HTTP 기반 RESTful API)을 사용하여 서로 통신합니다. 각 서비스는 특정 비즈니스를 중심으로 구축되었으며 프로덕션 환경, 프로덕션과 유사한 환경 등에 독립적으로 배포될 수 있습니다. 또한, 특정 서비스의 경우 상황에 따라 적절한 언어와 도구를 선택하여 통합되고 중앙화된 서비스 관리 메커니즘을 최대한 피해야 합니다.

마이크로서비스(또는 마이크로서비스 아키텍처)는 단일 애플리케이션이 느슨하게 결합되고 독립적으로 배포 가능한 여러 개의 작은 구성 요소 또는 서비스로 구성되는 클라우드 기반 아키텍처 접근 방식입니다. 이러한 서비스는 일반적으로

  • 데이터베이스 및 데이터 모델을 포함한 자체 스택을 갖고 있으며

  • REST API, 이벤트 스트림 및 메시지 브로커의 조합을 통해 서로 통신합니다.

  • , 서비스 분리 라인은 종종 제한된 컨텍스트라고 불립니다.

마이크로서비스에 대한 많은 논의가 아키텍처 정의 및 특성을 중심으로 이루어지지만, 그 가치는 매우 간단한 비즈니스 및 조직적 이점을 통해 더 일반적으로 이해할 수 있습니다.

  • 코드를 더 쉽게 업데이트할 수 있습니다.

  • 팀은 다양한 구성 요소에 대해 다양한 스택을 사용할 수 있습니다.

  • 구성 요소를 서로 독립적으로 확장할 수 있으므로 단일 기능이 과도한 로드에 직면할 수 있기 때문에 전체 애플리케이션을 확장해야 하는 낭비와 비용을 줄일 수 있습니다.

마이크로서비스를 사용하는 이유는 무엇인가요?

이 아키텍처는 전체 애플리케이션을 부분과 작은 모듈로 설명하는 데 도움이 되므로 각 서비스를 독립적으로 처리하고 해당 목적을 명확하게 표시하는 데 도움이 됩니다. 또한 이는 프로젝트 아키텍처의 일관성을 유지하는 데 도움이 됩니다(원래 설계된 아키텍처와 실제 개발된 아키텍처 간에 차이가 거의 없음). 또한 서로 다른 독립 팀을 구성하여 서비스를 배포 및 확장할 수 있으므로 각 팀이 병렬로 개발할 수 있습니다. 이 아키텍처에서는 코드 리팩토링이 더 쉽습니다. 또한 CI/CD(지속적인 전달 및 배포 프로세스)도 지원합니다.

go를 사용하여 마이크로서비스를 구축하는 이유는 무엇인가요?

이 질문에 대해 자세히 알아보기 전에. 먼저 Golang의 장점에 대해 말씀드리겠습니다. Golang은 새로운 언어이지만 다른 언어에 비해 장점이 많습니다. Golang으로 작성된 프로그램은 더욱 강력합니다. 실행 중인 서비스를 사용하여 프로그램이 구축하는 과도한 부하를 견딜 수 있습니다. Golang은 다중 프로세서 시스템 및 웹 애플리케이션에 더 적합합니다. 또한 GitHub와 쉽게 통합되어 분산된 코드 패키지를 관리할 수 있습니다. 마이크로서비스 아키텍처의 유용성은 프로그램을 확장해야 할 때 주로 반영됩니다. 표준을 완전히 준수하는 언어가 하나 있다면 바로 Golang입니다. 그 이유는 프로그래밍 언어인 C 계열을 상속받아 Golang으로 작성된 컴포넌트가 같은 계열의 다른 언어로 작성된 컴포넌트와 결합하기가 더 쉽기 때문입니다.

Go는 C 계열에서 나왔지만 C/C++보다 더 효율적입니다. Python과 다소 유사한 구문이 더 간단합니다. 구문은 안정적이며 첫 번째 공개 릴리스 이후 크게 변경되지 않았습니다. 즉, 이전 버전과 호환됩니다. 이는 golang이 다른 언어에 비해 우위를 점할 수 있게 해줍니다. 또한 Golang의 성능은 Python 및 Java보다 훨씬 높습니다. 금상첨화는 C/C++만큼 간단하면서도 읽고 이해하기 쉬우므로 마이크로서비스 애플리케이션 개발에 탁월한 선택이라는 점입니다.

Golang의 마이크로서비스 아키텍처 프레임워크

아래에서는 마이크로서비스 아키텍처에 사용할 수 있는 프레임워크에 대해 설명합니다. 다음과 같은 프레임워크가 있습니다.

Go Micro

Go Micro는 제가 지금까지 만난 RPC 프레임워크 중 가장 인기가 높습니다. 이는 플러그형 RPC 프레임워크입니다. Go Micro는 다음 기능을 제공합니다.

  • 서비스 검색: 프로그램이 서비스 검색 시스템에 자동으로 등록

  • 로드 밸런싱: 클라이언트 측 로드 밸런싱을 제공하여 서비스 인스턴스 간의 요청 균형을 맞추는 데 도움이 됩니다

  • 동기식 통신: 요청/응답 전송 계층 제공

  • 비동기식 통신: 게시 및 구독 기능 내장

  • 메시지 인코딩: 헤더의 Content-Type을 사용하여 인코딩 및 디코딩할 수 있습니다

  • RPC 클라이언트 엔드/서버 측: 위 기능을 활용하고 마이크로서비스 구축에 필요한 인터페이스를 제공합니다

Go 마이크로 아키텍처는 세 개의 레이어로 구성됩니다. 추상화의 첫 번째 수준은 서비스 계층입니다. 두 번째 계층은 클라이언트-서버 모델 계층입니다. 서버는 서비스 작성을 위한 블록으로 구성되며, 클라이언트는 서버 모델에 작성된 서비스에 요청하는 것이 유일한 목적인 인터페이스를 제공합니다.

세 번째 계층에는 다음과 같은 유형의 플러그인이 있습니다.

  • 브로커: 비동기 통신에서 메시지 브로커(메시지 브로커)에 대한 인터페이스를 제공합니다.

  • 코덱: 메시지를 암호화하거나 해독하는 데 사용됩니다.

  • 레지스트리 : 서비스 검색 기능 제공

  • Selector: 레지스터에 로드 밸런싱 내장

  • Transport: Transport는 서비스 간 동기 요청/응답을 위한 통신 인터페이스

Sidecar라는 기능도 제공합니다. 사이드카를 사용하면 Go 이외의 언어로 작성된 서비스를 통합할 수 있습니다. 또한 gRPC 인코딩/디코딩, 서비스 등록 및 HTTP 요청 처리 기능도 제공합니다.

GO Kit

Go Kit는 마이크로서비스 구축을 위한 프로그래밍 툴킷입니다. Go Micro와 달리 바이너리 패키지로 Import가 가능한 라이브러리입니다. Go Kit 규칙은 간단합니다. 다음과 같습니다.

  • 전역 변수 없음

  • 선언적 구성

  • 명시적 종속성

  • 계약으로서의 인터페이스(인터페이스 계약)

  • 도메인 기반 디자인(DDD)

고 키트 다음 코드 패키지가 제공됩니다.

  • 인증 인증: BasicAuth 및 JWT

  • 전송 프로토콜: HTTP, gRPC 등

  • 로깅 로깅: 서비스의 구조적 로깅 인터페이스

  • 측정항목: CloudWatch, Statsd, Graphite 및 기타

  • Tracing 분산 추적: Zipkin 및 OpenTracing

  • 서비스 검색 서비스 검색: Consul, ETCD, EUREKA 및 기타

  • circuitBreakes Flowing Flow: Hystrix의 Go 언어 구현

Go Kit 서비스 아키텍처는 다음과 같습니다

Gizmo

Gizmo는 The New York Times의 마이크로서비스 툴킷입니다. 서버 데몬과 pubsub 데몬을 함께 가져오는 패키지를 제공합니다. 다음 패키지를 공개합니다.

  • Server: 두 가지 서버 구현 제공: SimpleServer(HTTP) 및 RPCServer(gRPC)

  • Server/kit: Go Kit 기반 실험 코드 패키지

  • Config 구성: 구성 포함 JSON 파일의 함수, Consul k/v의 JSON blob 또는 환경 변수

  • Pubsub: 대기열의 데이터를 게시하고 소비하기 위한 공통 인터페이스 제공

  • Pubsub/pubsubtest: 게시자 및 구독 포함 테스트된 사용자 구현 인터페이스

  • 웹: 요청 쿼리 및 페이로드에서 유형을 구문 분석하기 위한 외부 기능

Pubsub 패키지는 다음 대기열을 처리하기 위한 인터페이스를 제공합니다.

  • pubsub/aws: Amazon SNS용 /SQS

  • pubsub/ gcp: for Google Pubsub

  • pubsub/kafka: for Kafka topic

  • pubsub/http: user HTTP push

그래서 Gizmo에서는 Between Go Micro와 Go Kit를 소개합니다. 고마이크로처럼 완전한 블랙박스는 아니다. 동시에 Go Kit만큼 원시적이지도 않습니다. 구성 및 pubsub 패키지와 같은 더 높은 수준의 구성 요소를 제공합니다.

Kite

Kite는 Go에서 마이크로서비스를 개발하기 위한 프레임워크입니다. RPC 클라이언트 및 서버 측 코드 패키지를 노출합니다. 생성된 서비스는 서비스 검색 시스템인 Kontrol에 자동으로 등록됩니다. Kontrol은 Kite로 작성되었으며 그 자체가 Kite 서비스입니다. 이는 Kite 마이크로서비스가 자체 환경에서 잘 작동한다는 것을 의미합니다. Kite 마이크로서비스를 다른 서비스 검색 시스템에 연결해야 하는 경우 사용자 정의가 필요합니다. 이것이 제가 목록에서 Kite를 선택하고 이 프레임워크를 도입하지 않기로 결정한 중요한 이유 중 하나입니다

[관련 권장 사항: Go 비디오 튜토리얼, 프로그래밍 교육]

위 내용은 golang의 마이크로서비스란 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.