2

我有 3 个项目:一个 hystrix 仪表板、一个涡轮服务器(使用 AMQP)和一个 API

当我开始开发环境时,我设置了 2 个 API 实例(使用端口 8080 和 8081)。为了测试涡轮机聚合,我拨打了电话,在仪表板中,我可以看到Hosts: 2.
虽然当我使用 Docker 时,即使负载均衡器命中 2 台服务器,我也只能在 hystrix 仪表板上看到一台主机。

我的假设:
1-因为两个容器都在同一个端口(8080)上启动,Turbine 将它们视为一个
2-因为我也对 RabbitMQ 进行了 dockerize,这可能会导致问题

这是我的docker-compose.yml文件

version: '2'
    services:
      postgres:
        image: postgres:9.5
        ports:
          - "5432"
        environment:
          POSTGRES_PASSWORD: postgres
          POSTGRES_USER: postgres
          POSTGRES_DB: fq
        volumes:
          - /var/lib/postgresql

      rabbitmq:
        image: rabbitmq:3-management
        ports:
          - "5672"
          - "15672"
        environment:
          RABBITMQ_DEFAULT_USER: turbine
          RABBITMQ_DEFAULT_PASS: turbine
        volumes:
          - /var/lib/rabbitmq/

      hystrix:
        build: hystrixdashboard/.
        links:
          - turbine_server
        ports:
          - "8989:8989"

      turbine_server:
        build: turbine/.
        links:
          - rabbitmq
        ports:
          - "8090:8090"

      persona_api:
        build: persona/.
        ports:
          - "8080"
        links:
          - postgres
          - rabbitmq

      lb:
        image: 'dockercloud/haproxy:1.5.1'
        links:
          - persona_api
        volumes:
          - /var/run/docker.sock:/var/run/docker.sock
        ports:
          - 80:80

我的persona_api配置文件

 spring:
  application:
    name: persona_api
  profiles:
    active: dev
  rabbitmq:
    addresses: 127.0.0.1:5672
    username: turbine
    password: turbine
    useSSL: false

server:
  compression.enabled: true
  port: ${PORT:8080}

params:
  datasource:
    driverClassName: org.postgresql.Driver
    username: postgres
    password: postgres
    maximumPoolSize: 10
    poolName: fq_connection_pool

spring.jpa:
  show-sql: true
  hibernate:
    ddl-auto: update

turbine:
  aggregator:
    clusterConfig: persona_api
  appConfig: persona_api

---

spring:
  profiles: dev

params:
  datasource:
    jdbcUrl: jdbc:postgresql://127.0.0.1:5432/fq
---

spring:
  profiles: docker
  rabbitmq:
    addresses: rabbitmq:5672

params:
  datasource:
    jdbcUrl: jdbc:postgresql://postgres:5432/fq

恐怕如果我将它部署到生产环境(在 Rancher 或 Docker 云上),我会看到同样的问题。

这是我设置两个负载平衡的 API 时发生的事情的 GIF

在此处输入图像描述

4

3 回答 3

1

尝试:

hystrix.stream.queue.send-id=false

在您的 API 中

于 2017-01-25T13:56:35.017 回答
0

我确实假设您的问题是您正在使用的 RabbitMQ 连接。因为您使用的连接字符串是 localhost,但实际上除了 RabbitMQ 容器之外,连接将在 localhost 上可用。我建议您使用环境变量将 Rabbit 主机注入您的 Spring 连接。如果我正确阅读了您的文件,则应该是${RABBITMQ_PORT_5672_TCP_ADDR}本地主机而不是本地主机。但请注意,我无法尝试。这只是一个有根据的猜测。当一切都在运行时,最好通过env在您的 persona_api 容器中进行仔细检查。

于 2016-06-20T18:50:05.483 回答
0

应该可以解决你的问题。

eureka:
  instance:
    prefer-ip-address: true
    instance-id: ${spring.cloud.client.ipAddress}:${server.port}  #make the application unique on the rancher service layer
spring:
  application:
    index: ${random.uuid} #make the application unique on the rancher containe layer,same service but with multi-instances.

https://github.com/spring-cloud/spring-cloud-netflix/issues/740

需要 instance-id:${spring.cloud.client.ipAddress}:${server.port} 和 index: ${random.uuid} 两者

于 2017-10-16T14:30:50.260 回答