Configuração de trabalho

Configuração de trabalho

Configuração de trabalho

Eu tenho uma configuração de

  • VPS externo com IP público que possui proxy reverso Nginx (A)
  • servidor interno com Nginx (B)
  • aplicativo autônomo (não conteinerizado) Keycloak 17.0.1

Que se parece com isto. Eu tinha um domínio registrado para esse servidor que é (digamos)auth.exemplo.com

Quando eu for parahttps://auth.example.comPosso ver a página normal do keycloak com link para o console de administração.

insira a descrição da imagem aqui

Ao clicar no console de administração, posso fazer login corretamente para gerenciar o domínio mestre.

insira a descrição da imagem aqui

O problema

Assim que eu coloco o keycloak em contêiner, todos os links para o console de administração e alguns scripts não funcionam mais, pois são alterados de https://auth.example.comparahttps://localhost

insira a descrição da imagem aqui

Configurações

Ao colocar o keycloak em contêineres, não modifiquei nenhuma das configurações do nginx.

Nginx A

        location /
        {
                proxy_set_header Host $host;
                proxy_set_header X-Real-IP $remote_addr;
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                proxy_set_header X-Forwarded-Host $host;
                proxy_set_header X-Forwarded-Server $host;
                proxy_set_header X-Forwarded-Port $server_port;
                proxy_set_header X-Forwarded-Proto $scheme;
                proxy_pass http://[nginx b ip];
        }

NginxB

server
{
        server_name auth.example.com;
        location /
        {
            proxy_pass http://localhost:[exposed docker port];
        }
        listen 80;
}

Keycloak independente (comando de trabalho)

/usr/bin/bash bin/kc.sh start --proxy edge --hostname=auth.example.com --db-url-host localhost --db-username keycloak --db-password password

Keycloak dockerizado (docker-compose)

  keycloak:
    image: quay.io/keycloak/keycloak:latest
    command: start --auto-build --features=token-exchange --hostname-strict-backchannel=true --hostname=auth.example.com
    depends_on:
      - db
    environment:
      KC_METRICS_ENABLED: "true"
      DB_VENDOR: [somedbvendor]
      DB_ADDR: db
      DB_DATABASE: keycloak
      DB_USER: keycloak
      DB_PASSWORD: password
      KEYCLOAK_ADMIN: admin
      KEYCLOAK_ADMIN_PASSWORD: admin
      KC_PROXY: edge
      PROXY_ADDRESS_FORWARDING: "true"
    ports:
      - "8081:8080"
    networks:
      - net

Gostaria de colocar em contêiner todo o aplicativo que possuo e suas dependências e o keycloak é uma primeira etapa que não consigo concluir.

informação relacionada