최신 애플리케이션에는 확장성, 안정성 및 유지 관리 가능성이 필요합니다. 이 가이드에서는 운영 우수성을 유지하면서 실제 문제를 처리할 수 있는 마이크로서비스 아키텍처를 설계하고 구현하는 방법을 살펴보겠습니다.
우리 아키텍처를 안내하는 핵심 원칙부터 시작해 보겠습니다.
graph TD A[Service Design Principles] --> B[Single Responsibility] A --> C[Domain-Driven Design] A --> D[API First] A --> E[Event-Driven] A --> F[Infrastructure as Code]
다음은 Go를 사용하여 잘 구성된 마이크로서비스의 예입니다.
package main import ( "context" "log" "net/http" "os" "os/signal" "syscall" "time" "github.com/prometheus/client_golang/prometheus" "go.opentelemetry.io/otel" ) // Service configuration type Config struct { Port string ShutdownTimeout time.Duration DatabaseURL string } // Service represents our microservice type Service struct { server *http.Server logger *log.Logger config Config metrics *Metrics } // Metrics for monitoring type Metrics struct { requestDuration *prometheus.HistogramVec requestCount *prometheus.CounterVec errorCount *prometheus.CounterVec } func NewService(cfg Config) *Service { metrics := initializeMetrics() logger := initializeLogger() return &Service{ config: cfg, logger: logger, metrics: metrics, } } func (s *Service) Start() error { // Initialize OpenTelemetry shutdown := initializeTracing() defer shutdown() // Setup HTTP server router := s.setupRoutes() s.server = &http.Server{ Addr: ":" + s.config.Port, Handler: router, } // Graceful shutdown go s.handleShutdown() s.logger.Printf("Starting server on port %s", s.config.Port) return s.server.ListenAndServe() }
연속적인 오류로부터 서비스를 보호하세요.
type CircuitBreaker struct { failureThreshold uint32 resetTimeout time.Duration state uint32 failures uint32 lastFailure time.Time } func NewCircuitBreaker(threshold uint32, timeout time.Duration) *CircuitBreaker { return &CircuitBreaker{ failureThreshold: threshold, resetTimeout: timeout, } } func (cb *CircuitBreaker) Execute(fn func() error) error { if !cb.canExecute() { return errors.New("circuit breaker is open") } err := fn() if err != nil { cb.recordFailure() return err } cb.reset() return nil }
신뢰할 수 있는 이벤트 스트리밍을 위해 Apache Kafka 사용:
type EventProcessor struct { consumer *kafka.Consumer producer *kafka.Producer logger *log.Logger } func (ep *EventProcessor) ProcessEvents(ctx context.Context) error { for { select { case <-ctx.Done(): return ctx.Err() default: msg, err := ep.consumer.ReadMessage(ctx) if err != nil { ep.logger.Printf("Error reading message: %v", err) continue } if err := ep.handleEvent(ctx, msg); err != nil { ep.logger.Printf("Error processing message: %v", err) // Handle dead letter queue ep.moveToDeadLetter(msg) } } } }
인프라 관리를 위해 Terraform 사용:
# Define the microservice infrastructure module "microservice" { source = "./modules/microservice" name = "user-service" container_port = 8080 replicas = 3 environment = { KAFKA_BROKERS = var.kafka_brokers DATABASE_URL = var.database_url LOG_LEVEL = "info" } # Configure auto-scaling autoscaling = { min_replicas = 2 max_replicas = 10 metrics = [ { type = "Resource" resource = { name = "cpu" target_average_utilization = 70 } } ] } } # Set up monitoring module "monitoring" { source = "./modules/monitoring" service_name = module.microservice.name alert_email = var.alert_email dashboard = { refresh_interval = "30s" time_range = "6h" } }
서비스 API 계약 정의:
openapi: 3.0.3 info: title: User Service API version: 1.0.0 description: User management microservice API paths: /users: post: summary: Create a new user operationId: createUser requestBody: required: true content: application/json: schema: $ref: '#/components/schemas/CreateUserRequest' responses: '201': description: User created successfully content: application/json: schema: $ref: '#/components/schemas/User' '400': $ref: '#/components/responses/BadRequest' '500': $ref: '#/components/responses/InternalError' components: schemas: User: type: object properties: id: type: string format: uuid email: type: string format: email created_at: type: string format: date-time required: - id - email - created_at
종합 모니터링 설정:
# Prometheus configuration scrape_configs: - job_name: 'microservices' kubernetes_sd_configs: - role: pod relabel_configs: - source_labels: [__meta_kubernetes_pod_annotation_prometheus_io_scrape] action: keep regex: true # Grafana dashboard { "dashboard": { "panels": [ { "title": "Request Rate", "type": "graph", "datasource": "Prometheus", "targets": [ { "expr": "rate(http_requests_total{service=\"user-service\"}[5m])", "legendFormat": "{{method}} {{path}}" } ] }, { "title": "Error Rate", "type": "graph", "datasource": "Prometheus", "targets": [ { "expr": "rate(http_errors_total{service=\"user-service\"}[5m])", "legendFormat": "{{status_code}}" } ] } ] } }
다운타임 없는 배포 구현:
apiVersion: apps/v1 kind: Deployment metadata: name: user-service spec: replicas: 3 strategy: type: RollingUpdate rollingUpdate: maxSurge: 1 maxUnavailable: 0 template: spec: containers: - name: user-service image: user-service:1.0.0 ports: - containerPort: 8080 readinessProbe: httpGet: path: /health port: 8080 initialDelaySeconds: 5 periodSeconds: 10 livenessProbe: httpGet: path: /health port: 8080 initialDelaySeconds: 15 periodSeconds: 20
복원력이 뛰어난 마이크로서비스를 구축하려면 여러 요소를 신중하게 고려해야 합니다. 핵심은 다음과 같습니다.
마이크로서비스를 구축하면서 어떤 어려움을 겪었나요? 아래 댓글로 여러분의 경험을 공유해 주세요!
위 내용은 탄력적인 마이크로서비스 설계: 클라우드 아키텍처에 대한 실용 가이드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!