Скрытие ключей с пользовательским развертыванием докера федерации пользователей

#java #docker #jboss #keycloak #federated-identity

#java #docker #jboss #keycloak #федеративная идентификация

Вопрос:

Я пытаюсь развернуть Keycloak с помощью пользовательского поставщика федерации пользователей в docker. Я хочу использовать внешнюю базу данных в качестве дополнительного источника аутентификации пользователя. Я протестировал конфигурацию на своем хосте (весь проект извлечен из .tar.gz ) и это работает — я могу искать пользователей из внешней базы данных в панели администратора или входить в keycloak.

Проблема в том, что когда я запускаю свой контейнер, я получаю следующую ошибку:

 12:36:36,127 ERROR [org.jboss.as.controller.management-operation] (Controller Boot Thread) WFLYCTL0013: Operation ("deploy") failed - address: ([("deployment" => "custom-user-storage-jpa.jar")]) - failure description: {
"WFLYCTL0412: Required services that are not installed:" => ["jboss.naming.context.java.jboss.datasources.ExternalPostgresDS"],
"WFLYCTL0180: Services with missing/unavailable dependencies" => [
    "jboss.persistenceunit."custom-user-storage-jpa.jar#custom-user-storage-jpa" is missing [jboss.naming.context.java.jboss.datasources.ExternalPostgresDS]",
    "jboss.persistenceunit."custom-user-storage-jpa.jar#custom-user-storage-jpa".__FIRST_PHASE__ is missing [jboss.naming.context.java.jboss.datasources.ExternalPostgresDS]"
]
  

поэтому я предполагаю, что мой jar не видит источник данных, настроенный в standalone.xml с помощью (с именем ExternalPostgresDS)

Существует persistance.xml в моем поставщике пользовательского хранилища, позже встроенном в jar с помощью maven clean install

     <?xml version="1.0" encoding="UTF-8" ?>
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="
        http://java.sun.com/xml/ns/persistence
        http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
    <persistence-unit name="custom-user-storage-jpa">
        <jta-data-source>java:jboss/datasources/ExternalPostgresDS</jta-data-source>
        <properties>
            <property name="hibernate.hbm2ddl.auto" value="none" />
            <property name="hibernate.show_sql" value="false" />
            <property name="hibernate.dialect" value="org.hibernate.dialect.PostgreSQL95Dialect" />
        </properties>
    </persistence-unit>
</persistence>
  

Существует также раздел в standalone.xml определение этого источника данных и драйвера

                 <xa-datasource jndi-name="java:jboss/datasources/ExternalPostgresDS" pool-name="ExternalPostgresDS" enabled="true" use-java-context="true" statistics-enabled="${wildfly.datasources.statistics-enabled:${wildfly.statistics-enabled:false}}">
                    <xa-datasource-property name="ServerName">
                        address...
                    </xa-datasource-property>
                    <xa-datasource-property name="PortNumber">
                        5432
                    </xa-datasource-property>
                    <xa-datasource-property name="DatabaseName">
                        dbname...
                    </xa-datasource-property>
                    <xa-datasource-class>org.postgresql.xa.PGXADataSource</xa-datasource-class>
                    <driver>postgresql</driver>
                    <security>
                        <user-name>username...</user-name>
                        <password>password...</password>
                    </security>
                    <validation>
                        <valid-connection-checker class-name="org.jboss.jca.adapters.jdbc.extensions.postgres.PostgreSQLValidConnectionChecker"/>
                        <exception-sorter class-name="org.jboss.jca.adapters.jdbc.extensions.postgres.PostgreSQLExceptionSorter"/>
                    </validation>
                </xa-datasource>
                <drivers>
                    <driver name="postgresql" module="org.postgresql">
                        <xa-datasource-class>org.postgresql.xa.PGXADataSource</xa-datasource-class>
                    </driver>
                    <driver name="h2" module="com.h2database.h2">
                        <xa-datasource-class>org.h2.jdbcx.JdbcDataSource</xa-datasource-class>
                    </driver>
                </drivers>
  

И, наконец, есть Dockerfile, который должен настроить официальный образ keycloak в соответствии с моими потребностями:

 FROM jboss/keycloak:11.0.2

ENV DB_VENDOR postgres
ENV DB_ADDR addr..
ENV DB_DATABASE dbname...
ENV DB_USER user...
ENV DB_PASSWORD password...
ENV PROXY_ADDRESS_FORWARDING true
ENV KEYCLOAK_USER admin
ENV KEYCLOAK_PASSWORD password

COPY ./_resources/standalone.xml /opt/jboss/keycloak/standalone/configuration/standalone.xml
COPY ./_resources/custom-user-storage-jpa.jar /opt/jboss/keycloak/standalone/deployments/custom-user-storage-jpa.jar
COPY ./_resources/postgresql/main/module.xml /opt/jboss/keycloak/modules/system/layers/keycloak/org/postgresql/main/module.xml
COPY ./_resources/postgresql/main/postgresql-42.2.18.jar /opt/jboss/keycloak/modules/system/layers/keycloak/org/postgresql/main/postgresql-42.2.18.jar

ENV JAVA_OPTS -server -Xms2048m -Xmx6144m -XX:MetaspaceSize=96M -XX:MaxMetaspaceSize=256m

EXPOSE 8080
  

Конечно, я проверил, что скопированные файлы верны и находятся на своем месте внутри запущенного контейнера, после запуска все работает нормально, но без моего развертывания пользовательского хранилища.

Чего мне не хватает?

Ответ №1:

Похоже, что ваш standalone.xml файл не был прочитан, и jboss пытается вместо этого использовать конфигурацию по умолчанию.

Есть упоминание об обновлении имени файла по умолчанию до standalone-ha.xml here https://lists.jboss.org/pipermail/keycloak-dev/2018-October/011304.html .

обновление команды построения образа до

 COPY ./_resources/standalone.xml /opt/jboss/keycloak/standalone/configuration/standalone-ha.xml
  

должно помочь