簡體   English   中英

Spring Cloud Gateway Kubernetes Eureka java.net.UnknownHostException:無法解決

[英]Spring Cloud Gateway Kubernetes Eureka java.net.UnknownHostException: failed to resolve

我正在開發一個具有微服務架構的項目。 我有 Spring 雲網關、eureka 服務發現和預訂微服務。 當我在本地運行這些應用程序時,一切正常。 當我用 docker compose 運行這些時,仍然沒有問題。 但是當我將這些部署到 kubernetes 時,我在 api 網關上收到錯誤。 當我在 api 網關上向 /book 發送 get 請求時出現此錯誤

api網關錯誤:

java.net.UnknownHostException: failed to resolve 'book-service-55665db7ff-bd75t' after 2 queries 
        at io.netty.resolver.dns.DnsResolveContext.finishResolve(DnsResolveContext.java:1046) ~[netty-resolver-dns-4.1.68.Final.jar!/:4.1.68.Final]
        Suppressed: reactor.core.publisher.FluxOnAssembly$OnAssemblyException: 
Error has been observed at the following site(s):
        |_ checkpoint ⇢ org.springframework.cloud.gateway.filter.WeightCalculatorWebFilter [DefaultWebFilterChain]
        |_ checkpoint ⇢ HTTP GET "/book" [ExceptionHandlingWebHandler]

api網關配置:

server:
  port: 8084
spring:
  application:
    name: api-gateway
  cloud:
    gateway:
      routes:
      - id: book
        uri: lb://BOOK-SERVICE/book
        predicates:
        - Path=/book/**
      - id: author
        uri: lb://BOOK-SERVICE/author
        predicates:
        - Path=/author/**
      - id: genre
        uri: lb://BOOK-SERVICE/genre
        predicates:
        - Path=/genre/**

預訂微服務配置:

spring:
  application:
    name: BOOK-SERVICE
  datasource:
    url: jdbc:postgresql://localhost:5432/book_service
    username: postgres
    password: password
  jpa:
    hibernate:
      ddl-auto: update
    properties:
      hibernate:
        dialect: org.hibernate.dialect.PostgreSQL10Dialect
server:
  port: 8081

Kubernetes 清單:

#secret
apiVersion: v1
kind: Secret
metadata:
  name: database
type: Opaque
data:
  password: cGFzc3dvcmQ=
---
#api gateway
apiVersion: apps/v1
kind: Deployment
metadata:
  name: api-gateway
  labels:
    app: api-gateway
spec:
  replicas: 1
  selector:
    matchLabels:
      app: api-gateway
  template:
    metadata:
      labels:
        app: api-gateway
    spec:
      containers:
      - name: api-gateway
        image: rikaciv802/api-gateway
        ports:
        - containerPort: 8084
        env:
        - name: eureka.client.serviceUrl.defaultZone
          value: http://service-discovery:8761/eureka
---
apiVersion: v1
kind: Service
metadata:
  name: api-gateway
spec:
  selector:
    app: api-gateway
  type: LoadBalancer
  ports:
    - protocol: TCP
      port: 8084
      targetPort: 8084
      nodePort: 30000
---
#service discovery
apiVersion: apps/v1
kind: Deployment
metadata:
  name: service-discovery
  labels:
    app: service-discovery
spec:
  replicas: 1
  selector:
    matchLabels:
      app: service-discovery
  template:
    metadata:
      labels:
        app: service-discovery
    spec:
      containers:
      - name: service-discovery
        image: rikaciv802/service-discovery
        ports:
        - containerPort: 8761
---
apiVersion: v1
kind: Service
metadata:
  name: service-discovery
spec:
  selector:
    app: service-discovery
  ports:
    - protocol: TCP
      port: 8761
      targetPort: 8761
---
#book service
apiVersion: apps/v1
kind: Deployment
metadata:
  name: book-service-database
  labels:
    app: book-service-database
spec:
  replicas: 1
  selector:
    matchLabels:
      app: book-service-database
  template:
    metadata:
      labels:
        app: book-service-database
    spec:
      containers:
      - name: book-service-database
        image: postgres:14.0
        ports:
        - containerPort: 5432
        env:
        - name: POSTGRES_DB
          value: book_service
        - name: POSTGRES_PASSWORD
          valueFrom:
            secretKeyRef:
              name: database
              key: password
---
apiVersion: v1
kind: Service
metadata:
  name: book-service-database
spec:
  selector:
    app: book-service-database
  ports:
    - protocol: TCP
      port: 5432
      targetPort: 5432
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: book-service
  labels:
    app: book-service
spec:
  replicas: 1
  selector:
    matchLabels:
      app: book-service
  template:
    metadata:
      labels:
        app: book-service
    spec:
      containers:
      - name: book-service
        image: rikaciv802/book-service
        ports:
        - containerPort: 8081
        env:
        - name: eureka.client.serviceUrl.defaultZone
          value: http://service-discovery:8761/eureka
        - name: SPRING_DATASOURCE_URL
          value: jdbc:postgresql://book-service-database:5432/book_service
        - name: SPRING_DATASOURCE_PASSWORD
          valueFrom:
            secretKeyRef:
              name: database
              key: password
---
apiVersion: v1
kind: Service
metadata:
  name: book-service
spec:
  selector:
    app: book-service
  ports:
    - protocol: TCP
      port: 8081
      targetPort: 8081

服務發現配置:

eureka:
  client:
    register-with-eureka: false
    fetch-registry: false
server:
  port: 8761

您的 pod 主機名似乎存在 DNS 問題。 在 kubernetes 中,pod 的 DNS 名稱通常格式如下: pod-ip-address.deployment-name.my-namespace.svc.cluster-domain.example (參見https://kubernetes.io/docs/concepts/services-networking /dns-pod-service/#pods )

您可以通過使用 IP 地址來解決此問題:將eureka.instance.preferIpAddress設置為true

https://cloud.spring.io/spring-cloud-netflix/multi/multi_spring-cloud-eureka-server.html#spring-cloud-eureka-server-prefer-ip-address

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM