web-dev-qa-db-ja.com

レルムファイルをkeycloakdockerコンテナにエクスポートする方法は?

レルムファイルをkeycloakdockerコンテナーにエクスポートしようとしていますが、次のコマンドを実行するとサーバーが実行されているため、エクスポートできません。

bin/standalone.sh -Dkeycloak.migration.action=export
-Dkeycloak.migration.provider=dir -Dkeycloak.migration.dir=<DIR TO EXPORT TO>

Docker-entrypoint.shを変更しようとしましたが、サーバーを実行して起動するコマンドを削除しました。

#!/bin/bash

if [ $KEYCLOAK_USER ] && [ $KEYCLOAK_PASSWORD ]; then
    keycloak/bin/add-user-keycloak.sh --user $KEYCLOAK_USER --password $KEYCLOAK_PASSWORD
fi

if [ "$DB_VENDOR" == "POSTGRES" ]; then
  databaseToInstall="postgres"
Elif [ "$DB_VENDOR" == "MYSQL" ]; then
  databaseToInstall="mysql"
Elif [ "$DB_VENDOR" == "H2" ]; then
  databaseToInstall=""
else
    if (printenv | grep '^POSTGRES_' &>/dev/null); then
      databaseToInstall="postgres"
    Elif (printenv | grep '^MYSQL_' &>/dev/null); then
      databaseToInstall="mysql"
    fi
fi

if [ "$databaseToInstall" != "" ]; then
    echo "[KEYCLOAK DOCKER IMAGE] Using the external $databaseToInstall database"
    /bin/sh /opt/jboss/keycloak/bin/change-database.sh $databaseToInstall
else
    echo "[KEYCLOAK DOCKER IMAGE] Using the embedded H2 database"
fi

exit $?

しかし、keycloakのポッドを実行すると、caschLoopBackを取得しました。 Dockerコンテナ内でエクスポートを行い、サーバーの実行を停止するための解決策はありますか?

9
Slim

一時コンテナを起動できます。私は群れと接続可能なネットワークを使用していますが、-networkフラグをDBコンテナへの--linkに置き換えると、Vanilladockerコンテナに対してそれを行う必要があります。

docker run --rm --network=naq\
    --name keycloak_exporter\
    -v /tmp:/tmp/keycloak-export\
    -e POSTGRES_DATABASE=keycloak\
    -e POSTGRES_PASSWORD=password\
    -e POSTGRES_USER=keycloak\
    -e DB_VENDOR=POSTGRES\
    -e POSTGRES_PORT_5432_TCP_ADDR=keycloakdb\
    jboss/keycloak:3.4.3.Final\
    -Dkeycloak.migration.action=export\
    -Dkeycloak.migration.provider=dir\
    -Dkeycloak.migration.dir=/tmp/keycloak-export\
    -Dkeycloak.migration.usersExportStrategy=SAME_FILE\
    -Dkeycloak.migration.realmName=Naq\

次に、ホストの/ tmpディレクトリにエクスポートファイルがあります。

12
Mat