Keycloak custom spi - настраиваемый тайм-аут транзакции - PullRequest
0 голосов
/ 28 мая 2020

Я пытаюсь выполнить процесс syn c через интерфейс keycloak ImportSynchronization . (wildlfy 18.0.1.Final) он предоставляет следующий метод для переопределения:

    @Override
    public SynchronizationResult sync(
        final KeycloakSessionFactory sessionFactory,
        final String realmId,
        final UserStorageProviderModel model) {
    ...}

Этот процесс syn c занимает гораздо больше времени, чем время ожидания транзакции по умолчанию (300 se c = 5 мин).

Я знаю об этой возможной возможности:

            <core-environment node-identifier="${jboss.tx.node.id:1}">
                <process-id>
                    <uuid/>
                </process-id>
            </core-environment>
            <recovery-environment socket-binding="txn-recovery-environment" status-socket-binding="txn-status-manager"/>
            <coordinator-environment statistics-enabled="${wildfly.transactions.statistics-enabled:${wildfly.statistics-enabled:false}}"
                                     default-timeout="${env.TRANSACTION_TIMEOUT_SEC:300}"/>
            <object-store path="tx-object-store" relative-to="jboss.server.data.dir"/>
        </subsystem>

НО это это не то, что я хочу, к сожалению.

Я не хочу, чтобы увеличивал время ожидания для всех наших процессов, только для этого один. Это означает, что я ищу решение для настраиваемого тайм-аута транзакции. (что-то вроде @TransactionTimeout ...)


Я пробовал следующие


@Override
    public SynchronizationResult doCleanup(final KeycloakSessionFactory keycloakSessionFactory, final String realmId)  {
        final SynchronizationResult synchronizationResult = new SynchronizationResult();

        try {

            final RealmModel realmModel = this.getRealmModelInTx(realmId, keycloakSessionFactory);

            Thread.sleep(<more than tx timeout>);

            final int userEntityCountBeforeCleanup = this.getUserCountInTx(realmModel, keycloakSessionFactory);
...}

и в обоих методах, я создал новый keycloakSession и новый transactionManager и закрыл их, как здесь:

    private CleanupTransactionHandler createSession(final KeycloakSessionFactory  keycloakSessionFactory) {
        KeycloakTransactionManager transactionManager = null;
        final KeycloakSession keycloakSession = keycloakSessionFactory.create();

        log.tracef("KeycloakSession has been created [%s].", keycloakSession.hashCode());
        transactionManager = keycloakSession.getTransactionManager();
        transactionManager.begin();
        log.tracef("KeycloakTransactionManager's transaction has been begun [%s].", transactionManager.hashCode());
        return new CleanupTransactionHandler(keycloakSession,transactionManager);
    }

    private void closeSession(final KeycloakSession keycloakSession) {
        keycloakSession.close();
        log.tracef("KeycloakSession has been closed [%s].", keycloakSession.hashCode());
    }

    private void rollback(final KeycloakTransactionManager keycloakTransactionManager) {
        keycloakTransactionManager.rollback();
        log.tracef("KeycloakTransactionManager's transaction has been rolled back [%s].", keycloakTransactionManager.hashCode());
    }

1 Ответ

0 голосов
/ 30 мая 2020

Я могу ответить на свой вопрос.

Нет возможности настроить тайм-аут транзакции для этого процесса, поскольку ImportSynchronization.syn c вызывается из KeycloakModelUtils.runJobInTransaction, который можно настроить только через тайм-аут по умолчанию, как указано выше.

...