Kev*_* O. 6 jdbc mariadb docker keycloak docker-compose
钥匙斗篷版本:20.0.1
码头工人版本:20.10.12
Docker-Compose 版本:2.2.2
Github 问题:https://github.com/keycloak/keycloak/issues/15898
我喜欢从 MariaDB 数据库导出 Keycloak 数据,但这是不可能的。
我使用的来源是: https: //www.keycloak.org/server/importExport
导出命令export 仅接受 H2 数据库 URL,即使我已经使用适当的数据库供应商创建了构建。我在执行导出之前创建了一个新版本:build --db=mariadb
如果我尝试从 MariaDB 数据库导出 Keycloak 数据,则会显示错误。
错误是:
Datasource '<default>': URL format error; must be "jdbc:h2:{ {.|mem:}[name] | [file:]fileName | {tcp|ssl}:[//]server[:port][,server2[:port]]/name }[;key=value...]" but is "jdbc:mariadb://db.my-domain.de:3306/keycloak"
预期的行为是,该export命令接受 MariaDB 数据库 URL,例如jdbc:mariadb:...。
实际的行为是,该export命令只接受 H2 数据库 URL,jdbc:h2:...即使我build --db=mariadb之前执行过也是如此。
此外,show-config命令显示kc.db = mariadb (KcEnvVarConfigSource)事实并非如此。
version: '3.9'
services:
keycloak-export:
container_name: keycloak-export
image: quay.io/keycloak/keycloak:latest
environment:
KC_HOSTNAME: login.my-domain.com
KC_HOSTNAME_STRICT_HTTPS: true
KC_HTTP_ENABLED: false
KC_PROXY: edge
KC_DB: mariadb
KC_DB_URL_HOST: db.my-domain.com
KC_DB_URL_DATABASE: keycloak
KC_DB_URL_PORT: 3306
KC_DB_USERNAME: ***
KC_DB_PASSWORD: ***
KC_HTTPS_KEY_STORE_FILE: /keystore.p12
KC_HTTPS_KEY_STORE_PASSWORD: ***
command:
- export --dir /export_data
volumes:
- ./keystore.p12:/keystore.p12
- ./export_data:/export_data
restart: "no"
Run Code Online (Sandbox Code Playgroud)
在生产模式下,Keycloak-Server 基于以下 Docker Compose 文件连接到 MariaDB-Database-Server:
version: '3.9'
services:
keycloak:
container_name: keycloak
image: quay.io/keycloak/keycloak:latest
environment:
KC_HOSTNAME: login.my-domain.de
KC_HOSTNAME_STRICT_HTTPS: true
KC_HTTP_ENABLED: false
KC_PROXY: edge
KC_DB: mariadb
KC_DB_URL_HOST: db.my-domain.de
KC_DB_URL_DATABASE: keycloak
KC_DB_URL_PORT: 3306
KC_DB_USERNAME: ***
KC_DB_PASSWORD: ***
KC_HTTPS_KEY_STORE_FILE: /keystore.p12
KC_HTTPS_KEY_STORE_PASSWORD: ***
KEYCLOAK_ADMIN: ***
KEYCLOAK_ADMIN_PASSWORD: ***
KC_TRANSACTION_XA_ENABLED: true
KC_HEALTH_ENABLED: true
KC_METRICS_ENABLED: true
command:
- start
ports:
- 8080:8080
volumes:
- ./keystore.p12:/keystore.p12
restart: always
Run Code Online (Sandbox Code Playgroud)
您必须先构建配置,然后导出。所以你应该添加“build”命令。
version: '3.9'
services:
keycloak-export:
container_name: keycloak-export
image: quay.io/keycloak/keycloak:latest
environment:
KC_HOSTNAME: login.my-domain.com
KC_HOSTNAME_STRICT_HTTPS: true
KC_HTTP_ENABLED: false
KC_PROXY: edge
KC_DB: mariadb
KC_DB_URL_HOST: db.my-domain.com
KC_DB_URL_DATABASE: keycloak
KC_DB_URL_PORT: 3306
KC_DB_USERNAME: ***
KC_DB_PASSWORD: ***
KC_HTTPS_KEY_STORE_FILE: /keystore.p12
KC_HTTPS_KEY_STORE_PASSWORD: ***
command:
- build && export --dir /export_data
volumes:
- ./keystore.p12:/keystore.p12
- ./export_data:/export_data
restart: "no"
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4316 次 |
| 最近记录: |