go
Go kit 프레임워크
까오기
2024. 7. 17. 09:24
Go Kit은 Go 언어로 작성된 마이크로서비스 아키텍처를 구축하기 위한 라이브러리와 프레임워크입니다. Go Kit은 서비스 간의 통신, 로깅, 인스트루멘테이션, 트레이싱 등과 같은 마이크로서비스 개발의 일반적인 문제를 해결하는 데 중점을 둡니다.
Go Kit의 주요 특징
- 서비스 지향 아키텍처 지원: Go Kit은 서비스 지향 아키텍처(SOA)를 지원하며, 각 서비스가 독립적으로 배포 및 운영될 수 있도록 설계되었습니다.
- 모듈성: Go Kit은 모듈형으로 구성되어 있어 필요한 기능만 선택적으로 사용할 수 있습니다.
- 표준화된 인터페이스: Go Kit은 서비스 인터페이스를 표준화하여 서비스 간의 일관성을 유지합니다.
- 트랜스포트 계층: HTTP, gRPC, Thrift 등 다양한 트랜스포트 프로토콜을 지원합니다.
- 미들웨어 지원: 로깅, 인스트루멘테이션, 트레이싱 등의 기능을 미들웨어로 쉽게 추가할 수 있습니다.
- 테스트 용이성: 테스트 가능성을 염두에 두고 설계되어, 서비스의 각 부분을 독립적으로 테스트할 수 있습니다.
Go Kit의 주요 구성 요소
- Service: 서비스는 비즈니스 로직을 포함하는 가장 중요한 구성 요소입니다. Go Kit은 서비스 인터페이스와 구현을 정의하여 서비스 로직을 캡슐화합니다.
- Endpoint: 엔드포인트는 서비스 메서드를 네트워크 호출로 변환하는 함수입니다. 엔드포인트는 미들웨어를 통해 확장될 수 있습니다.
- Transport: 트랜스포트는 네트워크를 통해 데이터를 주고받는 계층입니다. Go Kit은 HTTP, gRPC, Thrift 등을 지원합니다.
- Middleware: 미들웨어는 엔드포인트와 트랜스포트의 기능을 확장하기 위한 방법입니다. 로깅, 인증, 인스트루멘테이션 등의 기능을 추가할 수 있습니다.
Go Kit 예제
간단한 서비스 예제를 통해 Go Kit의 사용 방법을 알아보겠습니다.
서비스 인터페이스 정의
먼저 서비스 인터페이스를 정의합니다.
package main
import (
"context"
"errors"
"fmt"
"net/http"
"github.com/go-kit/kit/endpoint"
httptransport "github.com/go-kit/kit/transport/http"
)
// StringService는 문자열 관련 연산을 정의하는 인터페이스입니다.
type StringService interface {
Uppercase(context.Context, string) (string, error)
Count(context.Context, string) int
}
// stringService는 StringService 인터페이스를 구현하는 구조체입니다.
type stringService struct{}
func (stringService) Uppercase(_ context.Context, s string) (string, error) {
if s == "" {
return "", errors.New("empty string")
}
return strings.ToUpper(s), nil
}
func (stringService) Count(_ context.Context, s string) int {
return len(s)
}
엔드포인트 정의
서비스 메서드를 엔드포인트로 변환합니다.
func makeUppercaseEndpoint(svc StringService) endpoint.Endpoint {
return func(ctx context.Context, request interface{}) (interface{}, error) {
req := request.(uppercaseRequest)
v, err := svc.Uppercase(ctx, req.S)
if err != nil {
return uppercaseResponse{v, err.Error()}, nil
}
return uppercaseResponse{v, ""}, nil
}
}
type uppercaseRequest struct {
S string `json:"s"`
}
type uppercaseResponse struct {
V string `json:"v"`
Err string `json:"err,omitempty"`
}
트랜스포트 정의
HTTP 트랜스포트를 정의합니다.
func main() {
svc := stringService{}
uppercaseHandler := httptransport.NewServer(
makeUppercaseEndpoint(svc),
decodeUppercaseRequest,
encodeResponse,
)
http.Handle("/uppercase", uppercaseHandler)
fmt.Println("Listening on port 8080...")
log.Fatal(http.ListenAndServe(":8080", nil))
}
func decodeUppercaseRequest(_ context.Context, r *http.Request) (interface{}, error) {
var request uppercaseRequest
if err := json.NewDecoder(r.Body).Decode(&request); err != nil {
return nil, err
}
return request, nil
}
func encodeResponse(_ context.Context, w http.ResponseWriter, response interface{}) error {
return json.NewEncoder(w).Encode(response)
}
위 예제는 간단한 문자열 변환 서비스입니다. 클라이언트가 /uppercase 엔드포인트에 요청을 보내면, 서버는 문자열을 대문자로 변환한 결과를 반환합니다.
요약
- Go Kit은 Go 언어로 마이크로서비스를 쉽게 구축할 수 있게 해주는 라이브러리와 프레임워크입니다.
- 모듈성, 표준화된 인터페이스, 다양한 트랜스포트 계층, 미들웨어 지원 등의 특징을 갖추고 있습니다.
- Service, Endpoint, Transport, Middleware는 Go Kit의 주요 구성 요소입니다.
- 예제를 통해 간단한 문자열 변환 서비스를 구현하고, 이를 통해 Go Kit의 사용법을 배울 수 있습니다.
Go Kit을 사용하면 복잡한 마이크로서비스 아키텍처를 더 쉽게 관리하고 개발할 수 있습니다. 이를 통해 확장 가능하고 유지 보수하기 쉬운 애플리케이션을 구축할 수 있습니다.
출처 : chatGPT