Тихо не может разрешить javax.rmi после переключения на Java -11 - PullRequest
1 голос
/ 04 августа 2020

Я пытаюсь переключить наш устаревший многомодульный проект на Java -11, но жалуется на отсутствие зависимостей в моем файле pom, я добавил версию JDK как 11. Вот часть pom

...
 <properties>
    
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.source>11</maven.compiler.source>
    <maven.compiler.target>11</maven.compiler.target>
    <jdk-version>11</jdk-version>
    <!-- Plugins tycho version -->
    <tycho.version>1.7.0</tycho.version>
...
 </properties>
<build>
...
<plugin>
        <groupId>org.eclipse.tycho</groupId>
        <artifactId>tycho-compiler-plugin</artifactId>
        <version>${tycho.version}</version>
        <configuration>
          <source>${jdk-version}</source>
          <target>${jdk-version}</target>
        </configuration>
      </plugin>
...
</build>

А вот мой файл META-INF / MANIFEST.MF

Manifest-Version: 1.0
Bundle-ManifestVersion: 2
Meta-Persistence: META-INF/openjpa_persistence_product.xml
Bundle-Name: JPA
Bundle-SymbolicName: com.XXX.jpa
Bundle-Version: 2.1.2
Bundle-Vendor: XXX
Bundle-RequiredExecutionEnvironment: JavaSE-11
Eclipse-ExtensibleAPI: true
Import-Package: com.XXX.config,
 com.XXX.core,
 com.XXX.core.util.logging,
 com.XXX.sql,
 javax.persistence,
 javax.persistence.criteria,
 javax.persistence.metamodel,
 org.apache.openjpa.persistence,
 org.apache.openjpa.util,
 org.osgi.framework,
 org.osgi.service.component,
 org.osgi.service.jdbc,
 org.osgi.service.jndi,
 org.osgi.service.jpa,
 org.slf4j
Export-Package: com.XXX.jpa,
 com.XXX.jpa.concurrent,
 com.XXX.jpa.util
Service-Component: OSGI-INF/*.xml
Bundle-ActivationPolicy: lazy

После выполнения mvn clean install я получил

ERROR] Cannot resolve project dependencies:
[ERROR]   Software being installed: com.XXX.jpa 2.1.2
[ERROR]   Missing requirement: org.apache.openjpa 3.0.0 requires 'java.package; javax.rmi 0.0.0' but it could not be found
[ERROR]   Cannot satisfy dependency: com.XXX.jpa 2.1.2 depends on: java.package; org.apache.openjpa.persistence 0.0.0

То, что я пробовал

  1. добавить версию в org. apache .openjpa.persistence, org. apache .openjpa.util в MANIFEST.MF
  2. добавить javax.rmi в раздел Import-Package в MANIFEST.MF

Но результат всегда был один - тихо жалобы на пакет javax.rmi

ОБНОВЛЕНИЕ Привет @howlger! Спасибо за вашу помощь, но теперь я получил еще одну проблему

  1. Я создаю bunlde для javax.rmi
  <parent>
    <groupId>com.XXX</groupId>
    <artifactId>bundle.platform</artifactId>
    <version>2.1.2</version>
    <relativePath>../pom.xml</relativePath>
  </parent>
  
  <!-- This bundle was added because in Java-11 javax.rmi package was removed from the standard library -->
  <groupId>com.XXX</groupId>
  <artifactId>com.XXX.javax.rmi</artifactId>
  <version>1.0.6.Final</version>
  <packaging>bundle</packaging>
  <name>Java RMI API Bundle</name>
  
  <dependencies>
    <dependency>
      <groupId>org.jboss.spec.javax.rmi</groupId>
      <artifactId>jboss-rmi-api_1.0_spec</artifactId>
      <version>${project.version}</version>
    </dependency>
  </dependencies>

<build>
    <plugins>
      <plugin>
        <groupId>org.apache.felix</groupId>
        <artifactId>maven-bundle-plugin</artifactId>
        <extensions>true</extensions>
        <configuration>
          <instructions>
            <Export-Package>
              *;version="${project.version}"
            </Export-Package>
            <Import-Package>
              *
            </Import-Package>
            <Embed-Dependency>*;scope=compile|runtime;inline=true</Embed-Dependency>
            <Bundle-SymbolicName>
              ${project.artifactId}
            </Bundle-SymbolicName>
          </instructions>
        </configuration>
      </plugin>
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-dependency-plugin</artifactId>
      </plugin>
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-deploy-plugin</artifactId>
      </plugin>
    </plugins>
  </build>

и развертываю его в нашем артефакте, но, к сожалению, не могу добавить этот пакет в функцию p2

Я добавил его как зависимость от основного файла pom, который создает репозиторий p2 как

 <dependencies>
 <!-- com.XXX.javax.rmi -->
    <dependency>
      <groupId>org.jboss.spec.javax.rmi</groupId>
      <artifactId>jboss-rmi-api_1.0_spec</artifactId>
      <version>${javax.rmi.version}</version>
    </dependency>    
    <dependency>
      <groupId>org.jboss.spec.javax.rmi</groupId>
      <artifactId>jboss-rmi-api_1.0_spec</artifactId>
      <version>${javax.rmi.version}</version>
      <classifier>sources</classifier>
    </dependency>
 </dependencies> 

Но когда я пытаюсь добавить этот пакет в функцию платформы как плагин

<plugin
        id="com.XXX.javax.rmi"
        download-size="0"
        install-size="0"
        version="0.0.0"
        unpack="false"/>

Я получил:

[ERROR] Cannot resolve project dependencies:
[ERROR]   Software being installed: com.XXX.repository 2.1.2
[ERROR]   Missing requirement: com.XXX.bundle.platform.feature.feature.group 2.1.2 requires 'org.eclipse.equinox.p2.iu; com.navteq.javax.rmi 0.0.0' but it could not be found
[ERROR]   Cannot satisfy dependency: com.navteq.phoenix.repository 2.1.2 depends on: org.eclipse.equinox.p2.iu; com.navteq.phoenix.bundle.platform.feature.feature.group [2.1.2,2.1.3)
[ERROR]

Что я делаю неправильно?

UPDATE2 В этой проблеме было 2 основных проблемы

  1. Неправильная зависимость в основном файле pom, который создает репозиторий p2 - он должен иметь тот же groupId, artifactId, версию, что и те, что в pom, который создает бандл
<dependencies>
 <!-- com.XXX.javax.rmi -->
    <dependency>
      <groupId>com.XXX</groupId>
      <artifactId>com.XXX.javax.rmi</artifactId>
      <version>1.0.6.Final</version>
    </dependency>
 </dependencies>
Импорт sun.refelection должен быть добавлен в файл pom, который создал бандл
<configuration>
  <instructions>
    <Export-Package>
      *;version="${project.version}"
    </Export-Package>
    <Import-Package>
      sun.reflect;resolution:=optional
    </Import-Package>
    <Embed-Dependency>*;scope=compile|runtime;inline=true</Embed-Dependency>
    <Bundle-SymbolicName>
      ${project.artifactId}
    </Bundle-SymbolicName>
  </instructions>
</configuration>

1 Ответ

1 голос
/ 04 августа 2020

Пакет javax.rmi содержал в системной библиотеке (в Java 9 и 10 в модуле java.corba) до тех пор, пока не был удален в Java 11 с помощью JEP 320 .

Для Java 11 или выше вам необходимо добавьте плагин / пакет , содержащий пакет javax.rmi , на вашу целевую платформу , так как это требуется для org.apache.openjpa плагина / пакета, который у вас есть. Или, может быть, есть более новая версия org.apache.openjpa, которая содержит пакет javax.rmi или больше не требует его.

...