Использование нативного артефакта Maven (nar) в веб-приложении

У меня есть собственная разделяемая библиотека, которая создается и упаковывается с помощью плагина maven-nar. Это прекрасно работает и основывается на Linux/MacOSX/Windows. Я также определил библиотеку JNI, также созданную с использованием maven-nar, которая оборачивает общую библиотеку. Оба из них создаются как артефакты NAR и требуют использования подключаемого модуля maven-nar.

Проблема возникает при объявлении зависимости от этих NAR от не-NAR-упакованного проекта. Плагин maven-nar никогда не вызывается. Только когда я изменяю упаковку проекта на NAR, включается плагин maven-nar. Это создает впечатление, что упаковка NAR должна быть заразной, чтобы работать, если есть зависимость NAR, тогда все вышестоящие проекты должны быть упакованы NAR. Это правильно или я что-то упустил?

Можно ли с успехом использовать нативную общую библиотеку и артефакты JNI, созданные с помощью плагина maven-nar, в веб-приложениях, например, WAR-файлах? Если они могут быть использованы и развернуты в WAR, как это делается? В противном случае, является ли единственной возможностью вручную разместить собственные библиотеки в каком-либо месте в java.library.path на сервере приложений?

Вот фрагмент POM для проекта, который зависит от артефакта NAR JNI:

  <?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/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>

  <parent>
    <groupId>thegroup</groupId>
    <artifactId>theparent</artifactId>
    <version>1.0-SNAPSHOT</version>
    <relativePath>../pom.xml</relativePath>
  </parent>

  <artifactId>thedependant</artifactId>
  <packaging>jar</packaging>
  <name>A nice name</name>

  ...

  <properties>
    <skipTests>true</skipTests>
  </properties>

  ...

  <build>
    <plugins>
       <plugin>
         <groupId>org.apache.maven.plugins</groupId>
         <artifactId>maven-nar-plugin</artifactId>
         <version>2.1-SNAPSHOT</version>
       </plugin>
    </plugins>
  </build>

  ...

  <dependencies>
    <dependency>
      <groupId>thegoup</groupId>
      <artifactId>theJNI</artifactId>
      <version>1.0-SNAPSHOT</version>
      <type>nar</type>
    </dependency>
  </dependencies>

  ...

</project>

1 ответ

Решение

Нет или, по крайней мере, не легко.

Если у вас есть JNI, вам нужно связываться с -Djava.library.path и, возможно, LD_LIBRARY_PATH/DYLD_LIBRARY_PATH/PATH, и всем, что должно произойти при запуске всего контейнера. Там нет механизма для распространения всего этого из войны на контейнер.

В полнофункциональной Java EE модель JCA была / предназначена для того, чтобы встроить собственный код в веб-приложения. Но типичные легкие контейнеры не поддерживают это.

Если ваш нативный код не имеет зависимостей от других общих библиотек, и если вас не беспокоит конфликты нативного кода JVM (данный нативный класс может быть только в одном загрузчике классов), тогда ваша проблема - просто получить общие объекты в войну файл на всех.

http://maven.apache.org/plugins/maven-war-plugin/examples/adding-filtering-webresources.html

это один подход. Используйте плагин maven-dependency-plugin, чтобы поместить общие библиотеки в какой-либо каталог в ${project.build.directory}, а затем выбрать их как "веб-ресурсы".

Другие вопросы по тегам