Dockerized Kong 自省端点问题

问题描述 投票:0回答:1

我正在尝试按照本教程创建docker环境here

但是,在最后一步中,即使我做了上述所有操作,我仍收到以下错误:

要求:

curl "http://${HOST_IP}:8000/mock-postman"  -H "Accept: application/json"  -H "Authorization: Bearer $TKN"

回应:

accessing introspection endpoint (http://192.168.0.46:8180/realms/experimental/protocol/openid-connect/token/introspect) failed: timeout

为什么我会收到这样的错误?有什么想法吗?

我尝试重做每一步,看看是否遗漏了什么,但找不到任何东西。

此外,没有不记名令牌网关也能按预期运行。 要求:

 curl "http://${HOST_IP}:8000/mock-postman"-H "Accept:application/json"-I

回应:

HTTP/1.1 401 Unauthorized
Date: Sun, 02 Jun 2024 18:22:05 GMT
Connection: keep-alive
WWW-Authenticate: Bearer realm="experimental",error="no Authorization header found"
X-Kong-Response-Latency: 1
Server: kong/2.8.3

顺便说一句,我的 docker-compose.yml 如下所示,与教程中的没有什么不同:

version: '3.4'

networks: 
  kong-net:
    driver: bridge
  keycloak-net:

volumes:
  kong-datastore:
  keycloak-datastore:

services:
  kong-db:
    image: postgres:11-alpine
    volumes:
      - kong-datastore:/var/lib/postgresql/data
    networks:
      - kong-net
    ports:
      - "15432:5432"
    environment:
      POSTGRES_DB:       api-gw
      POSTGRES_USER:     kong
      POSTGRES_PASSWORD: kong

  kong:
    build:
      context: ./      
    image: kong-oidc:latest
    depends_on:
      - kong-db
    networks:
      - kong-net
    ports:
      - "8000:8000" # Listener
      - "8001:8001" # Admin API
      - "8443:8443" # Listener  (SSL)
      - "8444:8444" # Admin API (SSL)
    environment:
      KONG_DATABASE:         postgres
      KONG_PG_HOST:          kong-db
      KONG_PG_PORT:          5432
      KONG_PG_DATABASE:      api-gw
      KONG_PG_USER:          kong
      KONG_PG_PASSWORD:      kong
      KONG_PROXY_ACCESS_LOG: /dev/stdout
      KONG_ADMIN_ACCESS_LOG: /dev/stdout
      KONG_PROXY_ERROR_LOG:  /dev/stderr
      KONG_ADMIN_ERROR_LOG:  /dev/stderr
      KONG_PROXY_LISTEN:     0.0.0.0:8000, 0.0.0.0:8443 ssl
      KONG_ADMIN_LISTEN:     0.0.0.0:8001, 0.0.0.0:8444 ssl
      KONG_PLUGINS:          bundled,oidc
      KONG_LOG_LEVEL:        debug

  konga:
    image: pantsel/konga:0.14.9
    depends_on:
      - kong
    networks:
      - kong-net
    ports:
      - "1337:1337" # konga
    environment:
      DB_ADAPTER: postgres
      DB_HOST: kong-db
      DB_PORT: '5432'
      DB_USER: kong
      DB_PASSWORD: kong
      DB_DATABASE: api-gw
      NODE_ENV: development

  keycloak-db:
    image: postgres:14-alpine
    volumes: 
      - keycloak-datastore:/var/lib/postgresql/data
    networks:
      - keycloak-net
    ports:
      - "25432:5432"
    environment:
      POSTGRES_DB:       keycloak
      POSTGRES_USER:     keycloak
      POSTGRES_PASSWORD: password

  keycloak:
    image: quay.io/keycloak/keycloak:20.0.1
    depends_on:
      - keycloak-db
    command: start-dev
    networks:
      - keycloak-net
    ports:
      - "8180:8080"
    environment:
      KC_DB:       postgres
      KC_DB_URL:   jdbc:postgresql://keycloak-db/keycloak
      KC_DB_USERNAME: keycloak
      KC_DB_PASSWORD: password
      KEYCLOAK_ADMIN:           admin
      KEYCLOAK_ADMIN_PASSWORD:  admin
      KC_METRICS_ENABLED: 1

  prometheus:
    image: prom/prometheus
    depends_on:
      - kong
    container_name: prometheus
    networks:
      - kong-net
    restart: always
    volumes: 
      - ./prometheus.yml:/etc/prometheus/prometheus.yml
    command: "--config.file=/etc/prometheus/prometheus.yml --storage.tsdb.path=/prometheus"
    ports: 
      - 9090:9090

  grafana:
    image: grafana/grafana
    depends_on:
      - prometheus
    container_name: grafana
    networks:
      - kong-net
    restart: always
    volumes: 
      - ./grafana/provisioning/:/etc/grafana/provisioning
    ports:
      - 3000:3000

根据kong日志没有错误:

2024/06/05 12:02:59 [debug] 1108#0: *75515 [lua] openidc.lua:392: openidc_call_token_endpoint(): request body for introspection endpoint call: token=<my_token>&client_secret=<my_client_secret>&client_id=kong
2024/06/05 12:02:59 [debug] 1108#0: *75515 [lua] openidc.lua:354: openidc_configure_proxy(): openidc_configure_proxy : don't use http proxy
2024/06/05 12:03:04 [debug] 1118#0: *75855 [lua] init.lua:288: [cluster_events] polling events from: 1717588494.292
2024/06/05 12:03:09 [debug] 1126#0: *76216 [lua] init.lua:288: [cluster_events] polling events from: 1717588494.292
2024/06/05 12:03:14 [debug] 1122#0: *76577 [lua] init.lua:288: [cluster_events] polling events from: 1717588494.292
2024/06/05 12:03:19 [debug] 1110#0: *76938 [lua] init.lua:288: [cluster_events] polling events from: 1717588494.292
2024/06/05 12:03:24 [debug] 1117#0: *77299 [lua] init.lua:288: [cluster_events] polling events from: 1717588494.292
2024/06/05 12:03:29 [debug] 1109#0: *77659 [lua] init.lua:288: [cluster_events] polling events from: 1717588494.292
2024/06/05 12:03:34 [debug] 1120#0: *78021 [lua] init.lua:288: [cluster_events] polling events from: 1717588494.292
2024/06/05 12:03:39 [debug] 1117#0: *78382 [lua] init.lua:288: [cluster_events] polling events from: 1717588494.292
2024/06/05 12:03:44 [debug] 1121#0: *78742 [lua] init.lua:288: [cluster_events] polling events from: 1717588494.292
2024/06/05 12:03:49 [debug] 1127#0: *79103 [lua] init.lua:288: [cluster_events] polling events from: 1717588494.292
2024/06/05 12:03:54 [debug] 1115#0: *79464 [lua] init.lua:288: [cluster_events] polling events from: 1717588494.292
2024/06/05 12:03:59 [debug] 1116#0: *79825 [lua] init.lua:288: [cluster_events] polling events from: 1717588494.292
2024/06/05 12:03:59 [error] 1108#0: *75515 [lua] openidc.lua:405: openidc_call_token_endpoint(): accessing introspection endpoint (http://192.168.0.18:8180/realms/experimental/protocol/openid-connect/token/introspect) failed: timeout, client: 192.168.0.18, server: kong, request: "GET /mock-postman HTTP/1.1", host: "192.168.0.18:8000"
192.168.0.18 - - [05/Jun/2024:12:03:59 +0000] "GET /mock-postman HTTP/1.1" 401 148 "-" "curl/8.5.0"
2024/06/05 12:03:59 [info] 1108#0: *75515 client 192.168.0.18 closed keepalive connection
enter code here
docker keycloak kong kong-plugin konga
1个回答
0
投票

即使我无法从这个社区得到答案,我还是设法解决了我的问题并写了一篇medium文章来回答这个问题:

我正在遵循的教程中似乎缺少一些步骤,所以我修复了它。

© www.soinside.com 2019 - 2024. All rights reserved.