”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 扩展 Quarkus:何时以及如何编写自己的扩展

扩展 Quarkus:何时以及如何编写自己的扩展

发布于2024-11-16
浏览:619

Extending Quarkus: When and How to Write Your Own Extensions

Quarkus 凭借其创新的扩展框架,为开发人员提供了一种将各种技术无缝集成到其应用程序中的强大方法。这些扩展简化了配置、启用依赖项注入并优化了性能,使其成为 Java 开发人员的一个有吸引力的选择。然而,在深入创建您自己的 Quarkus 扩展之前,了解何时需要以及如何有效地做到这一点至关重要。

何时创建 Quarkus 扩展

  1. 复杂集成: 如果您正在使用 ORM 映射器、响应式客户端或数据访问库等复杂框架,那么创建扩展可以帮助管理复杂的配置和依赖项管理。扩展简化了 Quarkus 应用程序中这些框架的使用。

  2. 性能优化: Quarkus 扩展旨在与 Quarkus 的本机编译保持一致,从而使应用程序能够快速启动并具有最小的内存占用。通过创建扩展,您可以利用 Quarkus 的构建时优化能力来扫描依赖项并尽早生成配置,从而避免启动延迟。

  3. 开发者体验增强:扩展可以显着增强开发者体验。它们支持实时重新加载、CLI 扩展、模板化等,从而简化了开发过程。如果您想为您的团队提供无缝且高效的开发环境,扩展可以帮助实现这一目标。

  4. API 强化: 如果您正在构建供其他 Quarkus 开发人员使用的 API 或库,扩展提供了一种绝佳的方法来强化您的 API 并确保它们在 Quarkus 生态系统中无缝工作.

但是,扩展可能并不总是最好的方法。对于更简单的需求,例如在组件之间共享实用程序代码和粘合逻辑,基本的 JAR 文件可能就足够了,而无需创建扩展的开销。如果您的集成是特定于应用程序的并且不太可能在其他地方重用,则基本 JAR 可能是更简单的解决方案。此外,如果您需要完全控制依赖项版本,并且不想遵守 Quarkus 的 BOM(物料清单)进行依赖项管理,那么 JAR 可能是更好的选择。最后,如果您的代码需要跨多个 JVM 框架工作,例如 SpringMicronaut,最好避免与 Quarkus 紧密耦合。

创建 Quarkus 扩展可能很复杂,通常需要深入了解 Quarkus 内部工作原理。然而,对于许多场景,创建标准 JAR 就足够了。当 Jandex 索引此 JAR 时,Quarkus 可以在构建期间无缝地发现该 JAR。虽然 Quarkus 扩展提供了一系列优势,包括卓越的性能和开发人员生产力,但它们可能并不总是必要的。

Quarkus 将工作转移到构建时间而不是运行时的独特方法是其快速启动时间和低内存占用的核心。这一理念延伸到了 Quarkus 扩展,它可以利用这些构建时优化。即使您主要关心的不是快速启动时间,创建扩展的好处还包括简化配置、扩展 Quarkus CLI 以及与 Quarkus 的开发模式集成。

创建 Quarkus 扩展不必过于复杂。通过正确的方法和对项目需求的清晰了解,您可以有效地解决复杂的问题。扩展提供了一种灵活而强大的方式来增强您的 Quarkus 应用程序并使其更加高效且对开发人员友好。

创建 Quarkus 扩展

当您确定创建 Quarkus 扩展是正确的方法时,了解扩展的结构组件至关重要:

  • 运行时部分: 该部分包含作为 bean、服务或与 Quarkus 集成的其他组件实现的核心业务逻辑;
  • 部署部分:部署部分处理构建时的增强和配置。它确保您的扩展与 Quarkus 的优化流程无缝集成;
  • 描述符: 描述符声明有关您的扩展的元数据,包括其名称、参数、兼容性信息等;
  • 文档: 综合文档应随您的扩展一起提供。它指导用户如何有效地使用和配置您的扩展。

Quarkus 扩展的解剖

考虑一个场景,您想要为 Quarkus 创建自定义缓存扩展。此扩展将使开发人员能够轻松地将缓存功能集成到他们的 Quarkus 应用程序中。

  1. 运行时部分:

    • 在本节中,您将使用 Java 代码实现核心缓存功能。这可能包括缓存数据、检索缓存数据和管理缓存过期的方法。
    • 例如,您可能有一个 CustomCacheService 类,其中包含 put(key, value)、get(key) 和 evict(key) 等方法来处理缓存操作。
  2. 部署部分:

    • 部署部分负责构建时优化。在这里,您可以指定在构建过程中如何生成缓存配置。
    • 对于我们的缓存扩展,本节可能包括有关如何扫描应用程序代码中的缓存对象并生成缓存配置的说明。
  3. 描述符:

    • 描述符文件 (custom-cache-extension.yaml) 提供有关您的扩展的元数据。它包括扩展名称、版本、与 Quarkus 的兼容性以及配置参数等信息。
    • 例如,您的描述符可能指定扩展名为“custom-cache-extension”,与 Quarkus 2.0 兼容,并且需要缓存超时配置参数。
  4. 文档:

    • 您的扩展应附带全面的文档。它指导用户如何在 Quarkus 应用程序中有效地使用自定义缓存扩展。
    • 文档应包括如何配置缓存、将其集成到 Quarkus 服务以及管理缓存数据的示例。此外,它应该提供缓存利用的最佳实践。

通过遵循此结构,您的自定义缓存扩展将成为 Quarkus 开发人员的宝贵工具。他们可以轻松地将缓存合并到应用程序中,从而提高性能并优化资源使用。

运行时模块:

class CustomCacheService {

    // Core caching functionality using Java code
    public void put(String key, Object value) {
      // Cache data implementation
    }

    public Object get(String key) {
      // Retrieve cached data implementation
    }

    public void evict(String key) {
      // Evict cached data implementation
    }
}

部署模块:

class CustomCacheProcessor {
    @BuildStep
    FeatureBuildItem feature() {
        // This declares the custom cache extension as a feature
        return new FeatureBuildItem("custom-cache");
    }
}

描述符文件: custom-cache-extension.yaml

extension:
name: custom-cache-extension
metadata:
    short-name: "resteasy-reactive"
    keywords:
    - "jaxrs"
    - "web"
    - "rest"
    categories:
    - "web"
    - "reactive"
    status: "stable"
    guide: "https://quarkus.io/guides/resteasy-reactive"

结论

总之,是否创建 Quarkus 扩展取决于您项目的具体需求和目标。 Quarkus 扩展是用于深度集成、性能优化和增强开发人员体验的强大工具。然而,权衡利弊并考虑更简单的解决方案(例如标准 JAR 库)是否更适合您的用例至关重要。通过了解何时以及如何有效地创建 Quarkus 扩展,您可以做出明智的决策并充分利用这一创新框架的潜力。

版本声明 本文转载于:https://dev.to/yanev/extending-quarkus-when-and-how-to-write-your-own-extensions-1a0k?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如何有效地从 JavaScript 中的另一个数组中存在的数组中删除元素?
    如何有效地从 JavaScript 中的另一个数组中存在的数组中删除元素?
    高效删除与另一个数组匹配的数组元素在 JavaScript 中,可能需要删除一个数组中存在于另一个数组中的元素。这可以有效地实现,而无需借助循环和拼接。jQuery 方法使用 jQuery,可以利用 grep() 和 inArray() 函数:myArray = $.grep(myArray, fu...
    编程 发布于2024-11-16
  • Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta:列偏移的删除和恢复Bootstrap 4 在其 Beta 1 版本中引入了重大更改柱子偏移了。然而,随着 Beta 2 的后续发布,这些变化已经逆转。从 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    编程 发布于2024-11-16
  • 很棒的免费 Tailwind 登陆页面模板
    很棒的免费 Tailwind 登陆页面模板
    几个月前,我开源了一个 tailwind 登陆页面模板列表,从那时起它就变得越来越流行,所以这里是存储库中的一些顶级 tailwind 登陆页面。 你在 Github 上查看它们并复制文件夹 从Github获取⭐️ 或者您也可以从网络目录下载 从网络下载 1.Pixa AI - Pi...
    编程 发布于2024-11-16
  • 如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 识别今天生日的用户使用 MySQL 确定今天是否是用户的生日涉及查找生日匹配的所有行今天的日期。这可以通过一个简单的 MySQL 查询来实现,该查询将存储为 UNIX 时间戳的生日与今天的日期进行比较。以下 SQL 查询将获取今天有生日的所有用户: FROM USERS ...
    编程 发布于2024-11-16
  • 如何修复 MySQL 中的“锁定等待超时超出”错误:解锁卡住的表
    如何修复 MySQL 中的“锁定等待超时超出”错误:解锁卡住的表
    解锁“卡住”的 MySQL 表:解决“Lock Wait Timeout Exceeded”问题当遇到“Lock wait timeout Exceeded; try restarted”时在 MySQL 中使用 InnoDB 表时出现“事务”错误,很可能事务已被卡住。以下是修复表并解决卡住事务的方...
    编程 发布于2024-11-16
  • 如何修复 Mac OS X 上 Python 2.7 的 OpenSSL 兼容性问题?
    如何修复 Mac OS X 上 Python 2.7 的 OpenSSL 兼容性问题?
    Mac OS X 上 Python 2.7 中的 OpenSSL 兼容性问题排查Python 利用 OpenSSL 进行安全通信。 Python 使用的 OpenSSL 版本可能因系统配置而异。当遇到终端和 Python 使用的 OpenSSL 版本不一致时,例如升级 OpenSSL 而没有看到 P...
    编程 发布于2024-11-16
  • 除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    除了“if”语句之外:还有哪些地方可以在不进行强制转换的情况下使用具有显式“bool”转换的类型?
    无需强制转换即可上下文转换为 bool您的类定义了对 bool 的显式转换,使您能够在条件语句中直接使用其实例“t”。然而,这种显式转换提出了一个问题:“t”在哪里可以在不进行强制转换的情况下用作 bool?上下文转换场景C 标准指定了四种值可以根据上下文转换为 bool 的主要场景:语句:if、w...
    编程 发布于2024-11-16
  • 如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    MySQL配置不正确:相对路径的问题在Django中运行python manage.py runserver时,可能会遇到以下错误:ImproperlyConfigured: Error loading MySQLdb module: dlopen(/Library/Python/2.7/site-...
    编程 发布于2024-11-16
  • 如何在 Chrome 扩展的 CSS 中加载本地图片?
    如何在 Chrome 扩展的 CSS 中加载本地图片?
    Google Chrome 扩展程序中的本地图像加载问题排查尽管在 Chrome 扩展程序中合并了本地图像,但用户在使用 CSS 显示它们时遇到了困难。这个问题需要解决。核心问题在于 Chrome 的 i18n 支持,它允许 CSS 引用扩展资源。要解决此问题,请考虑以下方法:将图像放置在扩展程序内...
    编程 发布于2024-11-16
  • 如何计算MySQL中参与调查的员工百分比?
    如何计算MySQL中参与调查的员工百分比?
    在 MySQL 中计算百分比在包含员工和调查数据的 MySQL 数据库中,用户试图计算参与调查的员工百分比基于记录的调查数量的调查。原始查询尝试使用以下语句得出百分比:SELECT group_name, employees, surveys, COUNT( surveys ) AS...
    编程 发布于2024-11-16
  • 如何以特定用户身份从 PHP 控制 Rhythmbox 播放?
    如何以特定用户身份从 PHP 控制 Rhythmbox 播放?
    以特定用户身份从 PHP 控制 Rhythmbox 播放以 www 用户身份运行 PHP 脚本时,控制 Rhythmbox 等外部应用程序可能会遇到访问权限限制。当脚本尝试操作应用程序,但应用程序本身与不同的用户(例如您自己的用户)关联时,就会出现此问题。为了解决此问题,可以使用多种方法。一种有效的...
    编程 发布于2024-11-16
  • 如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    在 PHP 中组合关联数组在 PHP 中,将两个关联数组组合成一个数组是一项常见任务。考虑以下请求:问题描述:提供的代码定义了两个关联数组,$array1和$array2。目标是创建一个新数组 $array3,它合并两个数组中的所有键值对。 此外,提供的数组具有唯一的 ID,而名称可能重合。要求是构...
    编程 发布于2024-11-16
  • 如何在 Android 中创建具有自定义行项目和动态更改文本的 ListView?
    如何在 Android 中创建具有自定义行项目和动态更改文本的 ListView?
    在 Android 中自定义 ListView 行项目当前的任务涉及创建一个 ListView,其中的行显示标题,然后更改文本。为此,请按照下列步骤操作:行项目的自定义布局:在您的文件中创建名为“row.xml”的自定义行布局布局文件夹:<?xml version="1.0"...
    编程 发布于2024-11-16
  • C++ 枚举可以从其他枚举继承吗?
    C++ 枚举可以从其他枚举继承吗?
    扩展枚举:探索基本枚举类继承在 C 中,枚举提供了一种表示固定值集的便捷方法。但是,在某些情况下,您可能希望从现有枚举类继承值。本题探讨了实现这种继承的可能性。枚举可以继承其他枚举吗?默认情况下,C 中的枚举类型不能从其他枚举继承。但是,我们可以利用基于类的方法来模拟枚举继承。基于类的枚举继承以下代...
    编程 发布于2024-11-16
  • 如何在Python中按空格分割字符串?
    如何在Python中按空格分割字符串?
    Python中的空白分隔字符串字符串处理是编程中一个常见任务,在Python中,可以轻松地在空白处分割字符串。利用Python的str.split()方法,你可以按空格(空白字符)将字符串分割成一个列表:>>> "many fancy word \nhello ...
    编程 发布于2024-11-16

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3