Hi Oliver,
I had the same problem with mssql-jdbc.
But it's not exactly the same because the pax-jdbc-mssql feature only
depends on pax-jdbc-spec and only includes the driver mvn:com.microsoft. .
.    And that means there's no wrapper around the driver needed for osgi
and nothing is needed specially to configure it from pax.

But the pax-jdb-oracle feature includes the driver from oracle (wrapped as
wrap:mvn: because it's not an osgi bundle) and a wrapper from pax
mvn:org.ops4j.pax.jdbc/pax-jdbc-oracle/1.5.0

So you could try not installing the bundle and just install the
pax-jdbc-spec and the mvn:org.ops4j.pax.jdbc bundle along with the driver
jar you put in deploy.

-John

On Wed, Oct 6, 2021 at 11:13 AM Oliver Fürniß <[email protected]>
wrote:

> Hello,
>
> I'm trying to upgrade from Karaf 4.2.8 to 4.3.3.
>
> With 4.2.8 I was able to place the required Oracle driver to the
> deploy-folder and do a "feature:install pax-jdbc-oracle". With 4.3.3 it
> seems to be a little bit different. When I place the ojdbc6.jar or
> ojdbc7.jar or ojdbc8.jar in the deploy folder I will get the error below
> (at the end) after "feature:install pax-jdbc-oracle".
>
> It works when I do not place a specific Oracle driver to the deploy folder
> and just do "feature:install pax-jdbc-oracle". In this case it installs the
> latest Oracle driver by using maven.
>
> This is different to 4.2.8 and not the expected behaviour. IMO the latest
> Oracle driver cannot be used for all Oracle versions. Even Oracle provides
> specific downloads of their JDBC driver for different DB versions:
> https://www.oracle.com/de/database/technologies/appdev/jdbc-downloads.html
>
> In the ops4j features.xml file details is written, that "This feature
> requires actual Oracle JDBC driver installed", which conflicts with the
> auto bundle dependency installation of the latest Oracle driver. This line
> does not exist in 4.2.8.
>
> <feature name="pax-jdbc-oracle" description="Provides JDBC Oracle
> DataSourceFactory" version="${project.version}">
>
>     <details>This feature requires actual Oracle JDBC driver 
> installed</details>
>     <feature>pax-jdbc-spec</feature>
>
>     <bundle 
> dependency="true">wrap:mvn:com.oracle.database.jdbc/ojdbc8/${version.com.oracle.database.jdbc}</bundle>
>     <bundle>mvn:org.ops4j.pax.jdbc/pax-jdbc-oracle/${project.version}</bundle>
> </feature>
>
> Is there a reason why the latest and not with all Oracle versions
> compatible driver gets installed? Am I able to install somehow a different
> version of the Oracle driver?
>
> All the best,
>  Oliver
>
>
> karaf@root()> feature:install pax-jdbc-oracle
> org.apache.karaf.features.internal.util.MultiException: Error restarting
> bundles:
> Activator start error in bundle org.ops4j.pax.jdbc.oracle [223].
> at
> org.apache.karaf.features.internal.service.Deployer.deploy(Deployer.java:1049)
> at
> org.apache.karaf.features.internal.service.FeaturesServiceImpl.doProvision(FeaturesServiceImpl.java:1069)
> at
> org.apache.karaf.features.internal.service.FeaturesServiceImpl.lambda$doProvisionInThread$13(FeaturesServiceImpl.java:1004)
> at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264)
> at
> java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)
> at
> java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)
> at java.base/java.lang.Thread.run(Thread.java:829)
> Suppressed: org.osgi.framework.BundleException: Activator start error in
> bundle org.ops4j.pax.jdbc.oracle [223].
> at org.apache.felix.framework.Felix.activateBundle(Felix.java:2452)
> at org.apache.felix.framework.Felix.startBundle(Felix.java:2308)
> at org.apache.felix.framework.BundleImpl.start(BundleImpl.java:998)
> at org.apache.felix.framework.BundleImpl.start(BundleImpl.java:984)
> at
> org.apache.karaf.features.internal.service.BundleInstallSupportImpl.startBundle(BundleInstallSupportImpl.java:165)
> at
> org.apache.karaf.features.internal.service.FeaturesServiceImpl.startBundle(FeaturesServiceImpl.java:1160)
> at
> org.apache.karaf.features.internal.service.Deployer.deploy(Deployer.java:1041)
> ... 6 more
> Caused by: java.lang.NoClassDefFoundError: oracle/jdbc/internal/Monitor
> at java.base/java.lang.ClassLoader.defineClass1(Native Method)
> at java.base/java.lang.ClassLoader.defineClass(ClassLoader.java:1017)
> at
> org.apache.felix.framework.BundleWiringImpl$BundleClassLoader.defineClass(BundleWiringImpl.java:2312)
> at
> org.apache.felix.framework.BundleWiringImpl$BundleClassLoader.defineClassParallel(BundleWiringImpl.java:2130)
> at
> org.apache.felix.framework.BundleWiringImpl$BundleClassLoader.findClass(BundleWiringImpl.java:2064)
> at
> org.apache.felix.framework.BundleWiringImpl.findClassOrResourceByDelegation(BundleWiringImpl.java:1533)
> at
> org.apache.felix.framework.BundleWiringImpl.access$300(BundleWiringImpl.java:78)
> at
> org.apache.felix.framework.BundleWiringImpl$BundleClassLoader.loadClass(BundleWiringImpl.java:1950)
> at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:522)
> at
> org.apache.felix.framework.BundleWiringImpl.getClassByDelegation(BundleWiringImpl.java:1343)
> at
> org.apache.felix.framework.BundleWiringImpl.searchImports(BundleWiringImpl.java:1586)
> at
> org.apache.felix.framework.BundleWiringImpl.findClassOrResourceByDelegation(BundleWiringImpl.java:1516)
> at
> org.apache.felix.framework.BundleWiringImpl.access$300(BundleWiringImpl.java:78)
> at
> org.apache.felix.framework.BundleWiringImpl$BundleClassLoader.loadClass(BundleWiringImpl.java:1950)
> at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:522)
> at org.ops4j.pax.jdbc.oracle.impl.Activator.start(Activator.java:29)
> at
> org.apache.felix.framework.util.SecureAction.startActivator(SecureAction.java:698)
> at org.apache.felix.framework.Felix.activateBundle(Felix.java:2402)
> ... 12 more
> Caused by: java.lang.ClassNotFoundException: oracle.jdbc.internal.Monitor
> not found by ojdbc7.jar [222]
> at
> org.apache.felix.framework.BundleWiringImpl.findClassOrResourceByDelegation(BundleWiringImpl.java:1565)
> at
> org.apache.felix.framework.BundleWiringImpl.access$300(BundleWiringImpl.java:78)
> at
> org.apache.felix.framework.BundleWiringImpl$BundleClassLoader.loadClass(BundleWiringImpl.java:1950)
> at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:522)
> at
> org.apache.felix.framework.BundleWiringImpl.getClassByDelegation(BundleWiringImpl.java:1343)
> at
> org.apache.felix.framework.BundleWiringImpl.searchImports(BundleWiringImpl.java:1586)
> at
> org.apache.felix.framework.BundleWiringImpl.findClassOrResourceByDelegation(BundleWiringImpl.java:1516)
> at
> org.apache.felix.framework.BundleWiringImpl.access$300(BundleWiringImpl.java:78)
> at
> org.apache.felix.framework.BundleWiringImpl$BundleClassLoader.loadClass(BundleWiringImpl.java:1950)
> at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:522)
> ... 30 more
> Error executing command: Error restarting bundles:
> Activator start error in bundle org.ops4j.pax.jdbc.oracle [223].
>
>

Reply via email to