spring-boot - 内嵌Keycloak spring boot应用,将keycloak从12升级到14

标签 spring-boot keycloak

您好,我有一个带有嵌入式 Keyclock 的 SpringBoot 应用程序,使用以下示例创建
https://www.baeldung.com/keycloak-embedded-in-spring-boot-app
我正在尝试将 Keycloak 从 12 升级到 14,并将 resteasy 升级到 3.15.1.Final,将 infinispan 升级到 11.0.9.Final。应用程序无法启动,日志中除了 NullPointerException 之外没有太多内容。我想看看是否有人尝试过并有任何建议,因为日志中没有太多。谢谢

2021-07-07 10:02:05 [main] INFO  org.keycloak.services - KC-SERVICES0050: Initializing master realm
2021-07-07 10:02:07 [main] DEBUG org.keycloak.keys.GeneratedRsaKeyProviderFactory - Generated keys for master
2021-07-07 10:02:07 [main] DEBUG org.keycloak.keys.GeneratedHmacKeyProviderFactory - Generated secret for master
2021-07-07 10:02:07 [main] DEBUG org.keycloak.keys.GeneratedAesKeyProviderFactory - Generated secret for master
2021-07-07 10:02:07 [main] DEBUG org.keycloak.connections.jpa.updater.liquibase.lock.LiquibaseDBLockProvider - Going to release database lock namespace=KEYCLOAK_BOOT
2021-07-07 10:02:07 [main] DEBUG org.keycloak.connections.jpa.updater.liquibase.lock.CustomLockService - Going to release database lock
2021-07-07 10:02:07 [main] DEBUG org.keycloak.models.cache.infinispan.InfinispanUserCacheProviderFactory - Registered cluster listeners
2021-07-07 10:02:07 [main] DEBUG org.keycloak.executors.DefaultExecutorsProviderFactory - We are in managed environment. Executor 'java:jboss/ee/concurrency/executor/default' was available.
2021-07-07 10:02:07 [main] DEBUG org.keycloak.executors.DefaultExecutorsProviderFactory - Found executor for 'storage-provider-threads' under JNDI name 'java:jboss/ee/concurrency/executor/storage-provider-threads'
2021-07-07 10:02:07 [main] FATAL org.keycloak.services - java.lang.NullPointerException

2021-07-07 10:02:07 [main] DEBUG org.keycloak.executors.DefaultExecutorsProviderFactory - Found executor for 'storage-provider-threads' under JNDI name 'java:jboss/ee/concurrency/executor/storage-provider-threads'
$$$$$$$$$$$$$$$$Stachtrace$$$$$$$$$$$$$ : java.lang.NullPointerException
    at java.base/java.util.concurrent.ConcurrentHashMap.putVal(ConcurrentHashMap.java:1011)
    at java.base/java.util.concurrent.ConcurrentHashMap.put(ConcurrentHashMap.java:1006)
    at org.keycloak.executors.DefaultExecutorsProviderFactory.getExecutor(DefaultExecutorsProviderFactory.java:113)
    at org.keycloak.executors.DefaultExecutorsProviderFactory$1.getExecutor(DefaultExecutorsProviderFactory.java:68)
    at org.keycloak.utils.ServicesUtils.timeBoundOne(ServicesUtils.java:71)
    at org.keycloak.storage.AbstractStorageManager.mapEnabledStorageProvidersWithTimeout(AbstractStorageManager.java:135)
    at org.keycloak.storage.UserStorageManager.getUsersCount(UserStorageManager.java:374)
    at org.keycloak.models.cache.infinispan.UserCacheSession.getUsersCount(UserCacheSession.java:545)
    at org.keycloak.storage.user.UserQueryProvider.getUsersCount(UserQueryProvider.java:52)
    at org.keycloak.services.managers.ApplianceBootstrap.createMasterRealmUser(ApplianceBootstrap.java:99)

最佳答案

在 Spring Boot/Servlet 样式的应用程序中将嵌入式 keycloak 升级到 15 时,我们有类似的模糊错误消息。但我们最终通过爬取这个 baeldung.com tutorial 的项目的代码/历史来修复它们。是基于;托马斯达里蒙特 Embedded Keycloak Server running in a Spring Boot App .这个 repo 是对初始教程的一些升级;直到 Keycloak 13。我们将历史记录与我们的代码进行了比较,并为从 keycloak 11 到 13 的每个版本递增地应用/测试修复程序。之后,从 13 到 15 的更新更容易理解,并且错误也不那么神秘.
我们的应用程序与 Baeldung 教程中给出的示例代码并不完全相同,但下面是我们升级到 Keycloak 15.0.1 所需的更改列表。这些更改可能与您的项目不是 1:1 的,但希望这些更改可以帮助某人节省一些时间。

  • KeycloakApplication将领域设置函数从构造函数方法移至 bootstrap()方法。 ( An example fix found here )
    
    public class EmbeddedKeycloakApplication extends KeycloakApplication {
    ...

     //public EmbeddedKeycloakApplication() {
     //    createMasterRealmAdminUser();
     //    createBaeldungRealm();
     //}
    
     @Override
     protected ExportImportManager bootstrap() {
         final ExportImportManager exportImportManager = super.bootstrap();
         createMasterRealmAdminUser();
         createBaeldungRealm();
         return exportImportManager;
     }
    
  • EmbeddedKeycloakConfig我们添加了几个新的 bean 引用/工厂(Both found here)

    public class EmbeddedKeycloakConfig { ...

     @Bean("fixedThreadPool")
     public ExecutorService fixedThreadPool() {
         return Executors.newFixedThreadPool(5);
     }
    
     @Bean
     @ConditionalOnMissingBean(name = "springBootPlatform")
     protected SimplePlatformProvider springBootPlatform() {
         return (SimplePlatformProvider) Platform.getPlatform();
     }
    
  • 在我们的 keycloak-server.json 中,我们从 mapStorage 提供程序中删除了默认的“concurrenthashmap”名称,但仍然提供了 concurrenthashmap 属性。这与其他 Keycloak 15 示例相匹配。正如保罗所说,需要启用map_storage,最简单的解决方案是使用系统属性-Dkeycloak.profile.feature.map_storage=enabled -Dkeycloak.mapStorage.provider=concurrenthashmap .类似的例子可以在 Keycloak 测试套件 here 中找到。和 here . 然而 :我们在使用这些系统属性时遇到了错误,并决定我们的代码不需要它。幸运的是,“mapStorage”在教程中没有特别提及;它仅在 Referenced Tutorial Code 中找到.所以我们简单地匹配了其他 Keycloak 13+ 示例并删除了 keycloak-server.json 中的引用(如下所示)以摆脱空指针异常。

    //Change this:

     "mapStorage": {
         "provider": "${keycloak.mapStorage.provider:concurrenthashmap}",
         "concurrenthashmap": {
             "dir": "${project.build.directory:target}"
         }
     },
    
    //到这里
     "mapStorage": {
         "provider": "${keycloak.mapStorage.provider:}",
         "concurrenthashmap": {
             "dir": "${project.build.directory:target}"
         } 
     },
    
  • 使用 keycloak 版本升级了适当的 infinispan 和 rest 版本。 ( Tutorial code reference )

    < properties>

     < keycloak.version>15.0.1</keycloak.version>
    
     < !-- these should be updated together with Keycloak -->
     < !-- check keycloak-dependencies-server-all effective pom -->
     < infinispan.version>11.0.9.Final</infinispan.version>
     < resteasy.version>3.15.1.Final/resteasy.version>
    

  • 我们还在 SimplePlatformProvider 中添加了临时目录位置,因为该字段是必需的。 注意 :示例中使用的系统临时文件夹不推荐用于生产。

     @Override
     public File getTmpDirectory() {
         return System.getProperty("java.io.tmpdir");
     }
    
  • 我希望有人觉得这个信息有用,祝你好运!

    关于spring-boot - 内嵌Keycloak spring boot应用,将keycloak从12升级到14,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68288531/

    相关文章:

    spring-boot - Keycloak:无法在 Spring Boot 应用程序中加载 URL

    javascript - Keycloak javascript适配器 `keycloak.init`加载404 iframe

    java - Springboot提交未找到 Controller

    spring-boot - 如何在通过keycloak生成的访问 token (JWT)中添加自定义字段?

    java - org.hibernate.hql.internal.ast.QuerySyntaxException : unexpected token: FETCH

    java - Spring boot,如何从json文件读取特定对象,我需要什么注释?

    Keycloak +Proxy(nginx) CSP header 问题 ({{notification.header}} {{notification.message}})

    angularjs - Keycloak + AngularJS : persist URL hash fragments after login redirect url

    keycloak - 领域的脚本主题配置

    spring-boot - Spring-Boot入门测试导入未解决