我试图将配置从一个keycloak示例导入到许多不同的keycloak示例中(每个示例都用于相同的应用程序,只是我的CICD流中的不同部分)
我正在通过Docker运行keycloak,发现很难导入所需的json文件
为了获得我想要导入的实际数据,我转到所需的领域,并简单地单击导出按钮,选择客户端等。这将一个文件下载到我的浏览器中,我现在想要在构建我的docker容器时导入
我已经尝试了很多不同的方法,我发现网上似乎没有工作,所以我会感激一些帮助
我尝试的第一件事是通过docker-compose文件使用以下命令导入文件
KEYCLOAK_IMPORT: /realm-export.json
接下来我尝试的也是在我的docker-compose里
command: "-b 0.0.0.0 -Djboss.http.port=8080 -Dkeycloak.migration.action=import -Dkeycloak.import=realm-export.json
最后,我尝试进入我的Dockerfile并使用以下命令作为我的CMD运行导入
CMD ["-b 0.0.0.0", "-Dkeycloak.import=/opt/jboss/keycloak/realm-export.json"]
下面是我当前的docker-compose和没有添加导入的Dockerfiles,它们可能会对回答这个问题有所帮助。
# Dockerfile
FROM jboss/keycloak:4.8.3.Final
COPY keycloak-metrics-spi-1.0.1-SNAPSHOT.jar keycloak/standalone/deployments
和我的docker-compose文件的keycloak相关部分
postgres:
image: postgres
volumes:
- postgres_data:/var/lib/postgresql/data
environment:
POSTGRES_DB: keycl0ak
POSTGRES_USER: keycl0ak
POSTGRES_PASSWORD: password
ports:
- 5431:5431
keycloak:
build:
context: services/keycloak
environment:
DB_VENDOR: POSTGRES
DB_ADDR: postgres
DB_DATABASE: keycl0ak
DB_USER: keycl0ak
DB_PASSWORD: password
KEYCLOAK_USER: administrat0r
KEYCLOAK_PASSWORD: asc88a8c0ssssqs
ports:
- 8080:8080
depends_on:
- postgres
volumes:
postgres_data:
driver: local
4条答案
按热度按时间8hhllhi21#
说明
首先,你需要将文件复制到你的容器中,然后才能将其导入Keycloak。你可以将你的
realm-export.json
放在docker-compose.yml
旁边的文件夹中,假设我们称之为imports
。这可以使用volumes:
来实现。一旦文件被复制到容器中,你就可以像以前一样使用command:
。指向容器中的正确文件。文件结构
/your_computer/keycloak_stuff/
|--
docker-compose.yml
|--
imports
-〉realm-export.json
Docker-Compose
以下是
docker-compose.yml
在更改后的外观:r8xiu3jd2#
为了总结@JesusBenito和@raujonas的答案,可以更改docker-compose,以便您使用keyloak环境KEYCLOAK_IMPORT:
bvjveswy3#
这个配置为我工作:
mzaanser4#
在
21.0.2
版本中,唯一对我有用的是这个命令行参数和卷的精确Map。设置自定义文件夹似乎不像其他答案那样工作: