Как встроить внешние jar-зависимости в комплекты OSGI? - PullRequest
2 голосов
/ 21 июня 2019

Я пытаюсь преобразовать свой проект в приложение OSGI.У меня мало сомнений.Предположим, что ModuleA в моем приложении зависит от внешних jar-файлов jarA и jarB.Теперь, чтобы запустить ModeuleA, я встраиваю оба jar-файла, используя свойство embed-dependency в maven-bundle-plugin.Теперь предположим, что у меня есть другой модуль ModuleB, который также зависит от jarA.Таким образом, этот модуль также встраивает JARA.Мой проект заканчивается тем, что jarA внедряется 2 раза, что излишне увеличивает размер проекта.

Можно ли сказать OSGI, что нужно загрузить jarA только один раз и предоставить его обоим модулям.

Если преобразование этих jar-файлов в пакеты OSGI является единственным решением, у меня есть еще несколько вопросов:

  1. Какой самый простой способ преобразования jar-файла в пакет.Инструмент BND выглядит хорошим решением, но я не могу найти соответствующую документацию по нему.

  2. jarA также будет иметь несколько зависимых jar-файлов.Так что мне нужно также конвертировать все зависимые банки в связки.В моем проекте более 100 банок.Как я могу автоматизировать этот процесс.

Заранее спасибо:)

1 Ответ

0 голосов
/ 21 июня 2019

На самом деле есть решения для этого, оба немного отличающиеся от того, что вы делаете сейчас:

  1. Сборка один пакет "сторонних зависимостей", который будетВнедрить все зависимости, отличные от OSGi, которые есть в вашем проекте.
  2. Преобразовать каждую зависимость, отличную от OSGi, в комплект OSGi.

Вариант 1 легче обрабатывать, поэтому я думаю, что большинство проектов делают это.Лично я предпочитаю вариант 2. У нас есть шаблон Maven «pom.xml», который мы используем для преобразования этих зависимостей.

«pom.xml» выглядит следующим образом:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" 
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

    <modelVersion>4.0.0</modelVersion>

    <properties>
        <library.groupId></library.groupId>
        <library.artifactId></library.artifactId>
        <library.version></library.version>
    </properties>

    <artifactId></artifactId>
    <packaging>bundle</packaging>

    <name></name>
    <description>${library.groupId}:${library.artifactId}:${library.version}</description>

    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.felix</groupId>
                <artifactId>maven-bundle-plugin</artifactId>
                <extensions>true</extensions>
                <configuration>
                    <instructions>
                        <Import-Package>*;resolution:=optional</Import-Package>
                        <Export-Package>*</Export-Package>
                        <Embed-Dependency>*;scope=compile|runtime;inline=true</Embed-Dependency>
                        <Embed-Transitive>true</Embed-Transitive>
                    </instructions>
                </configuration>
            </plugin>
        </plugins>
    </build>

    <dependencies>
        <dependency>
            <groupId>${library.groupId}</groupId>
            <artifactId>${library.artifactId}</artifactId>
            <version>${library.version}</version>
        </dependency>
    </dependencies>

</project>

Это делает:

  1. Добавить не-OSGi библиотеку как зависимость
  2. Скажите maven-bundle-plugin, чтобы встроить эту зависимость (транзитивно)
  3. Скажите maven-bundle-plugin для экспорта всехиз пакетов зависимостей

Я оставил некоторые вещи пустыми, которые вы должны установить, например library.groupId, library.artifactId и library.version.И кое-что нам нужно настроить в maven-bundle-plugin.Но это наша отправная точка.К примеру, вы не хотите экспортировать все пакеты и т. Д.

Если у вас действительно есть 100+ зависимостей, которые вам нужно преобразовать, вам лучше использовать этот шаблон и просто добавить все свои 100 зависимостей в качестве зависимостии соберите одну большую связку со всеми ними внутри.

Документацию по maven-bundle-plugin можно найти здесь:

https://felix.apache.org/documentation/subprojects/apache-felix-maven-bundle-plugin-bnd.html

На данный момент я также хочуупомянуть, что есть новый плагин пакета, который вы можете рассмотреть для этого: bnd-maven-plugin.

См .: https://github.com/bndtools/bnd/tree/master/maven/bnd-maven-plugin

...