如何在Docker中部署Keycloak HA集群

时间:2018-09-17 03:35:47

标签: postgresql docker cluster-computing keycloak

我正在关注http://blog.keycloak.org/2015/04/running-keycloak-cluster-with-docker.html,并且在尝试运行第一个keycloak实例时:

docker run --name postgres -e POSTGRES_DATABASE=keycloak -e POSTGRES_USER=keycloak -e POSTGRES_PASSWORD=password -e POSTGRES_ROOT_PASSWORD=password -d postgres

docker run -p 8080:8080 --name keycloak --link postgres:postgres -e POSTGRES_DATABASE=keycloak -e POSTGRES_USER=keycloak -e POSTGRES_PASSWORD=password -d jboss/keycloak-ha-postgres

我遇到了错误:

javax.resource.ResourceException: IJ031083: Wrong driver class [org.postgresql.Driver] for this connection URL [jdbc:postgresql://postgres:tcp://172.17.0.2:5432/keycloak]

有人有使用此Keycloak Docker映像的经验吗?还是有更简单的方法将Keycloak集群部署到Docker?

2 个答案:

答案 0 :(得分:0)

您应该尝试使用图片后面的人提供的this more updated docker-compose file,其中可能包含更新的var名称和版本。我运行它,它正确创建了容器。只需下载文件并运行docker-compose up,即可运行堆栈。

在您提到的示例中,他们只是启动了另一个Docker容器,在docker compose中,这仅意味着添加一个新条目。查看要点:https://gist.github.com/pacuna/e7427d8fef752992ff1df944223ad0ab

现在,这不是运行docker容器集群的理想方法,如果这是一个严肃的项目,您可能想检出Kubernetes的docker swarm。 docker compose模板将很容易转换为Kubernetes文件。

答案 1 :(得分:0)

使用postgres在HA模式下部署密钥库的示例

version: '3'

volumes:
  postgres_data:
    driver: local

services:
  postgres:
    image: 'postgres:alpine'
    volumes:
      - ./postgres:/var/lib/postgresql/data
    restart: 'always'
    # ports:
    #   - 5432:5432
    environment:
      POSTGRES_USER: keycloak
      POSTGRES_PASSWORD: password
      POSTGRES_DB: keycloak
      POSTGRES_HOST: postgres

  traefik:
    image: library/traefik:alpine
    container_name: traefik
    volumes:
      - /var/run/docker.sock:/var/run/docker.sock
    command: >
      --logLevel=ERROR
      --api.dashboard
      --docker
      --entrypoints="Name:http Address::80"
      --defaultentrypoints="http"
    ports:
      - 80:80
      - 3000:8080

  keycloak:
    image: jboss/keycloak
    environment:
      DB_VENDOR: postgres
      DB_ADDR: postgres
      DB_PORT: 5432
      DB_DATABASE: keycloak
      DB_USER: keycloak
      DB_PASSWORD: password
      KEYCLOAK_USER: admin
      KEYCLOAK_PASSWORD: Pa55w0rd
      # KEYCLOAK_LOGLEVEL: DEBUG
      JGROUPS_DISCOVERY_PROTOCOL: JDBC_PING
      JGROUPS_DISCOVERY_PROPERTIES: datasource_jndi_name=java:jboss/datasources/KeycloakDS,info_writer_sleep_time=500,initialize_sql="CREATE TABLE IF NOT EXISTS JGROUPSPING ( own_addr varchar(200) NOT NULL, cluster_name varchar(200) NOT NULL, created timestamp default current_timestamp, ping_data BYTEA, constraint PK_JGROUPSPING PRIMARY KEY (own_addr, cluster_name))"
    depends_on:
      - postgres
    labels:
      traefik.enable: true
      traefik.port: 8080
      traefik.protocol: http
      traefik.frontend.rule: Host:localhost
      traefik.frontend.passHostHeader: true
      # traefik.backend.loadbalancer.stickiness: true

https://gist.github.com/ERRECabrera/a4fb1ebdba300521b46587881b66aaf4